Las actualizaciones ... ¿como ventaja competitiva?

En la carretera Seguimos con el tema de las actualizaciones.

En la introducción de la parte de la asignatura de desarrollo seguro en la que participo, comentábamos el otro día (transparencias en [PDF] Algunos datos sobre desarrollo y seguridad de aplicaciones que no podemos esperar que los usuarios actualicen (y mucho menos que lo hagan rápidamente).

En los últimos años se ha conseguido que determinados grupos de usuarios estén pendientes, al menos, de las últimas versiones de sus sistemas e instalen las actualizaciones, pero todavía parece que no es lo habitual entre la generalidad de los usuarios (ejercicio: observar la reacción de cualquier usuario medio ante las alertas de actualización de su dispositivo móvil; leer los mensajes con ellos para ver qué interpretan y sus intenciones al respeto).

Si pasamos al internet de las cosas (internet of things, IoT) con dispositivos de lo más variopinto conectados la cosa se complica: las interfaces son más escuetas y los sistemas de actualización pueden ser algo más complicados.

Recientemente se descubrían fallos de seguridad que permitían atacar a algunos modelos de Jeep Cherokee. También otros fallos que permitirían realizar algo parecido a través del sistema de información y entretenimiento del Tesla Model S (lo cuentan en How the Jeep Hack Reveals Tesla’s Biggest Advantage.

En el caso de los primeros la firma se vio obligada a hacer una llamada a los propietarios de los vehículos y/o a enviarles un USB con la actualización:

But the big difference between these scenarios is what happened next. Fiat Chrysler had to recall 1.4 million Jeeps that could potentially be vulnerable to the hack, but the “recall” actually amounted to mailing Jeep owners a USB stick that they could plug into their vehicle’s dashboard port in order to give the car the necessary patch.

En el segundo caso, al tratarse de coches conectados y que reciben actualizaciones a través de internet (OTA, Over The Air) la actualización fue envíada por ese sistema y los coches actualizados (parece que tenían que aceptar, pero seguramente están en ese sector que actualiza y agradece las novedades; estaría bien poder conocer el porcentaje de los que dijo ‘no’):

Tesla, on the other hand, was able to automatically send a patch to all its Model S vehicles on Wednesday through an over-the-air update, a method more akin to how your smartphone gets software fixes.

En Researchers Hacked a Model S, But Tesla’s Already Released a Patch hablan de ventaja en seguridad (‘Tesla cars have one security advantage that a lot of other cars don’t’) y cuentan más detalles de los fallos.

En todo caso, parece una ventaja desde el punto de vista de la seguridad clara para Tesla, con la preocupación que siempre tendremos de que no sabemos qué ocurre realmente con esas actualizaciones ni qué incluyen.

Lo que no tengo tan claro es que alguien pueda terminar decidiéndose por un modelo u otro en función de esos factores; sí que puede ser un factor determinante para las marcas, que empiecen a darse cuenta del ahorro que puede suponer (¿con sus riesgos asociados?) instalar en los vehículos sistemas de actualización adecuados.

Esta entrada está basada en Las actualizaciones … ¿como ventaja competitiva?.

Actualizando. Espere

Actualización Como por efecto mágico, nuestro sistema siempre decide actualizarse cuando menos conviene. Es paradigmático y forma parte de casi cualquier acto que se organiza cuando esos PCs proporcionados por la organización empiezan a mandar avisos diversos, muchos de ellos de actualizaciones de programas.

En este caso no sabemos si es la típica excusa (‘mi perro se comió los deberes’, ‘falló el ordenador’) pero nos contaban en German pro basketball team relegated to lower division due to Windows update de un equipo de baloncesto que habría visto afectada su participacińo en la liga cuando el equipo que manejaba el marcador comenzó a actualizarse antes de empezar el partido y retrasó todo.

“But as both teams warmed up, the computer crashed,” he said. “When we booted it again at 7:20pm, it started automatically downloading updates. But we did not initiate anything.”

After all the updates were installed, Paderborn was ready to start the game at 7:55pm.

¿Quién no tiene alguna anécdota que contar relacionada con las actualizaciones?

Confíamos en que los equipos están allí dispuestos para atender nuestras necesidades sin proporcionales ni prestar atención a las suyas más básicas.

Al final, no es más que dedicar tiempo e incluir en nuestros procesos el mantenimiento para que no nos sucedan estas situaciones desagradables

Elogio de Python por el equipo de ingeniería de PayPal

Portada Libro Python Desde hace algún tiempo, cuando tengo que hacer un programita para resolver un problema de manera rápida mi lenguaje elegido es Python. También voy encontrándome mis limitaciones, esencialmente por no dedicarle atención suficiente a todo el entorno que ofrece para trabajar. De hecho, ya algunas entradas sobre Python en esta bitácora. Principalmente desarrollos que he ido haciendo pequeñitos que tal vez podrían servirle a alguien más alguna vez.

Por eso me gustó leer 10 Myths of Enterprise Python que es un elogio por parte del equipo de ingeniería de PayPal, tratando de aclarar algunas ideas erróneas sobre el lenguaje. Las listo:

  1. Python is a new language
  2. Python is not compiled
  3. Python is not secure
  4. Python is a scripting language
  5. Python is weakly-typed
  6. Python is slow
  7. Python does not scale
  8. Python lacks good concurrency support
  9. Python programmers are scarce
  10. Python is not for big projects

Vale la pena leerlas y echarles un vistazo para ver los argumentos.

Mi relación con Python se basa fundamentalmente en que es rápido para hacer pruebas (con la ventaja del intérprete para terminar de comprender cosas que no tienes muy controladas) y, a la vez, permitiría evolucionar a proyectos más grandes (que con scripts de shell no es trivial). También sus ‘batteries included’ con bibliotecas disponibles casi para cualquier cosa que podamos querer hacer.

Mis quejas con el lenguaje, que también las hay, tendrían que ver con su incómodo sistema de gestión de codificaciones (quién no se haya enfrentado nunca al problema que nos diga como lo hizo), y la transición a Python 3 que no termina de llegar del todo.

Entre mis carencias, la gestión y pruebas con distintas versiones del lenguaje y el lío que (creo que) tengo montado en mis sistemas con la instalación de bibliotecas de terceros de manera poco adecuada. Estoy empezando a explorar Virtual Environments y pyenv para ver si controlo estas cosas un poco mejor.

Demandas por fallos de software: los coches

Portada Geekonomics De ven en cuando se habla de la responsabilidad de los desarrolladores de programas informáticos. El otro día preparando una clase recuperaba y actualizaba un par de enlaces sobre el tema: Is It Time For Software Liability? y Should Software Companies Be Legally Liable For Security Breaches? al que añadiré este que comento aquí. También se publicó hace unos años el libro Geekonomics: The Real Cost of Insecure Software (es un extracto del primer capítulo) donde se hacía un análisis sobre el tema desde diversas perspectivas.

En Lawsuit seeks damages against automakers and their hackable cars hablan justamente del tema en la industria del automóvil basándose en que los fabricantes no han tomado las medidas necesarias para proteger los vehículos de los atacantes. Incluso un Senador de los EEUU respaldaría esa idea:

The lawsuit also cites a study released last month by Sen. Edward Markey (D-Mass.) that claims automakers have fallen far short in their responsibility to secure their vehicles’ electronics

El informe está en [PDF] Analysis of automobile manufacturers’ efforts reveals security and privacy gaps Tracking & Hacking: Security & Privacy Gaps Put American Drivers at Risk.

Eso sin hablar de las limitaciones informáticas de los coches modernos, en los que normalmente (y afortunadamente, si hacemos caso a los riesgos aparecidos) hay muy pocas de las posibilidades que nos ofrece un ordenador aprovechadasa adecuadamente:

“You can get into five-year-old luxury car and it…feels like a Nintendo game…compared to the experience on your smartphone,” Morrison said in an earlier interview with Computerworld.

Que también tiene que ver con lo rápido que se quedarían anticuados (¿imaginas una pantalla como la de tu teléfono móvil de hace 5 años para tener en el vehículo durante otros cinco años más?).

En Senate Bill Seeks Standards For Cars’ Defenses From Hackers nos cuentan los planes sobre cómo abrodar el problema. Sin embargo, parece que las propuestas irían más bien en la línea de buscar ‘standards’ y buenas prácticas que las propias leyes (que era algo que se comentaba también en Informe sobre ciberseguridad nacional en EEUU.

No se cómo andará la reclamación legal pero desde luego parece que hay un problema y ya han aparecido los primeros intentos de soluciones legales. Hemos hablado de coches en mbpfernand0 y coches en esta bitácora.

Al final, todo tiene mucho que ver con las consecuencias económicas que tendrían ciertas consecuencias drásticas: probablemente la informática costaría más (dinero y/o tiempo) y todo tendría que ir algo más despacio tomando, tal vez, menos riesgos. Pero seguramente este es un debate que vamos a seguir presenciando en los próximos tiempos.

Command and Control con GMail

Cuadro de mandos Una de las tareas que tienen los ‘malos’ para organizar sus ataques es la gestión de los equipos comprometidos. No hace tanto esto se hacía mediante canales de IRC, y la cosa ha ido evolucionando hacia redes sociales y otros sistemad de comunicacación (nuestro propio bot -no malicioso-, del que hemos hablado a veces no es más que un sistema de control de un computador remoto, mediante XMPP Segundo bot: avanzamos). Un ataque de este tipo sólo necesita que el programa malicioso pueda escuchar de alguna manera las instrucciones y pueda comunicarnos las respuestas.

En este caso podíamos leer hace algún tiempo ¿Gmail como server de C&C? OMG! – Parte I. Lamentablemente la parte II no se ha llegado a materializar aún donde se comenta sobre Pyexfil - Using Python to make Gmail a C&C server .

Se trata de un programa en Python que permite controlar un equipo infectado mediante el envío y recepción de mensajes de correo electrónico. El programa es capaz de leerlos, ejecutar las instrucciones y responder, si es necesario. Si conseguimos hacer que se ejecute en el equipo de vez en cuando tendremos un mecanismo para comunicarnos que además puede ser bastante sigilioso (¿cómo va a despertar la sospecha una consulta a un servidor de correo de amplia implantación?).

Curioso.