Skip to content

Instantly share code, notes, and snippets.

@mix3d
Forked from lpetre/Google Play Api - Apk Upload.md
Last active October 18, 2021 12:12
Show Gist options
  • Select an option

  • Save mix3d/665f4ab329b4482297a2f425ebba402c to your computer and use it in GitHub Desktop.

Select an option

Save mix3d/665f4ab329b4482297a2f425ebba402c to your computer and use it in GitHub Desktop.

Revisions

  1. mix3d revised this gist Mar 31, 2016. 1 changed file with 2 additions and 2 deletions.
    4 changes: 2 additions & 2 deletions Google Play Api - Apk Upload.md
    Original file line number Diff line number Diff line change
    @@ -8,12 +8,12 @@ On Google Play Developer Console you have to give permissions to "YOUR_SERVICE_A

    Download Google APIs Client Library for Python (google-api-python-client): https://code.google.com/p/google-api-python-client/ or use pip:
    ```bash
    $ pip install google-api-python-client
    $ pip install google-api-python-client
    ```

    ## Execution
    ```bash
    python basic_upload_apks_service_account.py -p your.package.name -a apk-file.apk -s service_account.json
    python basic_upload_apks_service_account.py -p your.package.name -a apk-file.apk -s service_account.json
    ```

    Based on https://github.com/googlesamples/android-play-publisher-api/tree/master/v2/python and https://developers.google.com/api-client-library/python/start/get_started#installed
  2. mix3d revised this gist Mar 31, 2016. 1 changed file with 2 additions and 2 deletions.
    4 changes: 2 additions & 2 deletions Google Play Api - Apk Upload.md
    Original file line number Diff line number Diff line change
    @@ -8,12 +8,12 @@ On Google Play Developer Console you have to give permissions to "YOUR_SERVICE_A

    Download Google APIs Client Library for Python (google-api-python-client): https://code.google.com/p/google-api-python-client/ or use pip:
    ```bash
    $ pip install google-api-python-client
    $ pip install google-api-python-client
    ```

    ## Execution
    ```bash
    python basic_upload_apks_service_account.py -p your.package.name -a apk-file.apk -s service_account.json
    python basic_upload_apks_service_account.py -p your.package.name -a apk-file.apk -s service_account.json
    ```

    Based on https://github.com/googlesamples/android-play-publisher-api/tree/master/v2/python and https://developers.google.com/api-client-library/python/start/get_started#installed
  3. mix3d revised this gist Mar 31, 2016. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion basic_upload_apks_service_account.py
    Original file line number Diff line number Diff line change
    @@ -77,7 +77,7 @@ def main():
    parser.add_argument('-p', '--package', required=True, help='The package name. Example: com.android.sample')
    parser.add_argument('-s', '--service', required=True, help='The service account json file.')
    parser.add_argument('-a', '--apk', required=True, help='The path to the APK file to upload.')
    parser.add_argument('-t', '--track', default='alpha')
    parser.add_argument('-t', '--track', choices=['alpha', 'beta', 'production','rollout'], default='alpha')
    args = parser.parse_args()

    upload(args.package, args.service, args.apk, args.track)
  4. mix3d revised this gist Mar 31, 2016. 1 changed file with 3 additions and 0 deletions.
    3 changes: 3 additions & 0 deletions basic_upload_apks_service_account.py
    Original file line number Diff line number Diff line change
    @@ -17,7 +17,10 @@
    """Uploads an apk to the alpha track."""

    import sys
    #required on OSX to prevent the default 'six' library from interfering with the needed newer package,
    #as of the 1.4.1 google-api library
    sys.path.insert(1, '/Library/Python/2.7/site-packages')

    import argparse
    import httplib2
    import json
  5. mix3d revised this gist Mar 31, 2016. 1 changed file with 14 additions and 78 deletions.
    92 changes: 14 additions & 78 deletions Google Play Api - Apk Upload.md
    Original file line number Diff line number Diff line change
    @@ -1,83 +1,19 @@
    #!/usr/bin/env 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.
    **Updated to match latest changes to API**

    """Uploads an apk to the alpha track."""
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the JSON file.

    import sys
    sys.path.insert(1, '/Library/Python/2.7/site-packages')
    import argparse
    import httplib2
    import json
    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.

    from oauth2client.service_account import ServiceAccountCredentials
    from oauth2client.client import AccessTokenRefreshError
    from apiclient.discovery import build
    ## Installation

    def upload(package, service, apk, track):
    Download Google APIs Client Library for Python (google-api-python-client): https://code.google.com/p/google-api-python-client/ or use pip:
    ```bash
    $ pip install google-api-python-client
    ```

    # 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.
    credentials = ServiceAccountCredentials.from_json_keyfile_name(
    service, ['https://www.googleapis.com/auth/androidpublisher'])

    http_auth = credentials.authorize(http=httplib2.Http())
    service = build('androidpublisher', 'v2', http=http_auth)

    try:
    edit_request = service.edits().insert(body={}, packageName=package)
    result = edit_request.execute()
    edit_id = result['id']

    apk_response = service.edits().apks().upload(
    editId=edit_id,
    packageName=package,
    media_body=apk).execute()

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

    track_response = service.edits().tracks().update(
    editId=edit_id,
    track=track,
    packageName=package,
    body={u'versionCodes': [apk_response['versionCode']]}).execute()

    print 'Track %s is set for version code(s) %s' % (
    track_response['track'], str(track_response['versionCodes']))

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

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

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

    def main():
    parser = argparse.ArgumentParser()
    parser.add_argument('-p', '--package', required=True, help='The package name. Example: com.android.sample')
    parser.add_argument('-s', '--service', required=True, help='The service account json file.')
    parser.add_argument('-a', '--apk', required=True, help='The path to the APK file to upload.')
    parser.add_argument('-t', '--track', default='alpha')
    args = parser.parse_args()

    upload(args.package, args.service, args.apk, args.track)

    if __name__ == "__main__":
    main()
    ## Execution
    ```bash
    python basic_upload_apks_service_account.py -p your.package.name -a apk-file.apk -s service_account.json
    ```

    Based on https://github.com/googlesamples/android-play-publisher-api/tree/master/v2/python and https://developers.google.com/api-client-library/python/start/get_started#installed
  6. mix3d revised this gist Mar 31, 2016. 1 changed file with 12 additions and 16 deletions.
    28 changes: 12 additions & 16 deletions basic_upload_apks_service_account.py
    Original file line number Diff line number Diff line change
    @@ -17,30 +17,26 @@
    """Uploads an apk to the alpha track."""

    import sys
    sys.path.insert(1, '/Library/Python/2.7/site-packages')
    import argparse
    import httplib2
    import json

    from oauth2client.service_account import ServiceAccountCredentials
    from oauth2client.client import AccessTokenRefreshError
    from apiclient.discovery import build
    from oauth2client import client

    def upload(package, service, apk, track):

    # Load the service key and email from the Google Developer Service Account json file
    service_settings = json.load(service)

    # 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.
    credentials = client.SignedJwtAssertionCredentials(
    service_settings['client_email'],
    service_settings['private_key'],
    scope='https://www.googleapis.com/auth/androidpublisher')
    http = httplib2.Http()
    http = credentials.authorize(http)
    credentials = ServiceAccountCredentials.from_json_keyfile_name(
    service, ['https://www.googleapis.com/auth/androidpublisher'])

    service = build('androidpublisher', 'v2', http=http)
    http_auth = credentials.authorize(http=httplib2.Http())
    service = build('androidpublisher', 'v2', http=http_auth)

    try:
    edit_request = service.edits().insert(body={}, packageName=package)
    @@ -50,7 +46,7 @@ def upload(package, service, apk, track):
    apk_response = service.edits().apks().upload(
    editId=edit_id,
    packageName=package,
    media_body=apk.name).execute()
    media_body=apk).execute()

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

    @@ -68,20 +64,20 @@ def upload(package, service, apk, track):

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

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

    def main():
    parser = argparse.ArgumentParser()
    parser.add_argument('-p', '--package', required=True, help='The package name. Example: com.android.sample')
    parser.add_argument('-s', '--service', type=argparse.FileType('r'), required=True, help='The service account json file.')
    parser.add_argument('-a', '--apk', type=argparse.FileType('r'), required=True, help='The path to the APK file to upload.')
    parser.add_argument('-s', '--service', required=True, help='The service account json file.')
    parser.add_argument('-a', '--apk', required=True, help='The path to the APK file to upload.')
    parser.add_argument('-t', '--track', default='alpha')
    args = parser.parse_args()

    upload(args.package, args.service, args.apk, args.track)

    if __name__ == "__main__":
    main()
    main()
  7. mix3d revised this gist Mar 31, 2016. 1 changed file with 79 additions and 13 deletions.
    92 changes: 79 additions & 13 deletions Google Play Api - Apk Upload.md
    Original file line number Diff line number Diff line change
    @@ -1,17 +1,83 @@
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the JSON file.
    #!/usr/bin/env 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.

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.
    """Uploads an apk to the alpha track."""

    ## Installation
    import sys
    sys.path.insert(1, '/Library/Python/2.7/site-packages')
    import argparse
    import httplib2
    import json

    Download Google APIs Client Library for Python (google-api-python-client): https://code.google.com/p/google-api-python-client/ or use pip:
    ```bash
    $ pip install google-api-python-client
    ```
    from oauth2client.service_account import ServiceAccountCredentials
    from oauth2client.client import AccessTokenRefreshError
    from apiclient.discovery import build

    ## Execution
    ```bash
    python basic_upload_apks_service_account.py -p your.package.name -a apk-file.apk -s service_account.json
    ```

    Based on https://github.com/googlesamples/android-play-publisher-api/tree/master/v2/python
    def upload(package, service, apk, track):

    # 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.
    credentials = ServiceAccountCredentials.from_json_keyfile_name(
    service, ['https://www.googleapis.com/auth/androidpublisher'])

    http_auth = credentials.authorize(http=httplib2.Http())
    service = build('androidpublisher', 'v2', http=http_auth)

    try:
    edit_request = service.edits().insert(body={}, packageName=package)
    result = edit_request.execute()
    edit_id = result['id']

    apk_response = service.edits().apks().upload(
    editId=edit_id,
    packageName=package,
    media_body=apk).execute()

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

    track_response = service.edits().tracks().update(
    editId=edit_id,
    track=track,
    packageName=package,
    body={u'versionCodes': [apk_response['versionCode']]}).execute()

    print 'Track %s is set for version code(s) %s' % (
    track_response['track'], str(track_response['versionCodes']))

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

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

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

    def main():
    parser = argparse.ArgumentParser()
    parser.add_argument('-p', '--package', required=True, help='The package name. Example: com.android.sample')
    parser.add_argument('-s', '--service', required=True, help='The service account json file.')
    parser.add_argument('-a', '--apk', required=True, help='The path to the APK file to upload.')
    parser.add_argument('-t', '--track', default='alpha')
    args = parser.parse_args()

    upload(args.package, args.service, args.apk, args.track)

    if __name__ == "__main__":
    main()
  8. @lpetre lpetre revised this gist Aug 5, 2014. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion basic_upload_apks_service_account.py
    Original file line number Diff line number Diff line change
    @@ -64,7 +64,7 @@ def upload(package, service, apk, track):
    track_response['track'], str(track_response['versionCodes']))

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

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

  9. @lpetre lpetre revised this gist Jul 31, 2014. 1 changed file with 2 additions and 3 deletions.
    5 changes: 2 additions & 3 deletions Google Play Api - Apk Upload.md
    Original file line number Diff line number Diff line change
    @@ -1,5 +1,4 @@
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the p12 file.
    You need the service account key file, generated in the Google APIs Console into the same directory and rename it to key.p12.
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the JSON file.

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.

    @@ -12,7 +11,7 @@ Download Google APIs Client Library for Python (google-api-python-client): https

    ## Execution
    ```bash
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
    python basic_upload_apks_service_account.py -p your.package.name -a apk-file.apk -s service_account.json
    ```

    Based on https://github.com/googlesamples/android-play-publisher-api/tree/master/v2/python
  10. @lpetre lpetre revised this gist Jul 31, 2014. 1 changed file with 27 additions and 36 deletions.
    63 changes: 27 additions & 36 deletions basic_upload_apks_service_account.py
    Original file line number Diff line number Diff line change
    @@ -1,4 +1,4 @@
    #!/usr/bin/python
    #!/usr/bin/env python
    #
    # Copyright 2014 Marta Rodriguez.
    #
    @@ -16,68 +16,48 @@

    """Uploads an apk to the alpha track."""

    import sys
    import argparse
    import httplib2
    import json

    from apiclient.discovery import build
    import httplib2
    from oauth2client import client

    TRACK = 'alpha' # Can be 'alpha', beta', 'production' or 'rollout'
    SERVICE_ACCOUNT_EMAIL = (
    'ENTER_YOUR_SERVICE_ACCOUNT_EMAIL_HERE@developer.gserviceaccount.com')

    # Declare command-line flags.
    argparser = argparse.ArgumentParser(add_help=False)
    argparser.add_argument('package_name',
    help='The package name. Example: com.android.sample')
    argparser.add_argument('apk_file',
    nargs='?',
    default='test.apk',
    help='The path to the APK file to upload.')
    def upload(package, service, apk, track):


    def main():
    # Load the key in PKCS 12 format that you downloaded from the Google APIs
    # Console when you created your Service account.
    f = file('key.p12', 'rb')
    key = f.read()
    f.close()
    # Load the service key and email from the Google Developer Service Account json file
    service_settings = json.load(service)

    # 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.
    credentials = client.SignedJwtAssertionCredentials(
    SERVICE_ACCOUNT_EMAIL,
    key,
    service_settings['client_email'],
    service_settings['private_key'],
    scope='https://www.googleapis.com/auth/androidpublisher')
    http = httplib2.Http()
    http = credentials.authorize(http)

    service = build('androidpublisher', 'v2', http=http)

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

    package_name = flags.package_name
    apk_file = flags.apk_file

    try:
    edit_request = service.edits().insert(body={}, packageName=package_name)
    edit_request = service.edits().insert(body={}, packageName=package)
    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()
    packageName=package,
    media_body=apk.name).execute()

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

    track_response = service.edits().tracks().update(
    editId=edit_id,
    track=TRACK,
    packageName=package_name,
    track=track,
    packageName=package,
    body={u'versionCodes': [apk_response['versionCode']]}).execute()

    print 'Track %s is set for version code(s) %s' % (
    @@ -88,9 +68,20 @@ def main():

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

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

    def main():
    parser = argparse.ArgumentParser()
    parser.add_argument('-p', '--package', required=True, help='The package name. Example: com.android.sample')
    parser.add_argument('-s', '--service', type=argparse.FileType('r'), required=True, help='The service account json file.')
    parser.add_argument('-a', '--apk', type=argparse.FileType('r'), required=True, help='The path to the APK file to upload.')
    parser.add_argument('-t', '--track', default='alpha')
    args = parser.parse_args()

    upload(args.package, args.service, args.apk, args.track)

    if __name__ == '__main__':
    if __name__ == "__main__":
    main()
  11. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 1 changed file with 4 additions and 1 deletion.
    5 changes: 4 additions & 1 deletion Google Play Api - Apk Upload.md
    Original file line number Diff line number Diff line change
    @@ -1,4 +1,5 @@
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the p12 file.
    You need the service account key file, generated in the Google APIs Console into the same directory and rename it to key.p12.

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.

    @@ -12,4 +13,6 @@ Download Google APIs Client Library for Python (google-api-python-client): https
    ## Execution
    ```bash
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
    ```
    ```

    Based on https://github.com/googlesamples/android-play-publisher-api/tree/master/v2/python
  12. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 2 changed files with 0 additions and 15 deletions.
    15 changes: 0 additions & 15 deletions gistfile1.md
    Original file line number Diff line number Diff line change
    @@ -1,15 +0,0 @@
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the p12 file.

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.

    ## Installation

    Download Google APIs Client Library for Python (google-api-python-client): https://code.google.com/p/google-api-python-client/ or use pip:
    ```bash
    $ pip install google-api-python-client
    ```

    ## Execution
    ```bash
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
    ```
  13. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 1 changed file with 15 additions and 0 deletions.
    15 changes: 15 additions & 0 deletions gistfile1.md
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,15 @@
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the p12 file.

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.

    ## Installation

    Download Google APIs Client Library for Python (google-api-python-client): https://code.google.com/p/google-api-python-client/ or use pip:
    ```bash
    $ pip install google-api-python-client
    ```

    ## Execution
    ```bash
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
    ```
  14. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 1 changed file with 11 additions and 2 deletions.
    13 changes: 11 additions & 2 deletions Google Play Api - Apk Upload
    Original file line number Diff line number Diff line change
    @@ -2,5 +2,14 @@ In Google Developer Console inside your app project, on the Credentials section,

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.

    Script execution:
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
    ## Installation

    Download Google APIs Client Library for Python (google-api-python-client): https://code.google.com/p/google-api-python-client/ or use pip:
    ```bash
    $ pip install google-api-python-client
    ```

    ## Execution
    ```bash
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
    ```
  15. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 2 changed files with 4 additions and 2 deletions.
    1 change: 0 additions & 1 deletion Command Line
    Original file line number Diff line number Diff line change
    @@ -1 +0,0 @@
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
    5 changes: 4 additions & 1 deletion Instructions → Google Play Api - Apk Upload
    Original file line number Diff line number Diff line change
    @@ -1,3 +1,6 @@
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the p12 file.

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.
    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.

    Script execution:
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
  16. @martarodriguezm martarodriguezm renamed this gist Jul 31, 2014. 1 changed file with 0 additions and 0 deletions.
    File renamed without changes.
  17. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 1 changed file with 3 additions and 0 deletions.
    3 changes: 3 additions & 0 deletions gistfile1.txt
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,3 @@
    In Google Developer Console inside your app project, on the Credentials section, you must create a new "Service Account" "Client ID", if you have not already. And download the p12 file.

    On Google Play Developer Console you have to give permissions to "[email protected]" for uploading apks.
  18. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion Command Line
    Original file line number Diff line number Diff line change
    @@ -1 +1 @@
    python basic_upload_apks.py your.package.name apk-file.apk
    python basic_upload_apks_service_account.py your.package.name apk-file.apk
  19. @martarodriguezm martarodriguezm revised this gist Jul 31, 2014. 1 changed file with 1 addition and 0 deletions.
    1 change: 1 addition & 0 deletions Command Line
    Original file line number Diff line number Diff line change
    @@ -0,0 +1 @@
    python basic_upload_apks.py your.package.name apk-file.apk
  20. @martarodriguezm martarodriguezm created this gist Jul 31, 2014.
    96 changes: 96 additions & 0 deletions basic_upload_apks_service_account.py
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,96 @@
    #!/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.

    """Uploads an apk to the alpha track."""

    import argparse

    from apiclient.discovery import build
    import httplib2
    from oauth2client import client

    TRACK = 'alpha' # Can be 'alpha', beta', 'production' or 'rollout'
    SERVICE_ACCOUNT_EMAIL = (
    'ENTER_YOUR_SERVICE_ACCOUNT_EMAIL_HERE@developer.gserviceaccount.com')

    # Declare command-line flags.
    argparser = argparse.ArgumentParser(add_help=False)
    argparser.add_argument('package_name',
    help='The package name. Example: com.android.sample')
    argparser.add_argument('apk_file',
    nargs='?',
    default='test.apk',
    help='The path to the APK file to upload.')


    def main():
    # Load the key in PKCS 12 format that you downloaded from the Google APIs
    # Console when you created your Service account.
    f = file('key.p12', 'rb')
    key = f.read()
    f.close()

    # 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.
    credentials = client.SignedJwtAssertionCredentials(
    SERVICE_ACCOUNT_EMAIL,
    key,
    scope='https://www.googleapis.com/auth/androidpublisher')
    http = httplib2.Http()
    http = credentials.authorize(http)

    service = build('androidpublisher', 'v2', http=http)

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

    package_name = flags.package_name
    apk_file = flags.apk_file

    try:
    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,
    track=TRACK,
    packageName=package_name,
    body={u'versionCodes': [apk_response['versionCode']]}).execute()

    print 'Track %s is set for version code(s) %s' % (
    track_response['track'], str(track_response['versionCodes']))

    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()