The goal of this project is to create a method that allows users of the Flipper Zero to easily set up macless-haystack locally, for use with the FindMyFlipper app.
Functionally, this is primarily a fork of the endpoint container provided by macless-hackstack.
The major change to that container is that the Username, Password, and MFA code requested for the Apple account are no longer input from the terminal in interactive mode.
Instead, this is done through the web, to make it easier to authenticate when the container starts. This way, you can simply authenticate through your browser and keep the container running without stopping it.
I have also pre-enabled the certificate included with the macless-haystack container, so it uses HTTPS by default after authentication has completed.
I also created a Dockerfile to run the web application from macless-haystack locally, as some Flipper Zero users have had trouble with the app publically hosted on the web. The web application container also uses HTTPS by default.
I made the changes to the endpoint container, because some users of the Flipper Zero have reported that the server doesn't work to query the device properly after the container is restarted.
When using the provided compose file, the endpoint container from this project will prompt for authentication each time it starts. This is how it has been used in testing. When using a volume, it should keep credentials persistent the same way that the original macless-haystack container does, if you prefer that.
Keep in mind, the credentials are sent to your local server in plain text from your browser. As such, you should only authenticate within your local machine, or inside of a network that you trust.
These instructions have been customized for use with the Flipper Zero.
1. Prerequisites
- Docker installed
- Python3 and pip3 installed
- Apple-ID with F2A (mobile or sms) enabled
- Flipper Zero with MFW installed
Instructions to install Docker
Instructions to install Python
2. Flipper setup
-
Head over to the FindMyFlipper repo and download
generate_keys.py
from the KeyGeneration folder. -
Execute the
generate_keys.py
script to generate your keypair. (Note: dependencycryptography
is needed. Install it withpip install cryptography
)
pip install cryptography
python3 generate_keys.py
-
Follow the prompts and afterward you should have a .keys file generated in a keys subfolder.
-
Put the .keys file onto the Flipper, inside the AppsData/FindMyFlipper folder. Alternatively, you can manually enter this information into the FindMyFlipper app.
-
Open the FindMyFlipper app after starting the Flipper with the SD Card re-inserted.
-
Press the right button to open the config menu, and then select "Import Tag From File".
-
Select "OpenHaystack.keys" and then select the keys file.
-
Start broadcasting using the FindMyFlipper app.
3. Server setup
To make set up easier, I have pre-built the containers and created a compose file to simplify the process. Follow the "Docker Hub" steps if you want to use the pre-built containers.
You can also build the containers yourself using the Dockerfile in "endpoint" to build "macless-haystack-flipper", and "web" to build "macless-flipper-web". Follow the "Building It Yourself" steps if you want to do so.
Choose either the "Docker Hub" or "Building It Yourself" for the next steps.
- Create a new Docker network
docker network create mh-network
- Create a working directory and make a file inside called "docker-compose.yml" with these contents
version: '3'
services:
anisette:
image: dadoum/anisette-v3-server:latest
container_name: anisette
restart: unless-stopped
ports:
- "6969:6969"
networks:
- mh-network
macless-haystack:
image: sourcebunny/macless-haystack-flipper:latest
container_name: macless-haystack-flipper
restart: unless-stopped
ports:
- "6176:6176"
networks:
- mh-network
macless-haystack-web:
image: sourcebunny/macless-haystack-web:latest
container_name: macless-haystack-web
restart: unless-stopped
ports:
- "9443:443"
networks:
- mh-network
networks:
mh-network:
external: true
- Start the Docker containers (run inside your working directory with the docker-compose.yml file)
docker-compose up -d
-
Browse to your server on port 6176. For example, http://localhost:6176
-
You will be asked for your Apple-ID, password and your 2FA.
Your browser should redirect you through these prompts. If not, you may need to browse back to the server on port 6176 manually between them.
It also seems that sometimes you will need to log in twice before the 2FA prompt arrives. Just keep browsing back to the main page on 6176, and filling in the requested prompts.
- Test the server by browsing to https://localhost:6176, you should see "Nothing to see here"
- Clone or download the respository files
git clone https://github.com/sourcebunny/macless-haystack-flipper.git
- Create a new Docker network
docker network create mh-network
- Navigate to the project's "endpoint" directory and build the Docker image for the "macless-haystack-flipper" service
cd macless-haystack-flipper/endpoint
docker build -t local/macless-haystack-flipper:latest .
- Navigate to the project's "web" directory and build the Docker image for the "macless-haystack-web" service
cd macless-haystack-flipper/web
docker build -t local/macless-haystack-web:latest .
- Create a working directory outside of the downloaded repo and make a file inside called "docker-compose.yml" with these contents
version: '3'
services:
anisette:
image: dadoum/anisette-v3-server:latest
container_name: anisette
restart: unless-stopped
ports:
- "6969:6969"
networks:
- mh-network
macless-haystack-flipper:
image: local/macless-haystack-flipper:latest
container_name: macless-haystack-flipper
restart: unless-stopped
ports:
- "6176:6176"
networks:
- mh-network
macless-haystack-web:
image: local/macless-haystack-web:latest
container_name: macless-haystack-web
restart: unless-stopped
ports:
- "9443:443"
networks:
- mh-network
networks:
mh-network:
external: true
- Start the Docker containers (run inside your working directory with the docker-compose.yml file)
docker-compose up -d
-
Browse to your server on port 6176. For example, http://localhost:6176
-
You will be asked for your Apple-ID, password and your 2FA.
Your browser should redirect you through these prompts. If not, you may need to browse back to the server on port 6176 manually between them.
It also seems that sometimes you will need to log in twice before the 2FA prompt arrives. Just keep browsing back to the main page on 6176, and filling in the requested prompts.
- Test the server by browsing to https://localhost:6176, you should see "Nothing to see here"
4. Frontend setup
This repository includes a Dockerfile that hosts the web application locally.
This should already be running if you started the included docker-compose.yml file, and you can follow the steps to get it working.
-
Browse to your server with HTTPS on port 9443. For example, https://localhost:9443
-
Go to the settings, and correct the URL to match your server, on port 6176. For example, https://localhost:6176
-
Press "OK", and return to the main page.
-
Press the "+" button to add a new device.
-
Select "Import Accessory".
-
Pick any unique 7 digit ID number, and use it for the ID field. Other numbers and lengths may also work.
-
Name the device based on your preference. This will be displayed within the page.
-
Copy the Private Key from the ".keys" file you generated into the "Private Key (Base64)" field.
-
Enable both the "Is Active" and "Is Deployed" checkboxes.
-
Press the "Import" button.
-
Press the "Refresh" button. If you don't see your device's location, try again after some time. You can also try moving closer to a device such as an Apple iPhone.
Included projects are (Credits goes to them for the hard work):
- The original Openhaystack
- Stripped down to the mobile application (Android) and ESP32 firmware. ESP32 firmware combined with FindYou project and optimizations in power usage.
- Android application
- ESP32 firmware
- Biemster's FindMy
- Customization in keypair generator to output an array for the ESP32 firmware and a json for import in the Android application.
- The standalone python webserver for fetching the FindMy reports
- Positive security's Find you
- ESP32 firmware customization for battery optimization
- acalatrava's OpenHaystack-Fimware alternative
- NRF5x firmware customization for battery optimization
- dchrist's macless-haystack
- MatthewKuKanich's FindMyFlipper
This repository is for research purposes only, the use of this code is your responsibility.
I take NO responsibility and/or liability for how you choose to use any of the source code available here. By using any of the files available in this repository, you understand that you are AGREEING TO USE AT YOUR OWN RISK. Once again, ALL files available here are for EDUCATION and/or RESEARCH purposes ONLY.