Skip to content
This repository has been archived by the owner on Oct 3, 2020. It is now read-only.

Google Music Manager Uploader module / Easily upload MP3 (folder) to Google Music

License

Notifications You must be signed in to change notification settings

jaymoulin/google-music-manager-uploader

Repository files navigation

logo

Google Music Manager - Uploader

latest release PyPI version PayPal donation Buy me a coffee Become a Patron

(This product is available under a free and permissive license, but needs financial support to sustain its continued improvements. In addition to maintenance and stability there are many desirable features yet to be added.)

This program will replace former Google MusicManager to upload your music library to Google Music

This work is based upon Simon Weber's Google Music API.

Installation

Avconv is needed to convert some of your files due to Google's MP3 constraint also, this program needs watchdog, gmusicapi, netifaces, requests and bs4 Python libraries to work.

apt-get install python3-pip libav-tools build-essential
pip3 install google-music-manager-uploader

Once installed, You have to authenticate to Google Music via the google-music-auth command

# Usage google-music-auth [path_to_oauth_cred_file=~/oauth]

If first parameter is not defined, the script will try to store/load your oauth credentials through the ~/oauth file.

Then follow prompted instructions.

You will be asked to go to a Google URL to allow the connection:

Visit the following url:
    https://accounts.google.com/o/oauth2/v2/auth?client_id=XXXXXXXXXXX.apps.googleusercontent.com&access_type=offline&scope=https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fmusicmanager&response_type=code&redirect_uri=urn%3Aietf%3Awg%3Aoauth%3A2.0%3Aoob
Follow the prompts, then paste the auth code here and hit enter:

Usage

Uploader

This program will scan a given directory for new elements to upload them to Google Music. First, launch the daemon to watch a directory new inputs.

It will NOT upload already existing files, ONLY new files while the daemon is running. (Please contribute if you want this to change)

usage: google-music-upload [-h] [--directory DIRECTORY] [--oauth OAUTH] [-r]
                          [--uploader_id UPLOADER_ID] [-o] [--deduplicate_api DEDUPLICATE_API]

optional arguments:
  -h, --help            show this help message and exit
  --directory DIRECTORY, -d DIRECTORY
                        Music Folder to upload from (default: .)
  --oauth OAUTH, -a OAUTH
                        Path to oauth file (default: ~/oauth)
  -r, --remove          Remove the file on your hard drive if it was already successfully uploaded (default: False)
  --uploader_id UPLOADER_ID, -u UPLOADER_ID
                        Uploader identification (should be an uppercase MAC
                        address) (default: <current eth0 MAC address>)
  -o, --oneshot         Upload folder and exit (default: False)
  -w DEDUPLICATE_API, --deduplicate_api DEDUPLICATE_API
                        Deduplicate API (should be HTTP and compatible with
                        the manifest (see README)) (default: None)

Deduplicate

This program will send all files or the specified file to the deduplication API

usage: google-music-upload-deduplicate [-h] --deduplicate_api DEDUPLICATE_API
                                   [--directory DIRECTORY] [--file FILE]
                                   [--remove]

optional arguments:
  -h, --help            show this help message and exit
  --directory DIRECTORY, -d DIRECTORY
                        Music Folder to deduplicate
  --file FILE, -f FILE
                        Music file path to deduplicate
  -r, --remove          Unmark specified file/folder (default: False)
  -w DEDUPLICATE_API, --deduplicate_api DEDUPLICATE_API
                        Deduplicate API (should be HTTP and compatible with
                        the manifest (see README)) (default: None)

Deduplication API

Preface

This API is completely optional. You don't have to implement this. It will only help you to avoid useless Google calls

You can use your own API implementation to avoid sampling + Google upload. This API should match with the following requirements.

You may want to use this existing one : Google MusicManager Deduplicate API.

Exists

path method parameter status code
/ GET name description value description
path path of your file 200 or 204 Your file was already uploaded
404 (or whatever) Your file was NOT uploaded

Saving

path method parameter status code
/ POST name description value description
path path of your file whatever Status code does not change anything

Removing

path method parameter status code
/ DELETE name description value description
path path of your file whatever Status code does not change anything

About

Requirements

Google Music Uploader works with Python 3 or above. It requires Simon Weber's Google Music API and Watchdog.

Submitting bugs and feature requests

Bugs and feature request are tracked on GitHub

Author

Jay MOULIN jay@femtopixel.com See also the list of contributors which participated in this program.

License

Google Music Uploader is licensed under the MIT License