Skip to main content

Bindings for the mixcloud.com API

Project description

Mixcloud.com API access from Python

Build Status Coverage Status

This provides a Python API for the http://mixcloud.com website.

Example

from mixcloud import Mixcloud
m = Mixcloud()
u = m.user('michelplatiniste')
for c in u.cloudcasts():
    print c.name

Authorization

You must have an application registered with Mixcloud and a corresponding client ID and secret.

Authorization is a multi-step process:

  1. Generate the authorization URL

  2. Redirect the user to the URL to authorize your application

  3. Collect the code query string parameter from the redirect

  4. Exchange the code for an access token

o = mixcloud.MixcloudOauth(
    client_id=client_id, client_secret=client_secret,
    redirect_uri=redirect_uri)

url = o.authorize_url()

# Next redirect the user to `url`. They will be redirected to your
# redirect uri with a `code` query string parameter. This must be
# exchanged with Mixcloud for an access token.

access_token = o.exchange_token(code)

# This can then be used for calls that required authorization.

m = mixcloud.Mixcloud(access_token=access_token)
print(m.me())

Optionally you can store an access token in your .netrc file and it will be used automatically. The machine name must be mixcloud-api.

E.g.:

machine mixcloud-api
password my_access_token

Uploading

It is possible to use this module to upload cloudcasts. In order to do that you need to be authenticated. To do that, provide an API token to the constructor.

m = mixcloud.Mixcloud(access_token=access_token)
cc = Cloudcast(...)
with open(mp3_path) as mp3:
    r = m.upload(cc, mp3)

YML file support

It is possible to represent cloudcasts as YAML files. See example.yml.

The relevant keys are:

Key

Type

title

String

desc

String

tags

List of strings

tracks

List of tracks

Each track is a dict with the following keys:

Key

Type

start

Integer

artist

String

track

String

You can leverage YAML syntax for the “start” field: 2:54 will be parsed directly as 174 (then number of seconds).

It is possible to parse such a file with:

with open(yml_path) as yml:
    cc = mixcloud.Cloudcast.from_yml(yml, None)

Mocking

A mock server is provided for testing purposes in mixcloud.mock.

Changelog

0.4.0

release date: 2015-10-27

  • Switch to semantic versioning.

  • Include access token when calling /me (#10)

  • Add a helper class for OAuth (#11)

  • Support access token stored in netrc (#9, #12)

0.0.3

release date: 2015-03-15

  • Pictures can be uploaded and retrieved (#6)

  • Include LICENSE in tarball (#8)

0.0.2

release date: 2015-01-28

  • Switch from requirements.txt to install_requires (#7)

  • Add HISTORY.rst to MANIFEST.in

0.0.1

release date: 2015-01-28

  • Initial release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mixcloud-0.4.0.tar.gz (7.7 kB view details)

Uploaded Source

File details

Details for the file mixcloud-0.4.0.tar.gz.

File metadata

  • Download URL: mixcloud-0.4.0.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for mixcloud-0.4.0.tar.gz
Algorithm Hash digest
SHA256 797a7ac23187b033411d2a0897b4068af774eea93e92d18ac4f542f95af0d661
MD5 905e036e075181eaabee68559aca5653
BLAKE2b-256 e39e70aedb77e9b5d99b54dd569d0ba2357cb64909b20805f459f90d45c426c6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page