Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1289)

Unified Diff: chrome/browser/resources/chromeos/chromevox/tools/chromevox_webstore_util.py

Issue 927543003: Add a flag to ChromeVox upload script for direct publish without interactive mode. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address comments. Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/browser/resources/chromeos/chromevox/tools/upload_chromevox_to_webstore.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/resources/chromeos/chromevox/tools/chromevox_webstore_util.py
diff --git a/chrome/browser/resources/chromeos/chromevox/tools/chromevox_webstore_util.py b/chrome/browser/resources/chromeos/chromevox/tools/chromevox_webstore_util.py
index 5aa96f707d8e43b9c7bb6a21f045334c4a72a878..f2ded5d093b3ef7e7658226156fb7faadaad16aa 100755
--- a/chrome/browser/resources/chromeos/chromevox/tools/chromevox_webstore_util.py
+++ b/chrome/browser/resources/chromeos/chromevox/tools/chromevox_webstore_util.py
@@ -24,7 +24,10 @@ PROJECT_ARGS = {
'redirect_uri': 'http://localhost:8000'
}
+# Globals.
PORT = 8000
+g_auth_code = None
+g_oauth_token = None
APP_ID = 'kgejglhpjiefppelpmljglcjbhoiplfn'
OAUTH_DOMAIN = 'accounts.google.com'
@@ -45,6 +48,10 @@ class CodeRequestHandler(SocketServer.StreamRequestHandler):
self.rfile.close()
def GetAuthCode():
+ global g_auth_code
+ if g_auth_code:
+ return g_auth_code
+
Handler = CodeRequestHandler
httpd = SocketServer.TCPServer(("", PORT), Handler)
query = '&'.join(['response_type=code',
@@ -56,9 +63,14 @@ def GetAuthCode():
webbrowser.open(auth_url)
httpd.handle_request()
httpd.server_close()
- return httpd.code
+ g_auth_code = httpd.code
+ return g_auth_code
def GetOauthToken(code, client_secret):
+ global g_oauth_token
+ if g_oauth_token:
+ return g_oauth_token
+
PROJECT_ARGS['code'] = code
PROJECT_ARGS['client_secret'] = client_secret
body = urllib.urlencode(PROJECT_ARGS)
@@ -69,11 +81,14 @@ def GetOauthToken(code, client_secret):
conn.endheaders()
conn.send(body)
content = conn.getresponse().read()
- return json.loads(content)
+ conn.close()
+ g_oauth_token = json.loads(content)
+ return g_oauth_token
def GetPopulatedHeader(client_secret):
code = GetAuthCode()
access_token = GetOauthToken(code, client_secret)
+
url = 'www.googleapis.com'
return {'Authorization': 'Bearer %(access_token)s' % access_token,
@@ -85,14 +100,18 @@ def SendGetCommand(command, client_secret):
headers = GetPopulatedHeader(client_secret)
conn = httplib.HTTPSConnection(API_ENDPOINT_DOMAIN)
conn.request('GET', command, '', headers)
- return conn.getresponse()
+ r = conn.getresponse()
+ conn.close()
+ return r
def SendPostCommand(command, client_secret, header_additions = {}, body=None):
headers = GetPopulatedHeader(client_secret)
headers = dict(headers.items() + header_additions.items())
conn = httplib.HTTPSConnection(API_ENDPOINT_DOMAIN)
conn.request('POST', command, body, headers)
- return conn.getresponse()
+ r = conn.getresponse()
+ conn.close()
+ return r
def GetUploadStatus(client_secret):
'''Gets the status of a previous upload.
« no previous file with comments | « no previous file | chrome/browser/resources/chromeos/chromevox/tools/upload_chromevox_to_webstore.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698