Ensure you have a fairly recent Python 3 install, then you can install dependencies required for work:
# Setup a venv
python -m venv env/
# Activate venv
source env/bin/activate # Unix systems
env/Scripts/Activate.ps1 # PowerShell
env/Scripts/activate.bat # cmd
# Required to work on manifests
pip install -r requirements.txt
pre-commit install
# Required to work on the build script
pip install -r ci/requirements.txt
If pre-commit
is complaining about UnicodeDecodeError
, a temporary workaround is to edit the pre-commit hooks to use UTF-8:
# lib\site-packages\pre_commit_hooks\sort_simple_yaml.py
# line 110
# snip
with open(filename, 'r+', encoding='utf8') as f:
# snip
The files to edit are in this repository.
bypasses.yaml
contains information on the bypass themselves; mainly, its name and the repo it's hosted on.apps/
contains individual files for each app, containing basic information and which bypass to use.- Filename must be
<app name>.yaml
- Filename must be
As each already have their own defined structure, please follow the format on existing files.
All manifests must be encoded in UTF-8, with the newline being \n
(Unix line endings)
Check with this file for available bypasses. Its structure is as follows:
- Root key is the name of the bypass. It should be as close to the name of the package as possible, so use
Liberty Lite (Beta)
instead ofLiberty Lite Beta
. - Under the root key there are three keys that are made use of:
notes
: Extra notes about the bypass that does not fit any of the keys below.repo
: APT (Sileo, Cydia, etc.) source of the bypass. If the bypass is not hosted in a repo, please link the canonical source in thenotes
key (see: GenshinJailbreakBypass)guide
: Guide link for the bypass. If you want to add a guide, please do so under thedocsify
branch.
Each app has its own individual manifest under the apps/
directory, which has this structure:
- Filename:
<app name>.yaml
. It should be as close to the app name on App Store as possible; however, there are a few allowed exceptions:- If the app name contains any of the following characters:
< > : " / \ ? *
, it should be omitted. - If the app name contains a short description, such as YONO SBI:Banking and Lifestyle, the description should be cut off (YONO SBI).
- If the app name is written in a non-English script, it should be romanized (e.g. Альфа-Банк -> Alfa-Bank).
- If the app name contains any of the following characters:
- Inside the file are a few keys, in order:
name
, whose value should be the name of the app. Again, it should be as close to the app name on App Store as possible, but exception ii applies.uri
must contain an App Store URL to the app. This can be easily acquired by googlingsite:apps.apple.com <app name>
. If the link is not English, suffix the link with?l=en
(e.g.https://apps.apple.com/hk/app/aastocks-m-mobile/id368726182?l=en
).bypasses
contain information on how to bypass the app's detection:- If there is no known bypasses, the key's value is
null
:bypasses: null
- If there are bypasses, the key contains an array, with each item containing these keys:
name
: The name of the bypass, must be the same as a known bypass inbypasses.yaml
notes
: Extra notes about using the bypassversion
: Specify a version to downgrade to for the bypass
Eithername
ornotes
must exist.
- If there is no known bypasses, the key's value is