Unofficial python API for brain.fm
Project description
The Connection class exposes three operations: login, list_stations, and get_token. Please open an issue if there’s another operation you need.
This client requires Python 3.5+.
CLI Quickstart
$ pip install brainfm
$ brain init
Email: user@gdomain.com
Password: <hidden>
Repeat for confirmation: <hidden>
Add the following to your .profile, .bashrc, or equivalent:
export BRAINFM_SID="s%3...s0xo"
$ # <commands to modify and reload profile>
$ brain play 300
Library Quickstart
pip install brainfm
>>> import brainfm
>>> client = brainfm.Connection()
>>> client.login("your@email.here", "hunter2")
>>> client.list_stations()
[{'name': 'Cinematic Music Focus', 'id': 300,
'string_id': 'explore.focus.cinematic'},
{'name': 'Beach Focus', 'id': 53,
'string_id': 'explore.focus.beach'},
...]
>>> token = client.get_token(53)
>>> token
'63f4b59b-93f4-45e6-b0c2-eb6b1582fb96'
>>> client.make_stream_url(token)
'https://stream.brain.fm/?tkn=63f4b59b-93f4-45e6-b0c2-eb6b1582fb96'
Now, open the stream using that token:
https://stream.brain.fm/?tkn=63f4b59b-93f4-45e6-b0c2-eb6b1582fb96
CLI
Expects an environment variable named BRAINFM_SID to exist. You can use brain init to generate one:
$ brain init
Email: user@gdomain.com
Password: <hidden>
Repeat for confirmation: <hidden>
Add the following to your .profile, .bashrc, or equivalent:
export BRAINFM_SID="s%3...s0xo"
Usage:
$ brain ls +Available Stations------------+---------------------------+ | id | name | string_id | +-----+------------------------+---------------------------+ | 34 | Relaxed Focus | explore.relaxed | | 53 | Beach Focus | explore.focus.beach | | 54 | Chimes & Bowls Focus | explore.focus.bells | | 55 | Electronic Music Focus | explore.focus.electronic | | ... | ... | ... | | 262 | Wind Relax | explore.relax.wind | | 300 | Cinematic Music Focus | explore.focus.cinematic | +-----+------------------------+---------------------------+ $ brain gt 60 3ff0eab0-a5f6-11e6-a5c2-f11c700a6178 $ brain play 60 # opens a browser at: # https://stream.brain.fm/?tkn=3ff0eab0-a5f6-11e6-a5c2-f11c700a6178
User-Agent
By default the user agent is github.com/numberoverzero/brainfm followed by the project __version__. There is also a packaged browser-like user-agent:
>>> client = brainfm.Connection(...)
>>> client.user_agent = brainfm.BROWSER
Instead of filtering, maybe this will be a good metric for customer interest in an official API :heart:
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file brainfm-1.0.0.tar.gz.
File metadata
- Download URL: brainfm-1.0.0.tar.gz
- Upload date:
- Size: 5.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9f07b35ff5228845ba66b6f1704072da905f2985acca8fb29ac636ac78eae6c1
|
|
| MD5 |
9e3b302ad6435b2e9f8e4aa69dd486c6
|
|
| BLAKE2b-256 |
81434d6b165e9e47ab24123e89507c1245039085b5d64ff27916fd7eb3c430d2
|
File details
Details for the file brainfm-1.0.0-py3-none-any.whl.
File metadata
- Download URL: brainfm-1.0.0-py3-none-any.whl
- Upload date:
- Size: 6.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3d9c64e9a12f6e49618b274d0730ff8a8154c1ac5fd6f1c03b4ac5cfdd283e8d
|
|
| MD5 |
c064bde73851632005b1fb670c0b2339
|
|
| BLAKE2b-256 |
2de07dfc543efb873afde2afee51337979340d25fa55cace9f0160249e99e03c
|