الخميس، 20 أغسطس 2020

El Impacto De La Legislación De Derecho De Autor En América Latina Y El Caribe

El libro digital Bibliotecas LAC: El impacto de la legislación de derecho de autor en América Latina y el Caribe, tiene la pretensión de servir como instrumento de apoyo para los profesionales de la región.



América Latina y el Caribe es una región con alta concentración de países sin o con pocas limitaciones y excepciones a los derechos de autor y derechos conexos específicamente para las bibliotecas, archivos y museos. Incluso cuando estas limitaciones y excepciones existen, en la mayoría de casos no están adecuadamente adaptadas al ámbito digital. Solamente con la presencia de limitaciones y excepciones modernas en las leyes nacionales y con instrumentos o tratados internacionales, dichas instituciones culturales podrán continuar ofreciendo sus servicios y productos con la calidad necesaria y, principalmente, asegurando el acceso democrático, igualitario y de derecho a todos los ciudadanos.


Con el objetivo de actuar en ese contexto, el Comité Permanente de la Sección para América Latina y el Caribe de la Federación Internacional de Asociaciones de Bibliotecas e Instituciones (IFLA LAC) realizó, en 2016, el proyecto integrado "Impacto de la legislación sobre los derechos de autor en las bibliotecas en América Latina y el Caribe", cuyo objetivo era identificar y registrar las principales dificultades, problemas y situaciones que las bibliotecas enfrentan diariamente en la situación de trabajo, causados por la falta de actualización, la complejidad o la ausencia de leyes nacionales de derechos de autor en la región.


Este libro tiene la pretensión de servir como instrumento de apoyo para los profesionales de la región en lo concerniente a: 

(a) el desarrollo de estrategias y acciones más contundentes para buscar el equilibrio legal en sus países en lo que se refiere a la Ley de derechos de autor, 

(b) la identificación de los principales puntos de debate sobre el tema de las limitaciones y excepciones al derecho de autor, 

(c) la inserción de la temática en el programa y disciplinas de los cursos de graduación y programas de posgrado en biblioteconomía y ciencia de la información de los diferentes países y, finalmente, 

(d) la divulgación de los resultados aquí alcanzados con los países de América Latina y el Caribe, de modo a establecer una red de intercambio y apoyo entre los profesionales de la región.


En este espíritu de colaboración, en marzo de 2020 se lanzó el libro, la Comisión Brasileña de Derechos de Autor y Acceso Abierto de la FEBAB (CBDA3) asumió la tarea de editar y publicar este libro electrónico con los resultados finales. Quince países decidieron participar: Argentina, Brasil, Chile, Cuba, Ecuador, El Salvador, Guatemala, Haití, Jamaica, México, Nicaragua, Panamá, Perú, República Dominicana, Trinidad y Tobago.


Libro disponible en el sitio web de FEBAB (Federação Brasileira de Associações de Bibliotecários, Cientistas de Informação e Instituições):


CLICK AQUÍ


Fuente: IFLA


Related word


  1. What Does Vieja Mean
  2. Like Viaje A Israel
  3. Lifestyle Of A Butterfly
  4. Words Similar To Viaje
  5. Lifestyle Victoria
  6. Curiosidades Mundo
  7. Curiosidades Mundo
  8. Lifestyle Vs Trojan Condoms
  9. Viaje Redondo A Cancun
  10. Curiosidades 25 De Abril
  11. Viaje Por Viajes
  12. Curiosidades Plants Vs Zombies 2
  13. 90 Curiosidades Do Mundo
  14. Lifestyle Hashtags
  15. Viaje Birthday Blend 2020
  16. Lifestyle Block
  17. Curiosidades 3M
  18. Viaje Mais
  19. Viaje En El Tiempo Pelicula
  20. Lifestyle Vs Personal Blog
  21. When Will Lifestyle Sale Start
  22. Will Lifestyle Shirts
  23. Will Lifestyle Store
  24. Viaje Na Viagem Londres
  25. Lifestyle Vs Way Of Life
  26. Like Curiosidades
  27. Where Is Lifestyle Christianity Located
  28. When Lifestyle Variations Are Taken In Account
  29. Lifecycle 9500Hr Battery
  30. Lifestyle 650 Review
  31. Viaje 4 De Cristobal Colon
  32. Lifestyle Youtubers
  33. Viaje Olvidado
  34. How Much Are Lifestyle Garage Door Screens
  35. Viaje Ghost Rider
  36. Curiosidades De Paises
  37. Viaje Y Mesa Electoral
  38. Viaje
  39. Lifestyle Begumpet
  40. Curiosidades 2020
  41. Curiosidades França
  42. Viaje 3 De La Tierra Ala Luna
  43. Lifestyle And Mobility
  44. Lifestyle Habits
  45. Where Is Lifestyle Shopping Mall
  46. Curiosidades Gatos
  47. 01 Viaje Al Centro De La Tierra
  48. Curiosidades Alina Reno Nv
  49. 66 Curiosidades De La India
  50. Will Lifestyle Shirts
  51. Curiosidades 29 De Febrero
  52. Is Viaje In English Word
  53. Curiosidades Que No Sabias
  54. Lifestyle 8880 Dumaguete
  55. 8 Curiosidades Sobre O Trânsito
  56. Curiosidades Del Cuerpo Humano
  57. Viaje 7 Tazas
  58. Curiosidades Sobre Two And A Half Man
  59. Curiosidades Zoom
  60. Lifestyle 94 India
  61. Viaje Virtual A La Luna
  62. Viaje 6 Dias Polonia
  63. Lifestyle Owner
  64. Curiosidades 11 De Septiembre
  65. Viaje 8 Dias Egipto
  66. Lifestyle Home Products
  67. Lifestyle Ultra Sensitive
  68. Curiosidades How To Get Away With A Murderer
  69. How You Say Viaje In English
  70. Lifestyle Medicine
  71. Will Smith Viaje
  72. To Lifestyle Factors
  73. Viaje Jalapeno Phat
  74. Lifestyle Fitness
  75. Lifestyle Near Mg Road
  76. Curiosidades Guns And Roses
  77. Curiosidades Outer Banks
  78. Curiosidades Torre Eiffel
  79. Is Lifestyle A Niche
  80. Viaje Humanitario Colombia
  81. Lifestyle Near Garuda Mall
  82. Viaje Virtual A La Luna
  83. Will Lifestyle Store Near Me
  84. Viaje 4 Patas
  85. Curiosidades Você Sabia
  86. Curiosidades Karate
  87. Lifestyle Near Me
  88. Lifestyle 550
  89. Lifestyle 600 System
  90. Viaje 1 La Isla Misteriosa
  91. Lifestyle Food
  92. Viaje Virtual A La Luna
  93. Viaje Sin Rumbo
  94. Viaje Oro Reserva Vor No. 5
  95. Lifestyle Large
  96. Viaje En El Tiempo Pelicula
  97. Viaje Onirico
  98. How Much Do Lifestyle Coaches Make
  99. Viaje Na Viagem Los Angeles
  100. Lifestyle 101
  101. With Lifestyle Change
  102. Curiosidades 1917
  103. Viaje Oro Cigar
  104. Viaje Internacional
  105. Viaje To Travel
  106. Curiosidades Mexico
  107. Lifestyle Zambia
  108. Why Lifestyle Center
  109. Curiosidades 3Ds
  110. Lifestyle Of Riyaz
  111. Lifestyle 650 Home Entertainment System
  112. Curiosidades 8 Millas
  113. Curiosidades Lingua Portuguesa
  114. Curiosidades Sobre O Brasil
  115. 69 Curiosidades De Dragon Ball Super Broly
  116. Viaje 4 Dias Pais Vasco
  117. Curiosidades Jojo Rabbit
  118. Viaje 1 La Isla Misteriosa
  119. Viaje 5 Dias Europa
  120. Lifestyle By Focus
  121. Viaje 6 Dias Europa
  122. Viaje 7 Dias Marruecos
  123. Viaje Jet
  124. Lifestyle Vlog Ideas
  125. Curiosidades Biologia
  126. Viaje Mitico
  127. Lifestyle Without Gallbladder
  128. Viaje 12 Gauge
  129. Viaje Del Usuario
  130. Curiosidades Red Dead Redemption 2
  131. Curiosidades Google Earth
  132. Curiosidades 9/11
  133. Curiosidades 14 De Febrero
  134. Curiosidades Roma
  135. What Lifestyle Can I Afford Calculator
  136. Curiosidades Sobre Animais
  137. Lifestyle And Wellness
  138. Lifestyle And Co
  139. Curiosidades Kurt Cobain
  140. Where Are Lifestyle Campers Made
  141. Lifestyle 24
  142. Who Lifestyle Questionnaire
  143. Curiosidades One Piece
  144. Lifestyle Xl Condoms Size
  145. Lifestyle Entrepreneur
  146. Lifestyle 7-In-1 Desktop Game Set
  147. What Does Curiosidades Means In English
  148. Curiosidades 14 De Febrero
  149. Viaje Gender
  150. Viaje Can
  151. Viajes Baratos
  152. Freestyle Libre
  153. Curiosidades Sobre Two And A Half Man
  154. Curiosidades Umbanda
  155. 90 Curiosidades Do Mundo
  156. Lifestyle Z Square Kanpur
  157. Curiosidades De Chile
  158. Will Lifestyle Online
  159. Viaje 8 Dias Egipto
  160. Lifestyle 901
  161. Lifestyle Blogs Like The Tig
  162. Curiosidades Bts
  163. Curiosidades Xiaomi
  164. Lifestyle Quotes
  165. What Does Vieja Mean In Spanish

Hacking All The Cars - Part 1


A step by step lab based mini course on analyzing your car network


I wanted to learn about hacking cars. As usual I searched around the internet and didn't find any comprehensive resources on how to do this, just bits and pieces of the same info over and over which is frustrating. I am not a car hacking expert, I just like to hack stuff. This mini course will run in a fully simulated lab environment available from open garages, which means in 5 minutes from now you can follow along and hack cars without ever bricking your girlfriends car. Since you obviously wouldn't attack your own Lambo, totally use your girlfriends Prius. 

Below are the topics covered in this blog  series so you can decide if you want to read further: 

Whats covered in this car hacking mini course: 

Setting up Virtual Environments for testing
Sniffing CAN Traffic
Parsing CAN Traffic
Reverse Engineering CAN IDs 
Denial of service attacks
Replaying/Injecting Traffic
Coding your own CAN Socket Tools in python
Targeted attacks against your cars components
Transitioning this to attacking a real car with hardware

The first thing we are going to do before we get into any car hacking specifics such as "WTF is CAN?", is get your lab up and running. We are going to run a simple simulated CAN Bus network which controls various features of your simulated car. Its better to learn by doing then sit here and recite a bunch of car network lingo at you and hope you remember it.  

I also don't want you to buy a bunch of hardware and jack into your real car right away. Instead there are options that can get you started hacking cars RIGHT NOW by following along with this tutorial. This will also serve to take away the fear of hacking your actual car by understanding what your doing first. 


Video Playlist: 




Setting up your Lab: 

First things first, set yourself up with an Ubuntu VMware install, and load it up. Optionally you could use a Kali Iinux VM, however, that thing drives me nuts with copy paste issues and I think Kayak was giving me install problems. So support is on you if you would like to use Kali. However, I do know Kali will work fine with OpenGarages virtual car.. So feel free to use it for that if you have it handy and want to get started right away. 


Install PreReq Libraries: 

Once you load this up you are going to want to install CAN utilities and pre-requisite libraries. This is really easy to do with the following Apt-get commands:
sudo apt-get update
sudo apt-get install libsdl2-dev libsdl2-image-dev can-utils  

Then we are going to pull down the ICSimulator repo: 


Starting the simulator: 

Once this is done we can startup the simulator by changing directories to the downloaded repo and running the following 2 commands, which will setup a virtual CAN interface and a simulator GUI Cluster: 

Run the setup Script to get the vcan0 interface up: 
root@kali:~/ICSim# ./setup_vcan.sh 
root@kali:~/ICSim# ./icsim vcan0

On a new terminal tab we will open up our simulators controller with the following command,
root@kali:~/ICSim#./controls vcan0

Note: that the controller must be the in-focus GUI screen to send keyboard commands to the simulator. 






How to Use the Simulator: 

The simulator has a speedometer with Right and Left turn signals, doors etc.  Below are the list of commands to control the simulator when the Control panel is in focus. Give them each a try and note the changes to the simulator. 
Up and Down keys control the gauges clusters speedometer
Left and Right keys Control the Blinkers
Right Shift + X, A or B open doors 
Left Shift + X, A or be Close doors

Try a few of the above commands for example Right Shift +X and you will see the interface change like so, notice the open door graphic: 


Awesome, thanks to OpenGarages you now you have your very own car to hack

Notice in the setup commands above we used a VCan0 interface. Run Ifconfig and you will now see that you indeed have a new network interface that speaks to the CAN network over VCan0. 

ficti0n@ubuntu:~/Desktop/ICSim$ ifconfig vcan0
vcan0     Link encap:UNSPEC  HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00  
          UP RUNNING NOARP  MTU:16  Metric:1
          RX packets:558904 errors:0 dropped:0 overruns:0 frame:0
          TX packets:558904 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1 
          RX bytes:3663935 (3.6 MB)  TX bytes:3663935 (3.6 MB)


Car networks run on a variety of protocols most prevalent being CAN. You can think of a CAN Bus like an old school networking hub where everyone can see everyone elses traffic. This is true to some extent although you may not see all of the cars traffic if its not connected to that particular bus your plugged into. You can think of CAN traffic kind of like UDP in that its send and forget, the main difference being parts of the CAN bus network don't actually have addresses and everything runs off arbitration IDs and priorities. Thats enough background to get you doing rather then reading.

With a little knowledge out of the way lets check if we can see our CAN traffic from our virtual car via the CanDump utility, which you installed as part of CanUtils package above. Using the following command on the vcan0 interface our simulator uses you can view a stream of traffic: 

ficti0n@ubuntu:~/Desktop/ICSim$ candump vcan0



Above we can see a bunch of CAN frames, and if we perform actions on the vehicle we will see changes to data values in the CanDump output.  However this may happen very fast, and we may not be able to see if for example we unlocked our simulators door. This is because things are changing constantly in the cars IDLE state. One single value changing may not stand out enough for us to take notice or may scroll so fast we cant see it. 


Capture and Replay CAN Actions: 

One option would be to perform an action and replay it, we should see the actions happen again in the replay if the traffic for the action we recorded is on the same bus network our device is plugged into. There are loads of networks within a car and its not guaranteed our network tap for example an OBD2 port plugin is connected to the same network as door we opened.  Or the door may not be connected to the network at all depending on your car and its age or how its configured. 

Replaying dumps with CanPlayer: 
Another useful tool included with CanUtils package is CanPlayer for replaying traffic. If the functionality we are trying to capture is on the same Bus as the adaptor plugged into the car, or in this case our Virtual CAN interface, we can use CanDump to save traffic to a file. We then use CanPlayer to replay the traffic on the network. For example lets run CanDump and open a door and then replay the functionality with CanPlayer. 

Lab 1 Steps: 

  1. Run CanDump
  2. Right Shift + X to open a door
  3. Cancel CanDump (ctrl+c)
  4. Left Shift + X to close the door
  5. Run can player with the saved dump and it will replay the traffic and open the door

Recording the door opening:  (-l for logging) 
ficti0n@ubuntu:~/Desktop/ICSim$ candump -l vcan0

Replaying the CanDump file:  (use the file your can dump created) 
ficti0n@ubuntu:~/Desktop/ICSim$ canplayer -I candump-2018-04-06_154441.log 

Nice, so if all went well you should see that your door is now open again. If this did not happen when attacking a real car, just try to replay it again. CAN networks are not like TCP/IP, they are more like UDP in that you send out your request and its not expecting a response. So if it gets lost then it gets lost and you have to resend. Perhaps something with higher priority on the network was sending at the time of your replay and your traffic was overshadowed by it.   




Interacting with the Can Bus and Reversing Traffic: 

So thats cool, but what about actually understanding what is going on with this traffic, CanDump is not very useful for this, is scrolls by to quickly for us to learn much from.  Instead we can use CanSniffer with colorized output to show us the bytes within packets that change. Below is an example of CanSniffer Traffic: 

To startup can sniffer run the following: 
ficti0n@ubuntu:~/Desktop/ICSim$ cansniffer -c vcan0




You will see 3 fields, Time, ID  and Data. Its pretty easy to figure out what these are based on thier name. The most important part for our usage in this blog are the ID and the Data fields.  

The ID field is the frame ID which is loosely associated with the device on the network which is effected by the frame being sent. The ID to also determines the priority of the frame on the network.  The lower the number of the CAN-ID the higher priority it has on the network and more likely it will be handled first.  The data field is the data being sent to change some parameter like unlocking a door or updating output. You will notice that some of the bytes are highlighted RED. The values in red are the values that are changing during the idle state you are currently in. 


Determine which ID and Byte controls the throttle: 

So with the terminal sniffing window open put the simulator and the controller into the foreground, with the controller being the window you have clicked and selected.  Pay attention to the CanSniffer output while hitting the UP ARROW and look for a value that was white but is now Red and increasing in value as the throttle goes up.  This might take you a few minutes of paying attention to whats going on to see. 

The following 2 pictures show ID 244 in the IDLE state followed by pressing the up button to increase the speed. You will notice a byte has turned red and is increasing in value through a range of HEX values 0-F. It will continue to enumerate through values till it reaches its max speed. 





The byte in ID 244 which is changing is the value while the throttle is engaged, so 244 associated in some way with the increasing speed.   The throttle speed is a good value to start with as it keeps increasing its value when pressed making it easier to spot while viewing the CanSniffer output.  


Singling out Values with Filters: 

If you would like to single out the throttle value then click the terminal window and press -000000 followed by the Enter key which will clear out all of the values scrolling. Then press +244 followed by the Enter key which will add back the throttle ID. You can now click the controller again and increase the speed with your Up arrow button without all the noise clouding your view.  You will instead as shown below only have ID 244 in your output: 




To get back all of the IDs again click the terminal window and input +000000 followed by the Enter key.   Now you should see all of the output as before.  Essentially 000000 means include everything. But when you put a minus in front of it then it negates everything and clears your terminal window filtering out all values. 


Determine Blinker ID: 

Now lets figure out another ID for the blinkers. If you hit the left or right arrow with the controls window selected you will notice a whole new ID appears in the list, ID 188 shown in the picture below which is associated with the blinker. 




This ID was not listed before as it was not in use within the data output until you pressed the blinker control.  Lets single this value out by pressing -000000 followed by +188.  Just like in the throttle example your terminal should only show ID 188, initially it will show with 00 byte values. 

 As you press the left and the right blinker you will see the first Byte change from 00 to 01 or 02. If neither is pressed as in the screenshot above it will be 00. Its kind of hard to have the controller in focus and get a screenshot at the same time but the ID will remain visible as 00 until it times out and disappears from the list when not active. However with it filtered out as above you can get a better view of things and it wont disappear.  


Time for YOU to do some Protocol Reversing:

This lab will give you a good idea how to reverse all of the functionality of the car and associate each action with the proper ID and BYTE. This way you can create a map of intended functionality changes you wish to make.  Above we have done a few walk throughs with you on how to determine which byte and ID is associated with an action. Now its time to map everything out yourself with all the remaining functionality before moving on to attacking individual components.  


Lab Work Suggestion: 


  1. Take out a piece of paper and a pencil
  2. Try unlocking and locking doors and write down the ID which controls this action (remember your filters)
  3. Try unlocking each door and write down the BYTES needed for each door to open
  4. Try locking each doors and what Bytes change and what are their values, write them down
  5. Do the same thing for the blinkers left and right (Might be different then what I did above) 
  6. What ID is the speedometer using?  What byte changes the speed? 


Attacking Functionality Directly: 

With all of the functionality mapped out we can now try to target various devices in the network directly without interacting with the controllers GUI. Maybe we broke into the car via cellular OnStar connection  or the center console units BLE connection which was connected to the CAN network in some way.  
After an exploit we have direct access to the CAN network and we would like to perform actions. Or maybe you have installed a wireless device into an OBD2 port under the dashboard you have remote access to the automobile. 

Using the data from the CAN network reversing lab above we can call these actions directly with the proper CAN-ID and Byte.  Since we are remote to the target we can't just reach over and grab the steering wheel or hit the throttle we will instead send your CAN frame to make the change.
One way we can do this is via the CanSend utility. Lets take our information from our lab above and make the left turn signal flash with the following ID 188 for the turn signal by changing the first byte to 01 indicating the left signal is pressed. CanSend uses the format ID#Data. You will see this below when sending the turn signal via CanSend. 

ficti0n@ubuntu:~/Desktop/ICSim$ cansend vcan0 188#01000000 



You should have noticed that the left signal flashed. If not pay more attention and give it another try or make sure you used the correct ID and changed the correct byte.  So lets do the same thing with the throttle and try to set the speed to something with ID 244 that we determined was the throttle. 

ficti0n@ubuntu:~/Desktop/ICSim$ cansend vcan0 244#00000011F6 

My guess is that nothing happened because its so fast the needle is not going to jump to that value. So instead lets try repeating this over and over again with a bash loop which simply says that while True keep sending the throttle value of 11 which equates to about 30mph: 

ficti0n@ubuntu:~/Desktop/ICSim$ while true; do cansend vcan0 244#00000011F6;  done




Yes thats much better, you may notice the needle jumping back and forth a bit. The reason the needle is bouncing back and forth is because the normal CAN traffic is sent telling the car its actually set to 00 in between your frames saying its 30mph.  But it worked and you have now changed the speed the car sees and you have flashed the blinker without using the cars normal blinker controls. Pretty cool right? 


Monitor the CAN Bus and react to it: 

Another way to handle this issue is to monitor the CAN network and when it sees an ID sent it will automatically send the corresponding ID with a different value.. Lets give that a try to modify our speed output by monitoring for changes. Below we are simply running CanDump and parsing for ID 244 in the log output which is the throttle value that tells the car the speed. When a device in the car reports ID 244 and its value we will immediately resend our own value saying the speed is 30mph with the value 11.  See below command and try this out. 

ficti0n@ubuntu:~/Desktop/ICSim$ candump vcan0 | grep " 244 " | while read line; do cansend vcan0 244#00000011F6; done

With this running after a few seconds you will see the speed adjust to around 30MPH once it captures a legitimate CAN-ID 244 from the network traffic and sends its own value right after.  

Ok cool, so now while the above command is still running click the controller window and start holding down the Up arrow with the controller in focus.. After a few seconds or so when the speed gets above 30MPH you will see the needle fighting for the real higher value and adjusting back to 30MPH as your command keeps sending its on value as a replacement to the real speed. 

So thats one way of monitoring the network and reacting to what you see in a very crude manner.  Maybe someone stole your car and you want to monitor for an open door and if they try to open the door it immediately locks them in. 


Conclusion and whats next: 

I am not an expert car hacker but I hope you enjoyed this. Thats about as far as I want to go into this subject today, in the next blog we will get into how to code python to perform actions on the CAN network to manipulate things in a similar way.  With your own code you are not limited to the functionality of the tools you are provided and can do whatever you want. This is much more powerful then just using the CanUtils pre defined tools. Later on I will also get into the hardware side of things if you would like to try this on a real car where things are more complicated and things can go wrong. 

More info