| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | ---
 | 
					
						
							|  |  |  | - hosts:
 | 
					
						
							|  |  |  |     - 127.0.0.1
 | 
					
						
							|  |  |  |   gather_facts: true
 | 
					
						
							|  |  |  |   become: true
 | 
					
						
							|  |  |  |   vars:
 | 
					
						
							|  |  |  |     kernel:
 | 
					
						
							|  |  |  |       min: "6.1"
 | 
					
						
							| 
									
										
										
										
											2024-02-04 17:42:10 +01:00
										 |  |  |       full: "6.1.0-rpi8-rpi-v8"
 | 
					
						
							|  |  |  |       full_pi5: "6.1.0-rpi8-rpi-2712"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     pwnagotchi:
 | 
					
						
							|  |  |  |       hostname: "{{ lookup('env', 'PWN_HOSTNAME') | default('pwnagotchi', true) }}"
 | 
					
						
							|  |  |  |       version: "{{ lookup('env', 'PWN_VERSION') | default('pwnagotchi-torch', true) }}"
 | 
					
						
							|  |  |  |     system:
 | 
					
						
							|  |  |  |       boot_options:
 | 
					
						
							|  |  |  |         - "dtoverlay=dwc2"
 | 
					
						
							|  |  |  |         - "dtoverlay=spi1-3cs"
 | 
					
						
							|  |  |  |         - "dtparam=i2c1=on"
 | 
					
						
							|  |  |  |         - "dtparam=i2c_arm=on"
 | 
					
						
							|  |  |  |         - "dtparam=spi=on"
 | 
					
						
							|  |  |  |         - "gpu_mem=16"
 | 
					
						
							|  |  |  |       modules:
 | 
					
						
							|  |  |  |         - "i2c-dev"
 | 
					
						
							|  |  |  |     services:
 | 
					
						
							|  |  |  |       enable:
 | 
					
						
							|  |  |  |         - bettercap.service
 | 
					
						
							|  |  |  |         - fstrim.timer
 | 
					
						
							|  |  |  |         - pwnagotchi.service
 | 
					
						
							|  |  |  |         - pwngrid-peer.service
 | 
					
						
							| 
									
										
										
										
											2024-01-17 20:42:28 +01:00
										 |  |  |         - zramswap.service
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       disable:
 | 
					
						
							|  |  |  |         - apt-daily-upgrade.service
 | 
					
						
							|  |  |  |         - apt-daily-upgrade.timer
 | 
					
						
							|  |  |  |         - apt-daily.service
 | 
					
						
							|  |  |  |         - apt-daily.timer
 | 
					
						
							|  |  |  |         - bluetooth.service
 | 
					
						
							|  |  |  |         - ifup@wlan0.service
 | 
					
						
							|  |  |  |     packages:
 | 
					
						
							| 
									
										
										
										
											2023-11-07 08:38:50 +01:00
										 |  |  |       caplets:
 | 
					
						
							|  |  |  |         source: "https://github.com/jayofelony/caplets.git"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       bettercap:
 | 
					
						
							| 
									
										
										
										
											2023-11-07 08:38:50 +01:00
										 |  |  |         source: "https://github.com/jayofelony/bettercap.git"
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |         url: "https://github.com/jayofelony/bettercap/releases/download/2.32.2/bettercap-2.32.2.zip"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         ui: "https://github.com/bettercap/ui/releases/download/v1.3.0/ui.zip"
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |       pwngrid:
 | 
					
						
							| 
									
										
										
										
											2023-11-21 16:11:51 +01:00
										 |  |  |         source: "https://github.com/jayofelony/pwngrid.git"
 | 
					
						
							| 
									
										
										
										
											2024-02-05 12:34:09 -05:00
										 |  |  |         url: "https://github.com/jayofelony/pwngrid/releases/download/v1.10.5/pwngrid-1.11.1-aarch64.zip"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       apt:
 | 
					
						
							|  |  |  |         downgrade:
 | 
					
						
							|  |  |  |           - libpcap-dev_1.9.1-4_arm64.deb
 | 
					
						
							| 
									
										
										
										
											2023-11-07 11:11:12 +01:00
										 |  |  |           - libpcap0.8-dbg_1.9.1-4_arm64.deb
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libpcap0.8-dev_1.9.1-4_arm64.deb
 | 
					
						
							|  |  |  |           - libpcap0.8_1.9.1-4_arm64.deb
 | 
					
						
							|  |  |  |         hold:
 | 
					
						
							| 
									
										
										
										
											2024-01-25 15:16:33 +01:00
										 |  |  |           - firmware-atheros
 | 
					
						
							|  |  |  |           - firmware-brcm80211
 | 
					
						
							|  |  |  |           - firmware-libertas
 | 
					
						
							|  |  |  |           - firmware-misc-nonfree
 | 
					
						
							|  |  |  |           - firmware-realtek
 | 
					
						
							| 
									
										
										
										
											2023-11-09 16:39:11 +01:00
										 |  |  |           - libpcap-dev
 | 
					
						
							|  |  |  |           - libpcap0.8
 | 
					
						
							|  |  |  |           - libpcap0.8-dbg
 | 
					
						
							| 
									
										
										
										
											2024-01-25 15:16:33 +01:00
										 |  |  |           - libpcap0.8-dev
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         remove:
 | 
					
						
							|  |  |  |           - avahi-daemon
 | 
					
						
							| 
									
										
										
										
											2024-01-17 19:51:38 +01:00
										 |  |  |           - dhpys-swapfile
 | 
					
						
							| 
									
										
										
										
											2024-01-25 15:16:33 +01:00
										 |  |  |           - libcurl-ocaml-dev
 | 
					
						
							|  |  |  |           - libssl-ocaml-dev
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - nfs-common
 | 
					
						
							|  |  |  |           - triggerhappy
 | 
					
						
							|  |  |  |           - wpasupplicant
 | 
					
						
							|  |  |  |         install:
 | 
					
						
							| 
									
										
										
										
											2024-01-07 15:27:17 +01:00
										 |  |  |           - aircrack-ng
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - autoconf
 | 
					
						
							|  |  |  |           - bc
 | 
					
						
							|  |  |  |           - bison
 | 
					
						
							|  |  |  |           - bluez
 | 
					
						
							|  |  |  |           - build-essential
 | 
					
						
							|  |  |  |           - curl
 | 
					
						
							|  |  |  |           - dkms
 | 
					
						
							|  |  |  |           - fbi
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - firmware-atheros
 | 
					
						
							|  |  |  |           - firmware-brcm80211
 | 
					
						
							|  |  |  |           - firmware-libertas
 | 
					
						
							|  |  |  |           - firmware-misc-nonfree
 | 
					
						
							|  |  |  |           - firmware-realtek
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - flex
 | 
					
						
							|  |  |  |           - fonts-dejavu
 | 
					
						
							|  |  |  |           - fonts-dejavu-core
 | 
					
						
							|  |  |  |           - fonts-dejavu-extra
 | 
					
						
							|  |  |  |           - fonts-freefont-ttf
 | 
					
						
							|  |  |  |           - g++
 | 
					
						
							|  |  |  |           - gawk
 | 
					
						
							|  |  |  |           - gcc-arm-none-eabi
 | 
					
						
							|  |  |  |           - git
 | 
					
						
							| 
									
										
										
										
											2024-01-23 11:38:14 +01:00
										 |  |  |           - hcxtools
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libatlas-base-dev
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |           - libavcodec59
 | 
					
						
							|  |  |  |           - libavformat59
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libblas-dev
 | 
					
						
							| 
									
										
										
										
											2023-11-07 09:34:57 +01:00
										 |  |  |           - libbluetooth-dev
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libbz2-dev
 | 
					
						
							|  |  |  |           - libc-ares-dev
 | 
					
						
							|  |  |  |           - libc6-dev
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - libc6:armhf
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libcap-dev
 | 
					
						
							| 
									
										
										
										
											2024-01-25 15:16:33 +01:00
										 |  |  |           - libcurl-ocaml-dev
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libdbus-1-dev
 | 
					
						
							|  |  |  |           - libdbus-glib-1-dev
 | 
					
						
							|  |  |  |           - libeigen3-dev
 | 
					
						
							|  |  |  |           - libelf-dev
 | 
					
						
							|  |  |  |           - libffi-dev
 | 
					
						
							|  |  |  |           - libfl-dev
 | 
					
						
							|  |  |  |           - libfuse-dev
 | 
					
						
							|  |  |  |           - libgdbm-dev
 | 
					
						
							|  |  |  |           - libgl1-mesa-glx
 | 
					
						
							|  |  |  |           - libgmp3-dev
 | 
					
						
							|  |  |  |           - libgstreamer1.0-0
 | 
					
						
							|  |  |  |           - libhdf5-dev
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - libisl23:armhf
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - liblapack-dev
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - libmpc3:armhf
 | 
					
						
							|  |  |  |           - libmpfr6:armhf
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libncursesw5-dev
 | 
					
						
							|  |  |  |           - libnetfilter-queue-dev
 | 
					
						
							|  |  |  |           - libopenblas-dev
 | 
					
						
							|  |  |  |           - libopenjp2-7
 | 
					
						
							|  |  |  |           - libopenmpi-dev
 | 
					
						
							|  |  |  |           - libopenmpi3
 | 
					
						
							|  |  |  |           - libpcap-dev
 | 
					
						
							|  |  |  |           - libraspberrypi-bin
 | 
					
						
							|  |  |  |           - libraspberrypi-dev
 | 
					
						
							|  |  |  |           - libraspberrypi-doc
 | 
					
						
							|  |  |  |           - libraspberrypi0
 | 
					
						
							|  |  |  |           - libsqlite3-dev
 | 
					
						
							|  |  |  |           - libssl-dev
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - libssl-ocaml-dev
 | 
					
						
							|  |  |  |           - libstdc++6:armhf
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libswscale5
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |           - libtiff6
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - libtool
 | 
					
						
							|  |  |  |           - libusb-1.0-0-dev
 | 
					
						
							|  |  |  |           - lsof
 | 
					
						
							|  |  |  |           - make
 | 
					
						
							|  |  |  |           - python3-dbus
 | 
					
						
							|  |  |  |           - python3-flask
 | 
					
						
							|  |  |  |           - python3-flask-cors
 | 
					
						
							|  |  |  |           - python3-flaskext.wtf
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |           - python3-gast
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - python3-pil
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - python3-pip
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |           - python3-pycryptodome
 | 
					
						
							|  |  |  |           - python3-requests
 | 
					
						
							|  |  |  |           - python3-scapy
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - python3-setuptools
 | 
					
						
							|  |  |  |           - python3-smbus
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |           - python3-smbus2
 | 
					
						
							|  |  |  |           - python3-spidev
 | 
					
						
							|  |  |  |           - python3-tweepy
 | 
					
						
							|  |  |  |           - python3-werkzeug
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |           - python3-yaml
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - qpdf
 | 
					
						
							|  |  |  |           - raspberrypi-kernel-headers
 | 
					
						
							|  |  |  |           - rsync
 | 
					
						
							|  |  |  |           - screen
 | 
					
						
							| 
									
										
										
										
											2023-11-13 22:56:34 +01:00
										 |  |  |           - tcpdump
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |           - texinfo
 | 
					
						
							|  |  |  |           - time
 | 
					
						
							|  |  |  |           - tk-dev
 | 
					
						
							|  |  |  |           - unzip
 | 
					
						
							|  |  |  |           - vim
 | 
					
						
							|  |  |  |           - wget
 | 
					
						
							|  |  |  |           - wl
 | 
					
						
							|  |  |  |           - xxd
 | 
					
						
							|  |  |  |           - zlib1g-dev
 | 
					
						
							| 
									
										
										
										
											2024-01-17 19:51:38 +01:00
										 |  |  |           - zram-tools
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   tasks:
 | 
					
						
							| 
									
										
										
										
											2024-01-25 15:16:33 +01:00
										 |  |  |     # First we install packages
 | 
					
						
							| 
									
										
										
										
											2024-01-17 19:51:38 +01:00
										 |  |  |     - name: install packages
 | 
					
						
							|  |  |  |       apt:
 | 
					
						
							|  |  |  |         name: "{{ packages.apt.install }}"
 | 
					
						
							|  |  |  |         state: present
 | 
					
						
							|  |  |  |         update_cache: yes
 | 
					
						
							|  |  |  |         install_recommends: false
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Now we set up /boot/firmware
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: Create pi user
 | 
					
						
							|  |  |  |       copy:
 | 
					
						
							| 
									
										
										
										
											2024-01-06 23:21:28 +01:00
										 |  |  |         dest: /boot/firmware/userconf
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         content: |
 | 
					
						
							|  |  |  |           pi:$6$3jNr0GA9KIyt4hmM$efeVIopdMQ8DGgEPCWWlbx3mJJNAYci1lEXGdlky0xPyjqwKNbwTL5SrCcpb4144C4IvzWjn7Iv.QjqmU7iyT/
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-17 19:51:38 +01:00
										 |  |  |     - name: enable ssh on boot
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /boot/firmware/ssh
 | 
					
						
							|  |  |  |         state: touch
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: adjust /boot/firmware/config.txt
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         dest: /boot/firmware/config.txt
 | 
					
						
							|  |  |  |         insertafter: EOF
 | 
					
						
							|  |  |  |         line: '{{ item }}'
 | 
					
						
							|  |  |  |       with_items: "{{ system.boot_options }}"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: change root partition
 | 
					
						
							|  |  |  |       replace:
 | 
					
						
							|  |  |  |         dest: /boot/firmware/cmdline.txt
 | 
					
						
							|  |  |  |         backup: no
 | 
					
						
							|  |  |  |         regexp: "root=PARTUUID=[a-zA-Z0-9\\-]+"
 | 
					
						
							|  |  |  |         replace: "root=/dev/mmcblk0p2"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: configure /boot/firmware/cmdline.txt
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         path: /boot/firmware/cmdline.txt
 | 
					
						
							|  |  |  |         backrefs: True
 | 
					
						
							|  |  |  |         state: present
 | 
					
						
							|  |  |  |         backup: no
 | 
					
						
							|  |  |  |         regexp: '(.*)$'
 | 
					
						
							|  |  |  |         line: '\1 modules-load=dwc2,g_ether'
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: change hostname
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         dest: /etc/hostname
 | 
					
						
							|  |  |  |         regexp: '^raspberrypi'
 | 
					
						
							|  |  |  |         line: "{{pwnagotchi.hostname}}"
 | 
					
						
							|  |  |  |         state: present
 | 
					
						
							|  |  |  |       when: lookup('file', '/etc/hostname') == "raspberrypi"
 | 
					
						
							|  |  |  |       register: hostname
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: add hostname to /etc/hosts
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         dest: /etc/hosts
 | 
					
						
							|  |  |  |         regexp: '^127\.0\.1\.1[ \t]+raspberrypi'
 | 
					
						
							|  |  |  |         line: "127.0.1.1\t{{pwnagotchi.hostname}}"
 | 
					
						
							|  |  |  |         state: present
 | 
					
						
							|  |  |  |       when: hostname.changed
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-17 19:51:38 +01:00
										 |  |  |     # Now we disable sap and a2dp, we don't use them on rpi
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: disable sap plugin for bluetooth.service
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         dest: /lib/systemd/system/bluetooth.service
 | 
					
						
							| 
									
										
										
										
											2024-01-10 17:05:52 +01:00
										 |  |  |         regexp: '^ExecStart=/usr/libexec/bluetooth/bluetoothd$'
 | 
					
						
							|  |  |  |         line: 'ExecStart=/usr/libexec/bluetooth/bluetoothd --noplugin=sap,a2dp'
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         state: present
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-10 14:34:16 +01:00
										 |  |  |     ###########################################
 | 
					
						
							|  |  |  |     #
 | 
					
						
							|  |  |  |     # libpcap v1.9 - build from source
 | 
					
						
							|  |  |  |     #
 | 
					
						
							|  |  |  |     ###########################################
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # check for presence, then it can re-run in later parts if needed
 | 
					
						
							|  |  |  |     # use the "make" built in
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # install libpcap before bettercap and pwngrid, so they use it
 | 
					
						
							|  |  |  |     - name: clone libpcap v1.9 from github
 | 
					
						
							|  |  |  |       git:
 | 
					
						
							|  |  |  |         repo: 'https://github.com/the-tcpdump-group/libpcap.git'
 | 
					
						
							|  |  |  |         dest: /usr/local/src/libpcap
 | 
					
						
							|  |  |  |         version: libpcap-1.9
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: build and install libpcap into /usr/local/lib
 | 
					
						
							|  |  |  |       shell: "./configure && make && make install"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/libpcap
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: remove libpcap build folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /usr/local/src/libpcap
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: create symlink /usr/local/lib/libpcap.so.1.9.1
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         src: /usr/local/lib/libpcap.so.1.9.1
 | 
					
						
							|  |  |  |         dest: /usr/local/lib/libpcap.so.0.8
 | 
					
						
							|  |  |  |         state: link
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 15:16:33 +01:00
										 |  |  |     # install latest hcxtools
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: clone hcxtools
 | 
					
						
							|  |  |  |       git:
 | 
					
						
							|  |  |  |         repo: https://github.com/ZerBea/hcxtools.git
 | 
					
						
							|  |  |  |         dest: /usr/local/src/hcxtools
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: install hcxtools
 | 
					
						
							|  |  |  |       shell: "make && make install"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/hcxtools
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: remove hcxtools directory
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /usr/local/src/hcxtools
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-09 16:38:03 +01:00
										 |  |  |     # Install nexmon to fix wireless scanning (takes 2.5G of space)
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |     - name: symlink 1
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:26:20 +01:00
										 |  |  |         src: "/usr/lib/arm-linux-gnueabihf/libisl.so.23.2.0"
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |         dest: "/usr/lib/arm-linux-gnueabihf/libisl.so.10"
 | 
					
						
							|  |  |  |         state: link
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: symlink 2
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:26:20 +01:00
										 |  |  |         src: "/usr/lib/arm-linux-gnueabihf/libmpfr.so.6.2.0"
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |         dest: "/usr/lib/arm-linux-gnueabihf/libmpfr.so.4"
 | 
					
						
							|  |  |  |         state: link
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: clone nexmon repository
 | 
					
						
							|  |  |  |       git:
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:04:06 +01:00
										 |  |  |         repo: https://github.com/seemoo-lab/nexmon.git
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         dest: /usr/local/src/nexmon
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:51:15 +01:00
										 |  |  |     # FIRST WE BUILD DRIVER FOR RPi5
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  |     - name: make firmware, RPi5
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       shell: "source ./setup_env.sh && make"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/nexmon/
 | 
					
						
							| 
									
										
										
										
											2024-01-24 10:24:01 +01:00
										 |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full_pi5 }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  |     - name: make firmware patch (bcm43455c0), RPi5
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       shell: "source ./setup_env.sh && cd /usr/local/src/nexmon/patches/bcm43455c0/7_45_206/nexmon/ && make"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/nexmon/
 | 
					
						
							| 
									
										
										
										
											2024-01-24 10:24:01 +01:00
										 |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full_pi5 }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  |     - name: copy modified driver, RPi5
 | 
					
						
							|  |  |  |       copy:
 | 
					
						
							|  |  |  |         src: "/usr/local/src/nexmon/patches/driver/brcmfmac_{{ kernel.min }}.y-nexmon/brcmfmac.ko"
 | 
					
						
							|  |  |  |         dest: "/usr/lib/modules/{{ kernel.full_pi5 }}/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko"
 | 
					
						
							|  |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full_pi5 }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-26 10:45:18 +01:00
										 |  |  |     - name: Delete the modified driver, RPi5
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: '/usr/local/src/nexmon/patches/driver/brcmfmac_{{ kernel.min }}.y-nexmon/brcmfmac.ko'
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |     - name: backup original driver, RPi5
 | 
					
						
							|  |  |  |       command: "mv /usr/lib/modules/{{ kernel.full_pi5 }}/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko.xz /usr/lib/modules/{{ kernel.full_pi5 }}/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko.xz.orig"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: load brcmfmac drivers
 | 
					
						
							|  |  |  |       command: "/sbin/depmod {{ kernel.full_pi5 }}"
 | 
					
						
							|  |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full_pi5 }}"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Delete nexmon content & directory
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /usr/local/src/nexmon/
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # NOW WE BUILD DRIVERS FOR RPi4, RPizero2w and RPi3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: clone nexmon repository
 | 
					
						
							|  |  |  |       git:
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:50:51 +01:00
										 |  |  |         repo: https://github.com/seemoo-lab/nexmon.git
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         dest: /usr/local/src/nexmon
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:51:15 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  |     - name: make firmware, RPi4
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  |       shell: "source ./setup_env.sh && make"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/nexmon/
 | 
					
						
							|  |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  |     - name: make firmware patch (bcm43455c0), RPi4
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  |       shell: "source ./setup_env.sh && cd /usr/local/src/nexmon/patches/bcm43455c0/7_45_206/nexmon/ && make"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/nexmon/
 | 
					
						
							|  |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  |     - name: install new firmware (bcm43455c0), RPi4 RPi5
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       copy:
 | 
					
						
							|  |  |  |         src: /usr/local/src/nexmon/patches/bcm43455c0/7_45_206/nexmon/brcmfmac43455-sdio.bin
 | 
					
						
							|  |  |  |         dest: /usr/lib/firmware/brcm/brcmfmac43455-sdio.bin
 | 
					
						
							|  |  |  |         follow: true
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  |     # NOW WE BUILD DRIVERS FOR RPiZero2W, RPi 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: make firmware patch (bcm43436b0)
 | 
					
						
							|  |  |  |       shell: "source ./setup_env.sh && cd /usr/local/src/nexmon/patches/bcm43436b0/9_88_4_65/nexmon/ && make"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/nexmon/
 | 
					
						
							| 
									
										
										
										
											2024-01-24 10:24:01 +01:00
										 |  |  |       environment:
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  |         QEMU_UNAME: "{{ kernel.full }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     - name: install new firmware (bcm43436b0)
 | 
					
						
							|  |  |  |       copy:
 | 
					
						
							|  |  |  |         src: /usr/local/src/nexmon/patches/bcm43436b0/9_88_4_65/nexmon/brcmfmac43436-sdio.bin
 | 
					
						
							|  |  |  |         dest: /usr/lib/firmware/brcm/brcmfmac43436-sdio.bin
 | 
					
						
							|  |  |  |         follow: true
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: make firmware patch (bcm43430a1)
 | 
					
						
							|  |  |  |       shell: "source ./setup_env.sh && cd /usr/local/src/nexmon/patches/bcm43430a1/7_45_41_46/nexmon/ && make"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/nexmon/
 | 
					
						
							| 
									
										
										
										
											2024-01-24 10:24:01 +01:00
										 |  |  |       environment:
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:49:17 +01:00
										 |  |  |         QEMU_UNAME: "{{ kernel.full }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  |     - name: copy modified driver, RPi4
 | 
					
						
							|  |  |  |       copy:
 | 
					
						
							|  |  |  |         src: "/usr/local/src/nexmon/patches/driver/brcmfmac_{{ kernel.min }}.y-nexmon/brcmfmac.ko"
 | 
					
						
							|  |  |  |         dest: "/usr/lib/modules/{{ kernel.full }}/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko"
 | 
					
						
							|  |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-26 15:28:04 +01:00
										 |  |  |         ARCHFLAGS: "-arch aarch64"
 | 
					
						
							| 
									
										
										
										
											2024-01-25 21:38:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: install new firmware (bcm43430a1)
 | 
					
						
							|  |  |  |       copy:
 | 
					
						
							|  |  |  |         src: /usr/local/src/nexmon/patches/bcm43430a1/7_45_41_46/nexmon/brcmfmac43430-sdio.bin
 | 
					
						
							|  |  |  |         dest: /usr/lib/firmware/brcm/brcmfmac43430-sdio.bin
 | 
					
						
							|  |  |  |         follow: true
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: copy 43430-sdio as 43436s-sdio for the special 43430/1 /2
 | 
					
						
							|  |  |  |       copy:
 | 
					
						
							|  |  |  |         src: /usr/lib/firmware/brcm/brcmfmac43430-sdio.bin
 | 
					
						
							|  |  |  |         dest: /usr/lib/firmware/brcm/brcmfmac43436s-sdio.bin
 | 
					
						
							|  |  |  |         follow: true
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-04 13:48:42 +01:00
										 |  |  |     # delete blob files that make nexmon sad
 | 
					
						
							|  |  |  |     - name: Delete the firmware blob files to avoid some nexmon crashing
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							| 
									
										
										
										
											2023-11-04 13:48:42 +01:00
										 |  |  |         path: '{{ item }}'
 | 
					
						
							|  |  |  |       loop:
 | 
					
						
							|  |  |  |         - /usr/lib/firmware/brcm/brcmfmac43430-sdio.clm_blob
 | 
					
						
							|  |  |  |         - /usr/lib/firmware/brcm/brcmfmac43430-sdio.raspberrypi,model-zero-w.clm_blob
 | 
					
						
							|  |  |  |         - /usr/lib/firmware/brcm/brcmfmac43430-sdio.raspberrypi,3-model-b.clm_blob
 | 
					
						
							|  |  |  |         - /usr/lib/firmware/brcm/brcmfmac43430b0-sdio.raspberrypi,model-zero-2-w.clm_blob
 | 
					
						
							|  |  |  |         - /usr/lib/firmware/brcm/brcmfmac43436-sdio.clm_blob
 | 
					
						
							|  |  |  |         - /usr/lib/firmware/brcm/brcmfmac43436-sdio.raspberrypi,model-zero-2-w.clm_blob
 | 
					
						
							| 
									
										
										
										
											2023-11-04 17:17:28 +01:00
										 |  |  |         - /usr/lib/firmware/brcm/brcmfmac43455-sdio.clm_blob
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     - name: backup original driver
 | 
					
						
							|  |  |  |       command: "mv /usr/lib/modules/{{ kernel.full }}/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko.xz /usr/lib/modules/{{ kernel.full }}/kernel/drivers/net/wireless/broadcom/brcm80211/brcmfmac/brcmfmac.ko.xz.orig"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-24 01:47:23 +01:00
										 |  |  |     - name: load brcmfmac drivers
 | 
					
						
							|  |  |  |       command: "/sbin/depmod {{ kernel.full }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-24 10:24:01 +01:00
										 |  |  |       environment:
 | 
					
						
							|  |  |  |         QEMU_UNAME: "{{ kernel.full }}"
 | 
					
						
							| 
									
										
										
										
											2024-01-24 01:47:23 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     # To shrink the final image, remove the nexmon directory (takes 2.5G of space) post build and installation
 | 
					
						
							|  |  |  |     - name: Delete nexmon content & directory
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /usr/local/src/nexmon/
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Create custom plugin directory
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /usr/local/share/pwnagotchi/custom-plugins/
 | 
					
						
							|  |  |  |         state: directory
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Create custom config directory
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /etc/pwnagotchi/conf.d/
 | 
					
						
							|  |  |  |         state: directory
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: clone pwnagotchi repository
 | 
					
						
							|  |  |  |       git:
 | 
					
						
							| 
									
										
										
										
											2024-01-05 00:24:27 +01:00
										 |  |  |         repo: https://github.com/jayofelony/pwnagotchi-bookworm.git
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         dest: /usr/local/src/pwnagotchi
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: build pwnagotchi wheel
 | 
					
						
							| 
									
										
										
										
											2024-01-05 15:18:14 +01:00
										 |  |  |       command: "pip3 install . --no-cache-dir --break-system-packages"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |       args:
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/pwnagotchi
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: remove pwnagotchi folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /usr/local/src/pwnagotchi
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: create /usr/local/share/pwnagotchi/ folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /usr/local/share/pwnagotchi/
 | 
					
						
							|  |  |  |         state: directory
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-05 14:34:04 +01:00
										 |  |  |     - name: Install go-1.21
 | 
					
						
							|  |  |  |       unarchive:
 | 
					
						
							| 
									
										
										
										
											2023-12-14 14:38:49 +01:00
										 |  |  |         src: https://go.dev/dl/go1.21.5.linux-arm64.tar.gz
 | 
					
						
							| 
									
										
										
										
											2023-11-05 14:34:04 +01:00
										 |  |  |         dest: /usr/local
 | 
					
						
							|  |  |  |         remote_src: yes
 | 
					
						
							|  |  |  |       register: golang
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Update .bashrc for go-1.21
 | 
					
						
							|  |  |  |       blockinfile:
 | 
					
						
							|  |  |  |         dest: /home/pi/.bashrc
 | 
					
						
							|  |  |  |         state: present
 | 
					
						
							|  |  |  |         block: |
 | 
					
						
							|  |  |  |           export GOPATH=$HOME/go
 | 
					
						
							|  |  |  |           export PATH=/usr/local/go/bin:$PATH:$GOPATH/bin
 | 
					
						
							|  |  |  |       when: golang.changed
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |     - name: download pwngrid
 | 
					
						
							| 
									
										
										
										
											2023-11-05 14:34:04 +01:00
										 |  |  |       git:
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |         repo: "{{ packages.pwngrid.source }}"
 | 
					
						
							|  |  |  |         dest: /usr/local/src/pwngrid
 | 
					
						
							| 
									
										
										
										
											2023-11-05 14:34:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |     - name: install pwngrid
 | 
					
						
							| 
									
										
										
										
											2023-11-05 14:34:04 +01:00
										 |  |  |       shell: "export GOPATH=$HOME/go && export PATH=/usr/local/go/bin:$PATH:$GOPATH/bin && go mod tidy && make && make install"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |         chdir: /usr/local/src/pwngrid
 | 
					
						
							| 
									
										
										
										
											2023-11-05 14:34:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |     - name: remove pwngrid folder
 | 
					
						
							| 
									
										
										
										
											2023-11-05 14:34:04 +01:00
										 |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |         path: /usr/local/src/pwngrid
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-05 23:07:02 +01:00
										 |  |  |     - name: download bettercap
 | 
					
						
							|  |  |  |       git:
 | 
					
						
							| 
									
										
										
										
											2023-11-07 08:38:50 +01:00
										 |  |  |         repo: "{{ packages.bettercap.source }}"
 | 
					
						
							| 
									
										
										
										
											2023-11-05 23:07:02 +01:00
										 |  |  |         dest: /usr/local/src/bettercap
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-14 12:34:14 +01:00
										 |  |  |     - name: install bettercap 2.32.2
 | 
					
						
							| 
									
										
										
										
											2023-11-05 23:07:02 +01:00
										 |  |  |       shell: "export GOPATH=$HOME/go && export PATH=/usr/local/go/bin:$PATH:$GOPATH/bin && go mod tidy && make && make install"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  |         chdir: /usr/local/src/bettercap
 | 
					
						
							| 
									
										
										
										
											2023-11-05 15:15:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-05 23:07:02 +01:00
										 |  |  |     - name: remove bettercap folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /usr/local/src/bettercap
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     #- name: download and install bettercap
 | 
					
						
							|  |  |  |     #  unarchive:
 | 
					
						
							|  |  |  |     #    src: "{{ packages.bettercap.url }}"
 | 
					
						
							|  |  |  |     #    dest: /usr/local/bin
 | 
					
						
							|  |  |  |     #    remote_src: yes
 | 
					
						
							|  |  |  |     #    exclude:
 | 
					
						
							|  |  |  |     #      - README.md
 | 
					
						
							|  |  |  |     #      - LICENSE.md
 | 
					
						
							|  |  |  |     #    mode: 0755
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     - name: clone bettercap caplets
 | 
					
						
							|  |  |  |       git:
 | 
					
						
							| 
									
										
										
										
											2023-11-07 08:38:50 +01:00
										 |  |  |         repo: "{{ packages.caplets.source }}"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         dest: /tmp/caplets
 | 
					
						
							|  |  |  |       register: capletsgit
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: install bettercap caplets
 | 
					
						
							|  |  |  |       make:
 | 
					
						
							|  |  |  |         chdir: /tmp/caplets
 | 
					
						
							|  |  |  |         target: install
 | 
					
						
							|  |  |  |       when: capletsgit.changed
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: download and install bettercap ui
 | 
					
						
							|  |  |  |       unarchive:
 | 
					
						
							|  |  |  |         src: "{{ packages.bettercap.ui }}"
 | 
					
						
							|  |  |  |         dest: /usr/local/share/bettercap/
 | 
					
						
							|  |  |  |         remote_src: yes
 | 
					
						
							|  |  |  |         mode: 0755
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-03 21:46:11 +01:00
										 |  |  |     # to always have the bettercap webui available (because why not?)
 | 
					
						
							|  |  |  |     - name: copy pwnagotchi-manual over pwnagotchi-auto caplet
 | 
					
						
							|  |  |  |       ansible.builtin.copy:
 | 
					
						
							|  |  |  |         src: /usr/local/share/bettercap/caplets/pwnagotchi-manual.cap
 | 
					
						
							|  |  |  |         dest: /usr/local/share/bettercap/caplets/pwnagotchi-auto.cap
 | 
					
						
							|  |  |  |         force: true
 | 
					
						
							|  |  |  |       ignore_errors: true
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: create /etc/pwnagotchi folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /etc/pwnagotchi
 | 
					
						
							|  |  |  |         state: directory
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-06 22:43:05 +01:00
										 |  |  |     - name: create log folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /home/pi/logs
 | 
					
						
							|  |  |  |         state: directory
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: check if user configuration exists
 | 
					
						
							|  |  |  |       stat:
 | 
					
						
							|  |  |  |         path: /etc/pwnagotchi/config.toml
 | 
					
						
							|  |  |  |       register: user_config
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: create /etc/pwnagotchi/config.toml
 | 
					
						
							|  |  |  |       copy:
 | 
					
						
							|  |  |  |         dest: /etc/pwnagotchi/config.toml
 | 
					
						
							|  |  |  |         content: |
 | 
					
						
							|  |  |  |           # Add your configuration overrides on this file any configuration changes done to default.toml will be lost!
 | 
					
						
							|  |  |  |           # Example:
 | 
					
						
							|  |  |  |           # ui.display.enabled = true
 | 
					
						
							|  |  |  |           # ui.display.type = "waveshare_2"
 | 
					
						
							|  |  |  |       when: not user_config.stat.exists
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Delete motd
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /etc/motd
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Delete motd 10-uname
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /etc/update-motd.d/10-uname
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Add pwnlog alias
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         dest: /home/pi/.bashrc
 | 
					
						
							| 
									
										
										
										
											2024-01-06 21:45:11 +01:00
										 |  |  |         line: "\nalias pwnlog='tail -f -n300 /home/pi/logs/pwn*.log | sed --unbuffered \"s/,[[:digit:]]\\{3\\}\\]//g\" | cut -d \" \" -f 2-'"
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |         insertafter: EOF
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: Add pwnver alias
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         dest: /home/pi/.bashrc
 | 
					
						
							|  |  |  |         line: "\nalias pwnver='python3 -c \"import pwnagotchi as p; print(p.__version__)\"'"
 | 
					
						
							|  |  |  |         insertafter: EOF
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-09 21:38:03 +01:00
										 |  |  |     - name: Add pwnkill alias to restart pwnagotchi with a signal
 | 
					
						
							|  |  |  |       lineinfile:
 | 
					
						
							|  |  |  |         dest: /home/pi/.bashrc
 | 
					
						
							|  |  |  |         line: "\nalias pwnkill='sudo killall -USR1 pwnagotchi'"
 | 
					
						
							|  |  |  |         insertafter: EOF
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: add firmware packages to hold
 | 
					
						
							|  |  |  |       dpkg_selections:
 | 
					
						
							|  |  |  |         name: "{{ item }}"
 | 
					
						
							|  |  |  |         selection: hold
 | 
					
						
							|  |  |  |       with_items: "{{ packages.apt.hold }}"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: disable unnecessary services
 | 
					
						
							|  |  |  |       systemd:
 | 
					
						
							|  |  |  |         name: "{{ item }}"
 | 
					
						
							|  |  |  |         state: stopped
 | 
					
						
							|  |  |  |         enabled: no
 | 
					
						
							|  |  |  |       with_items: "{{ services.disable }}"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: enable services
 | 
					
						
							|  |  |  |       systemd:
 | 
					
						
							|  |  |  |         name: "{{ item }}"
 | 
					
						
							|  |  |  |         enabled: true
 | 
					
						
							|  |  |  |         state: stopped
 | 
					
						
							|  |  |  |       with_items: "{{ services.enable }}"
 | 
					
						
							|  |  |  |       register: enabled
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-03 21:48:46 +01:00
										 |  |  |     - name: make /root readable, becauase that's where all the files are
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /root
 | 
					
						
							|  |  |  |         mode: '755'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: fix permissions on /home/pi
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /home/pi
 | 
					
						
							|  |  |  |         owner: pi
 | 
					
						
							|  |  |  |         group: pi
 | 
					
						
							|  |  |  |         recurse: true
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-19 14:46:08 +01:00
										 |  |  |     - name: remove pre-collected packages zip
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         path: /root/go_pkgs.tgz
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |     - name: remove /root/go folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /root/go
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: remove /usr/local/go folder
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /usr/local/go
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     - name: remove pip cache
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: /root/.cache/pip
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-01 18:25:26 +01:00
										 |  |  |     - name: remove ssh keys
 | 
					
						
							|  |  |  |       file:
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         path: "{{ item }}"
 | 
					
						
							|  |  |  |       with_fileglob:
 | 
					
						
							|  |  |  |           - "/etc/ssh/ssh_host*_key*"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-08 13:01:31 +01:00
										 |  |  |     - name: regenerate ssh keys
 | 
					
						
							|  |  |  |       shell: "dpkg-reconfigure openssh-server"
 | 
					
						
							|  |  |  |       args:
 | 
					
						
							|  |  |  |         executable: /bin/bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 15:16:33 +01:00
										 |  |  |     # Now we remove packages
 | 
					
						
							|  |  |  |     - name: remove unnecessary apt packages
 | 
					
						
							|  |  |  |       apt:
 | 
					
						
							|  |  |  |         name: "{{ packages.apt.remove }}"
 | 
					
						
							|  |  |  |         state: absent
 | 
					
						
							|  |  |  |         purge: yes
 | 
					
						
							|  |  |  |       register: removed
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 17:30:15 +01:00
										 |  |  |     - name: remove dependencies that are no longer required
 | 
					
						
							|  |  |  |       apt:
 | 
					
						
							|  |  |  |         autoremove: yes
 | 
					
						
							|  |  |  |       when: removed.changed
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-25 16:31:35 +01:00
										 |  |  |     - name: clean apt cache
 | 
					
						
							|  |  |  |       apt:
 | 
					
						
							|  |  |  |         autoclean: true
 | 
					
						
							|  |  |  |       when: removed.changed
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-31 22:49:00 +01:00
										 |  |  |   handlers:
 | 
					
						
							|  |  |  |     - name: reload systemd services
 | 
					
						
							|  |  |  |       systemd:
 | 
					
						
							|  |  |  |         daemon_reload: yes
 | 
					
						
							|  |  |  |       when: enabled.changed
 |