Metadata-Version: 2.1
Name: brainfm
Version: 2.0.0
Summary: Unofficial python API for brain.fm
Home-page: https://github.com/numberoverzero/brainfm
Author: Joe Cross
Author-email: joe.mcross@gmail.com
License: MIT
Keywords: brainfm api
Platform: any
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Topic :: Software Development :: Libraries
Requires-Dist: click (>=6)
Requires-Dist: jmespath (>=0.9)
Requires-Dist: requests (>=2.11)
Requires-Dist: terminaltables (>=3.1)

Unofficial Brain.fm Python Client (3.5+)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

The ``Connection`` class exposes four operations: ``login``,
``list_stations``, ``get_token`` and ``make_stream_url``.  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"
        export BRAINFM_STREAM_ENDPOINT="https://..."

    $ # ... commands to modify and reload profile ...
    $ brain play 300

====================
 Library Quickstart
====================

::

    pip install brainfm

.. code-block:: pycon

    >>> 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
=====

You must pass an sid with ``--sid`` or define an environment variable
``BRAINFM_SID``.  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"
        export BRAINFM_STREAM_ENDPOINT="https://..."

While setting ``BRAINFM_STREAM_ENDPOINT`` is not strictly necessary, the
cli is faster when either the env var is defined or you provide the endpoint
explicitly: ``brain --stream-endpoint=... ls``

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

--------------------
 Override Endpoints
--------------------

From the cli you can override the api and stream endpoints with
``--api-endpoint`` and ``--stream-endpoint`` respectively.  This is useful
when the service switches endpoints but this library hasn't been updated to
match.

You can also provide these as env variables
``BRAINFM_API_ENDPOINT`` and ``BRAINFM_STREAM_ENDPOINT``

============
 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:

.. code-block:: pycon

    >>> 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:


