Files
AppleMusicDecrypt/README.md

94 lines
2.9 KiB
Markdown
Raw Normal View History

2024-05-04 18:14:57 +08:00
# AppleMusicDecrypt
2024-05-04 23:59:52 +08:00
Apple Music decryption tool, based
on [zhaarey/apple-music-alac-atmos-downloader](https://github.com/zhaarey/apple-music-alac-atmos-downloader)
2024-05-04 18:14:57 +08:00
2024-05-04 23:59:52 +08:00
**WARNING: This project is currently in an extremely early stage, and there are still a large number of undiscovered
bugs and unfinished features. USE IT WITH CAUTION.**
2024-05-04 18:14:57 +08:00
# Usage
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
```shell
# Download song/album with default codec (alac)
download https://music.apple.com/jp/album/nameless-name-single/1688539265
# Download song/album with specified codec
download https://music.apple.com/jp/song/caribbean-blue/339592231 -c aac
```
# Support Codec
2024-05-04 23:00:54 +08:00
- `alac (audio-alac-stereo)`
- `ec3 (audio-atmos / audio-ec3)`
- `ac3 (audio-ac3)`
- `aac (audio-stereo)`
- `aac-binaural (audio-stereo-binaural)`
2024-05-04 23:22:08 +08:00
- `aac-downmix (audio-stereo-downmix)`
2024-05-04 18:14:57 +08:00
# Support Link
2024-05-04 23:59:52 +08:00
- Apple Music Song Share
Link (https://music.apple.com/jp/album/%E5%90%8D%E3%82%82%E3%81%AA%E3%81%8D%E4%BD%95%E3%82%82%E3%81%8B%E3%82%82/1688539265?i=1688539274)
2024-05-04 18:14:57 +08:00
- Apple Music Album Share Link (https://music.apple.com/jp/album/nameless-name-single/1688539265)
- Apple Music Song Link (https://music.apple.com/jp/song/caribbean-blue/339592231)
# Deploy
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
## Prepare Local Environment
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
1. Install [GPAC](https://gpac.io/downloads/gpac-nightly-builds/)
2024-05-04 23:59:52 +08:00
2. Download [Bento4 MP4Tools](https://www.bento4.com/downloads/) and add the executable files to the environment
variables
2024-05-04 18:14:57 +08:00
3. Run `gpac -version`, `mp4box -version`, `mp4extract`, `mp4edit` and make sure all the commands run fine
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
## Prepare Android Environment
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
### For WSA (Recommend):
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
1. Install Apple Music (3.6.0-beta) and login
2024-05-04 19:09:33 +08:00
2. Play a song in Apple Music
2024-05-04 23:59:52 +08:00
3. Install WSA from [LSPosed/MagiskOnWSALocal](https://github.com/LSPosed/MagiskOnWSALocal). Choose the version that
includes Magisk but not GApps
4. Install following Magisk
modules: [magisk-frida](https://github.com/ViRb3/magisk-frida), [sqlite3-magisk-module](https://github.com/rojenzaman/sqlite3-magisk-module)
2024-05-04 19:09:33 +08:00
5. Edit `config.toml`
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
```toml
[[devices]]
host = "127.0.0.1"
port = 58526 # Replace this value to your WSA ADB port!
agentPort = 10020
fridaPath = "/system/bin/frida-server"
suMethod = "su -c"
```
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
### For Google Android Emulator
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
1. Install Apple Music (3.6.0-beta) and login
2024-05-04 19:09:33 +08:00
2. Play a song in Apple Music
3. Manually install Frida and start frida-server in background
4. Edit `config.toml`
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
```toml
[[devices]]
host = "127.0.0.1"
port = 5555
agentPort = 10020
fridaPath = "/data/local/tmp/frida-server-16.2.1-android-x86_64" # Replace this value to your frida-server path!
suMethod = "su 0"
```
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
## Run Script
2024-05-04 23:59:52 +08:00
### Use pre-built script (For Windows)
2024-05-04 23:59:52 +08:00
Download latest build from [Actions](https://github.com/WorldObservationLog/AppleMusicDecrypt/actions) (need login your
GitHub account). Unzip it, and run `main.exe`
### Manually Run
2024-05-04 23:59:52 +08:00
2024-05-04 18:14:57 +08:00
```shell
git clone https://github.com/WorldObservationLog/AppleMusicDecrypt.git
cd AppleMusicDecrypt
poetry install
poetry run python main.py
```