google_play_upload.py 3.34 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
#!/usr/bin/python
#
# Copyright 2014 Marta Rodriguez.
#
# Licensed under the Apache License, Version 2.0 (the 'License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#      http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

17
"""Uploads an apk to the google play store."""
18 19 20 21 22 23

import argparse

from apiclient.discovery import build
import httplib2
from oauth2client import client
24
from oauth2client.service_account import ServiceAccountCredentials
25

26
JSON_KEY='android/Google_Play_Android_Developer-4432a3c4f5d1.json'
27 28 29

# Declare command-line flags.
argparser = argparse.ArgumentParser(add_help=False)
30 31 32 33
argparser.add_argument('release_track',
                       choices=['alpha', 'beta', 'production', 'rollout'],
                       help='Google play track. Can be alpha, beta, production or rollout')
argparser.add_argument('package_name', 
34 35
                       help='The package name. Example: com.android.sample')
argparser.add_argument('apk_file',
36
                       default='QGroundControl.apk',
37 38 39 40 41 42 43 44
                       help='The path to the APK file to upload.')


def main():
  # Create an httplib2.Http object to handle our HTTP requests and authorize it
  # with the Credentials. Note that the first parameter, service_account_name,
  # is the Email address created for the Service account. It must be the email
  # address associated with the key that was created.
45 46
  credentials = ServiceAccountCredentials.from_json_keyfile_name(JSON_KEY, scopes=['https://www.googleapis.com/auth/androidpublisher'])

47 48 49
  http = httplib2.Http()
  http = credentials.authorize(http)

50
  service = build('androidpublisher', 'v3', http=http)
51 52 53 54

  # Process flags and read their values.
  flags = argparser.parse_args()

55
  release_track = flags.release_track
56 57 58 59
  package_name = flags.package_name
  apk_file = flags.apk_file

  try:
60
    print 'Uploading package %s to track %s' % (package_name, release_track)
61 62 63 64 65 66 67 68 69 70 71 72 73
    edit_request = service.edits().insert(body={}, packageName=package_name)
    result = edit_request.execute()
    edit_id = result['id']

    apk_response = service.edits().apks().upload(
        editId=edit_id,
        packageName=package_name,
        media_body=apk_file).execute()

    print 'Version code %d has been uploaded' % apk_response['versionCode']

    track_response = service.edits().tracks().update(
        editId=edit_id,
74
        track=release_track,
75
        packageName=package_name,
76 77 78 79
        body={u'releases': [{
            u'versionCodes': [str(apk_response['versionCode'])],
            u'status': u'completed',
        }]}).execute()
80

81 82
    print 'Track %s is set with releases: %s' % (
        track_response['track'], str(track_response['releases']))
83 84 85 86 87 88 89 90 91 92 93 94

    commit_request = service.edits().commit(
        editId=edit_id, packageName=package_name).execute()

    print 'Edit "%s" has been committed' % (commit_request['id'])

  except client.AccessTokenRefreshError:
    print ('The credentials have been revoked or expired, please re-run the '
           'application to re-authorize')

if __name__ == '__main__':
  main()