Index: sitescripts/oauth2dl/bin/oauth2dl.py |
diff --git a/sitescripts/oauth2dl/bin/oauth2dl.py b/sitescripts/oauth2dl/bin/oauth2dl.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..7925ee7ef629c70e500d6237c0de11506ae51647 |
--- /dev/null |
+++ b/sitescripts/oauth2dl/bin/oauth2dl.py |
@@ -0,0 +1,123 @@ |
+# This file is part of the Adblock Plus web scripts, |
+# Copyright (C) 2006-present eyeo GmbH |
+# |
+# Adblock Plus is free software: you can redistribute it and/or modify |
+# it under the terms of the GNU General Public License version 3 as |
+# published by the Free Software Foundation. |
+# |
+# Adblock Plus is distributed in the hope that it will be useful, |
+# but WITHOUT ANY WARRANTY; without even the implied warranty of |
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
+# GNU General Public License for more details. |
+# |
+# You should have received a copy of the GNU General Public License |
+# along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
+ |
+ |
+import argparse |
Vasily Kuznetsov
2018/07/20 21:00:01
PEP8 recommends breaking the imports into three gr
Tudor Avram
2018/07/23 19:29:03
Acknowledged.
Tudor Avram
2018/07/31 09:20:16
Done.
|
+import codecs |
+import os |
+import sys |
+from httplib2 import Http |
+from oauth2client.service_account import ServiceAccountCredentials |
+import json |
+ |
+try: |
Vasily Kuznetsov
2018/07/20 21:00:00
I think we can assume that the root of sitescripts
Tudor Avram
2018/07/23 19:29:03
That was to allow it to run both as `python -m ...
Tudor Avram
2018/07/31 09:20:17
Done.
|
+ from sitescripts.oauth2dl.bin import constants as cnts |
+except ImportError: |
+ import constants as cnts |
+ |
+ |
+def write_to_file(content, path): |
Vasily Kuznetsov
2018/07/20 21:00:00
I'm not sure if it really makes sense to have this
Tudor Avram
2018/07/23 19:29:03
Acknowledged.
Tudor Avram
2018/07/31 09:20:16
Done.
|
+ """Write data to file. |
+ |
+ Parameters |
+ ---------- |
+ content: str |
+ The data to write. |
+ path: str |
+ Path to the file we write to. |
+ """ |
+ with codecs.open(path, encoding='utf-8', mode='wb') as f: |
+ f.write(content) |
+ |
+ |
+def download_file(url, key_file, scope): |
+ """Download a file using Oauth2. |
+ |
+ Parameters |
+ ---------- |
+ url: str |
+ The url of the file we want to download |
+ key_file: str |
+ Path/ url to key file used in Oauth2 |
+ scope: str |
+ The scope used in Oauth2 |
+ |
+ Returns |
+ ------- |
+ dict |
+ Headers resulted from the HTTP request. |
+ str |
+ The content of the file we want to download/ |
+ error message if it was unsuccessful. |
+ """ |
+ credentials = ServiceAccountCredentials.from_json_keyfile_name(key_file, scopes=[scope]) |
Vasily Kuznetsov
2018/07/20 21:00:00
PEP8 recommends keeping the lines under 80 charact
Tudor Avram
2018/07/23 19:29:03
Yeah, I know. that's why I added the flake8 except
Tudor Avram
2018/07/31 09:20:16
Done.
|
+ |
+ http_auth = credentials.authorize(Http()) |
+ |
+ headers, content = http_auth.request(url) |
+ try: |
+ content = content.decode('utf-8') |
+ finally: |
+ return headers, content |
+ |
+ |
+def parse_args(): |
+ """Set up the required arguments and returns them.""" |
+ parser = argparse.ArgumentParser(description='Download using Oauth2') |
+ |
+ parser.add_argument('url', help='URL to download from') |
+ parser.add_argument('-k', '--key', help='Oauth2 key file path', |
+ default=os.environ.get('OAUTH2DL_KEY')) |
+ parser.add_argument('-s', '--scope', help='Oauth2 scope', |
+ default=os.environ.get('OAUTH2DL_SCOPE')) |
+ parser.add_argument('-o', help='Path where to save the file.') |
+ |
+ return parser.parse_args() |
+ |
+ |
+def main(): |
+ args = parse_args() |
+ |
+ if args.key is None: |
+ sys.exit(cnts.KEYFILE_NOT_FOUND_ERROR) |
+ |
+ if args.scope is None: |
+ sys.exit(cnts.SCOPE_NOT_FOUND_ERROR) |
+ |
+ try: |
+ headers, content = download_file(args.url, args.key, args.scope) |
+ except KeyError as err: |
+ sys.exit(cnts.INVALID_KEY_FILE.format(str(err), str(args.key))) |
+ except Exception as err: |
+ sys.exit(err) |
+ |
+ if headers['status'] != '200': |
+ try: |
+ error_json = json.loads(content, encoding='utf-8') |
+ sys.exit(cnts.GOOGLE_OAUTH_ERROR.format( |
+ str(error_json['error']['code']), |
+ str(error_json['error']['message']), |
+ )) |
+ except ValueError: |
+ sys.exit(content) |
+ |
+ if args.o is None: |
+ sys.stdout.write(content) |
+ else: |
+ write_to_file(content, args.o) |
+ |
+ |
+if __name__ == '__main__': |
+ main() |