Musicmanager Interface¶
-
class
gmusicapi.clients.
Musicmanager
(debug_logging=True, validate=True, verify_ssl=True)¶ Allows uploading by posing as Google’s Music Manager.
Musicmanager uses OAuth, so a plaintext email and password are not required when logging in.
For most authors and users of gmusicapi scripts,
perform_oauth()
should be run once per machine to store credentials to disk. Future calls tologin()
can use use the stored credentials by default.Some authors may want more control over the OAuth flow. In this case, credentials can be directly provided to
login()
.
Setup and login¶
-
classmethod
Musicmanager.
perform_oauth
(storage_filepath=<object object>, open_browser=False)¶ Provides a series of prompts for a user to follow to authenticate. Returns
oauth2client.client.OAuth2Credentials
when successful.In most cases, this should only be run once per machine to store credentials to disk, then never be needed again.
If the user refuses to give access,
oauth2client.client.FlowExchangeError
is raised.Parameters: - storage_filepath –
a filepath to write the credentials to, or
None
to not write the credentials to disk (which is not recommended).Appdirs
user_data_dir
is used by default. Check the OAUTH_FILEPATH field on this class to see the exact location that will be used. - open_browser – if True, attempt to open the auth url in the system default web browser. The url will be printed regardless of this param’s setting.
This flow is intentionally very simple. For complete control over the OAuth flow, pass an
oauth2client.client.OAuth2Credentials
tologin()
instead.- storage_filepath –
-
Musicmanager.
__init__
(debug_logging=True, validate=True, verify_ssl=True)¶ Parameters: - debug_logging –
each Client has a
logger
member. The logger is namedgmusicapi.<client class><client number>
and will propogate to thegmusicapi
root logger.If this param is
True
, handlers will be configured to send this client’s debug log output to disk, with warnings and above printed to stderr. Appdirsuser_log_dir
is used by default. Users can run:from gmusicapi.utils import utils print utils.log_filepath
to see the exact location on their system.
If
False
, no handlers will be configured; users must create their own handlers.Completely ignoring logging is dangerous and not recommended. The Google Music protocol can change at any time; if something were to go wrong, the logs would be necessary for recovery.
- validate –
if False, do not validate server responses against known schemas. This helps to catch protocol changes, but requires significant cpu work.
This arg is stored as
self.validate
and can be safely modified at runtime. - verify_ssl – if False, exceptions will not be raised if there are problems verifying SSL certificates. Be wary of using this option; it’s almost always better to fix the machine’s SSL configuration than to ignore errors.
- debug_logging –
-
Musicmanager.
login
(oauth_credentials='/home/docs/.local/share/gmusicapi/oauth.cred', uploader_id=None, uploader_name=None)¶ Authenticates the Music Manager using OAuth. Returns
True
on success,False
on failure.Unlike the
Webclient
, OAuth allows authentication without providing plaintext credentials to the application.In most cases, the default parameters should be acceptable. Users on virtual machines will want to provide uploader_id.
Parameters: - oauth_credentials –
oauth2client.client.OAuth2Credentials
or the path to aoauth2client.file.Storage
file. By default, the same default path used byperform_oauth()
is used.Endusers will likely call
perform_oauth()
once to write credentials to disk and then ignore this parameter.This param is mostly intended to allow flexibility for developers of a 3rd party service who intend to perform their own OAuth flow (eg on their website).
- uploader_id –
a unique id as a MAC address, eg
'00:11:22:33:AA:BB'
. This should only be provided in cases where the default (host MAC address incremented by 1) will not work.Upload behavior is undefined if a Music Manager uses the same id, especially when reporting bad matches.
ValueError
will be raised if this is provided but not in the proper form.OSError
will be raised if this is not provided and a real MAC could not be determined (most common when running on a VPS).If provided, use the same id on all future runs for this machine, because of the upload device limit explained below.
- uploader_name –
human-readable non-unique id; default is
"<hostname> (gmusicapi-{version})"
.This doesn’t appear to be a part of authentication at all. Registering with (id, name = X, Y) and logging in with (id, name = X, Z) works, and does not change the server-stored uploader_name.
There are hard limits on how many upload devices can be registered; refer to Google’s docs. There have been limits on deauthorizing devices in the past, so it’s smart not to register more devices than necessary.
- oauth_credentials –
-
Musicmanager.
logout
(revoke_oauth=False)¶ Forgets local authentication in this Client instance.
Parameters: revoke_oauth – if True, oauth credentials will be permanently revoked. If credentials came from a file, it will be deleted. Returns
True
on success.
Uploading Songs¶
-
Musicmanager.
upload
(filepaths, enable_matching=False, enable_transcoding=True, transcode_quality='320k')¶ Uploads the given filepaths.
All non-mp3 files will be transcoded before being uploaded. This is a limitation of Google’s backend.
An available installation of ffmpeg or avconv is required in most cases: see the installation page for details.
Returns a 3-tuple
(uploaded, matched, not_uploaded)
of dictionaries, eg:( {'<filepath>': '<new server id>'}, # uploaded {'<filepath>': '<new server id>'}, # matched {'<filepath>': '<reason, eg ALREADY_EXISTS>'} # not uploaded )
Parameters: - filepaths – a list of filepaths, or a single filepath.
- enable_matching – if
True
, attempt to use scan and match to avoid uploading every song. This requires ffmpeg or avconv. WARNING: currently, mismatched songs can not be fixed with the ‘Fix Incorrect Match’ button norreport_incorrect_match
. They would have to be deleted and reuploaded with matching disabled (or with the Music Manager). Fixing matches from gmusicapi may be supported in a future release; see issue #89. - enable_transcoding – if
False
, non-MP3 files that aren’t matched using scan and match will not be uploaded. - transcode_quality – if int, pass to ffmpeg/avconv
-q:a
for libmp3lame (lower-better int,). If string, pass to ffmpeg/avconv-b:a
(eg'128k'
for an average bitrate of 128k). The default is 320kbps cbr (the highest possible quality).
All Google-supported filetypes are supported; see Google’s documentation.
If
PERMANENT_ERROR
is given as a not_uploaded reason, attempts to reupload will never succeed. The file will need to be changed before the server will reconsider it; the easiest way is to change metadata tags (it’s not important that the tag be uploaded, just that the contents of the file change somehow).
Downloading Songs¶
-
Musicmanager.
get_uploaded_songs
(incremental=False)¶ Returns a list of dictionaries, each with the following keys:
('id', 'title', 'album', 'album_artist', 'artist', 'track_number', 'track_size', 'disc_number', 'total_disc_count')
.All Access tracks that were added to the library will not be included, only tracks uploaded/matched by the user.
Parameters: incremental – if True, return a generator that yields lists of at most 1000 dictionaries as they are retrieved from the server. This can be useful for presenting a loading bar to a user.
-
Musicmanager.
get_purchased_songs
(incremental=False)¶ Returns a list of dictionaries, each with the following keys:
('id', 'title', 'album', 'album_artist', 'artist', 'track_number', 'track_size', 'disc_number', 'total_disc_count')
.Parameters: incremental – if True, return a generator that yields lists of at most 1000 dictionaries as they are retrieved from the server. This can be useful for presenting a loading bar to a user.
-
Musicmanager.
download_song
(song_id)¶ Download an uploaded or purchased song from your library.
Subscription tracks can’t be downloaded with this method.
Returns a tuple
(u'suggested_filename', 'audio_bytestring')
. The filename will be what the Music Manager would save the file as, presented as a unicode string with the proper file extension. You don’t have to use it if you don’t want.Parameters: song_id – a single uploaded or purchased song id. To write the song to disk, use something like:
filename, audio = mm.download_song(an_id) # if open() throws a UnicodeEncodeError, either use # filename.encode('utf-8') # or change your default encoding to something sane =) with open(filename, 'wb') as f: f.write(audio)
Unlike with
Webclient.get_song_download_info
, there is no download limit when using this interface.Also unlike the Webclient, downloading a track requires authentication. Returning a url does not suffice, since retrieving a track without auth will produce an http 500.
Misc¶
..automethod:: Musicmanager.get_quota