Cross-platform iMessage POC
Go to file
2023-11-05 21:25:52 -05:00
emulated New serial 2023-10-30 14:30:19 -04:00
ids Daemon flag addition (#41) 2023-11-01 20:59:13 -04:00
proxy Iterate over references instead of indexes for identities 2023-08-20 17:15:45 -06:00
.gitignore incorporate most of June's changes 2023-08-19 15:25:21 -04:00
albert.py incorporate most of June's changes 2023-08-19 15:25:21 -04:00
apns.py incorporate most of June's changes 2023-08-19 15:25:21 -04:00
bags.py more refactoring 2023-07-27 17:34:38 -04:00
demo.py Update demo.py 2023-11-01 22:05:33 -04:00
exceptions.py Fix ignoring gateway parameter (#34) 2023-10-23 19:28:36 -04:00
gateway_fetch.py Add gateway_fetch code 2023-09-22 15:44:25 -04:00
imessage.py refactoring and cleanup 2023-08-25 22:26:37 -04:00
LICENSE Add licensing information 2023-08-02 11:42:06 -04:00
README.md Updated readme to use venv and crontab 2023-11-05 21:25:52 -05:00
requirements.txt Add trio to requirements.txt 2023-09-01 13:54:00 +01:00
sms_registration.py Fix ignoring gateway parameter (#34) 2023-10-23 19:28:36 -04:00

Overview

This is the Pypush sms-registration branch. This branch allows you to register your phone number to your Apple account as an iMessage alias.

sms-registration is not fully developed yet, and still contains bugs! If you encounter any sort of bug, please join our Discord, however please note we cannot get to everyone, so try to figure out any errors yourself before asking.

Please note: You will have to use a client to send messages from your phone. We recommend Beeper, which is the best solution to keep all your chat apps inside one place, including iMessage! You can also use BlueBubbles (which requires you to have a server Mac running 24/7) or Sunbird (which is closed source and requires you to be a beta tester). One of our community members is also currently working on a BlueBubbles fork that implements a version of Pypush within it, so no server is needed and number reregistration is automatically ran.

However, Beeper is completely free and easy to use, and comes packed with multiple features that rivals native apps. Beeper is currently in the process of removing the waitlist, so you will have to use an invite link shared to you in order to skip the waitlist until this change is made. This app is what most testing is done on, and is by far the most popular in the Android and iMessage community.

Installation

You will first install Pypush onto your machine. Please keep in mind that you will have to have a script running on a home server or PC 24/7 to keep your number active! See below for instructions.

PNRgateway

In order for Apple to verify your number, a specialized message has to be sent from your phone to Apple's "gateway number" and have the r nbnnnnnnnnnnnnnnnnnnnnnnesponse captured. This number is different for each carrier, however the newest app version should automatically find your gateway number. If PNRgateway cannot find your gateway number, see below for help.

  1. Enable USB debugging/ADB on your phone. There are multiple online guides that guide you through this based on your phone.
  2. Install the APK. The message link containing the APK is located here, and the GitHub repository is here.
  3. Grant SMS permissions. This will be in the app info page, and on the newer version, there should be a button in the app that does this for you.
  4. Connect your phone to the same WiFi network as your host PC, and open the app.

Pypush

Make sure you have git and Python installed.

  1. git clone -b sms-registration https://github.com/beeper/pypush
  2. cd pypush

Number Registration on Linux/MacOS

It is strongly recommended to use a Python virtual environment to setup Pypush. This ensures changes in your system's Python installation does not break compatibility with Pypush with system updates.

  1. If you do not already have a directory where Python virtual environments are located then create a directory for your Python virtual environment. If you already have one then skip this step. Virtual environments are traditionally placed in a hidden folder in your home directory on Linux/MacOS. It can be created anywhere you wish. These instructions will assume you created it in your home directory.
mkdir ~/.venv
  1. Create a virtual environment using Python 3.10:
python3.10 -m pypush ~/.venv
  1. Activate the virtual environment:
source ~/.venv/pypush/bin/activate
  1. Install the required packages using pip:
pip install -r requirements.txt
  1. Run the demo script, replacing [ip] with your phone's local IP address:
python demo.py --phone [ip]

Number reregistration option 1, automatic reregistration

Automatic reregistration is handled by determining when your imessage registration certificate expires and reregistering 5 minutes before expiration. Put the following in a text file and save as pypush_reregister.sh in your home directory:

#!/bin/bash
cd /path/to/pypush
source ~/.venv/pypush/bin/activate
python ./demo.py --reregister --daemon
  1. Make the reregistration script executable:
chmod +x ~/pypush_reregister.sh
  1. Use Screen to easily monitor reregistration status and set to run on boot, replacing "user" with your username:
@reboot screen -S pypush /home/user/pypush_reregister.sh > /dev/null 2>&1
  1. Reboot

The basics of using screen are outlined below but this is not intended to be a tutorial in using screen. In order to see a more complete guid please visit the following guide. To monitor the status of registration you can connect to the virtual screen you created.

$ screen -r pypush

To disconnect from the virtual screen press ctrl+a d.

Number reregistration option 2, registration every 30 minutes

Put the following in a text file and save as pypush_reregister.sh in your home directory:

#!/bin/bash
cd /path/to/pypush
source ~/.venv/pypush/bin/activate
python ./demo.py --reregister
  1. Make the reregistration script executable:
chmod +x ~/pypush_reregister.sh
  1. To automatically reregister every 30 minutes, execute the following:
  1. Add the following to your crontab file, replacing "user" with your username:
*/30 * * * * /home/user/pypush_reregister.sh

Please note: This last script is the script you will be running continuously. We recommend every 30 minutes.

Good to Know

You will have to reregister your number every so often. This can last anywhere between 10 minutes to 48 hours, and usually the longer you run the script, the longer it takes to deregister. We may implement a feature to automatically detect deregistration in the future.

If you ever have any type of error, delete the config.json file and run steps 3-4 again. This is really important.

Issues

This is still in the development stage, so expect issues and bugs. Here is a list of possible errors:

Timeout waiting for response from gateway

This means it took too long for Apple to respond from the gateway number, PNRgateway is not sending the message to the correct gateway, or the response is in an incorrect encoding. This is common, please reach out for help.

Connection Closed

This means the app crashed or could not parse the response data from the gateway. This is also common, and a recent bug has caused this error to happen excessively with non-Verizon carriers.

Failed to resolve host

This error occurs when you are not connected to the same network, the all is closed, or you are not using the correct IP.

Automatic gateway detection failed

This is because PNRgateway could not detect the correct gateway corresponding to your carrier. Please report this issue if you find it. To fix this issue, when you are on step 1 of number registration, append --gateway [number] after the --ip argument, and replace number with the gateway number. (You can find your gateway number here)

Failed to load the dynamic library

This is a Unicorn error. We do not yet know exactly what causes this error, but on MacOS try to run sudo brew install unicorn. This error usually occurs in MacOS VMs.

Failed to register

Delete config.json and retry.

If you encounter any other errors, please try to find answers online for help.

Resources