Forked from martarodriguezm/Google Play Api - Apk Upload.md
Last active
June 6, 2025 18:28
-
-
Save machinekoder/6ab0c25c8afae600e2ecd24282aed4bc to your computer and use it in GitHub Desktop.
This python script uploads an apk file into Google Play Store using Android Play Publisher API
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| #!/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() |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| 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. | |
| Script execution: | |
| python basic_upload_apks_service_account.py your.package.name apk-file.apk |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment