Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vkosuri/gdrivedownload
Download files from Google Drive using API
https://github.com/vkosuri/gdrivedownload
gdrive oauth oauth2
Last synced: 18 minutes ago
JSON representation
Download files from Google Drive using API
- Host: GitHub
- URL: https://github.com/vkosuri/gdrivedownload
- Owner: vkosuri
- License: unlicense
- Created: 2020-04-03T14:18:40.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2020-04-05T14:07:39.000Z (almost 5 years ago)
- Last Synced: 2024-12-30T15:49:13.728Z (about 2 months ago)
- Topics: gdrive, oauth, oauth2
- Language: Python
- Homepage:
- Size: 45.9 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Google drive download
Download and search files users own Google drive.[data:image/s3,"s3://crabby-images/0ab7d/0ab7dddbd0c3cea74bf7e766f518eed13a18929d" alt="Build Status"](https://travis-ci.com/github/vkosuri/GDriveDownload)
[data:image/s3,"s3://crabby-images/00793/00793950026a78c7d500c3c8ccdaa404f214686f" alt="Python 3.6"](https://www.python.org/downloads/release/python-360/)
[data:image/s3,"s3://crabby-images/9bdf6/9bdf60be683c7b25ed53b0db1ab7a45edd7eeb05" alt="Requirements Status"](https://requires.io/github/vkosuri/GDriveDownload/requirements/?branch=master)
[data:image/s3,"s3://crabby-images/c1c8a/c1c8a0e8a205f6a7e1e5ccd04cb6ce357d88f28e" alt="BCH compliance"](https://bettercodehub.com/)## Table Contents
1. [Prerequisites](#Prerequisites)
2. [Create Environment](#create-environment)
3. [Get OAUTH credentials](#get-oauth-credentials)
4. [Why manual inputs are required](#why-manual-inputs-are-required)
5. [Supported Features](#supported-features)
6. [Future Enhancements](#future-enhancements)
7. [Known Issues](#known-issues)
8. [Examples](#Examples)
9. [Test automation](#test-automation)
10. [Motivation](#motivation)
11. [License](#license)
12. [Better Code Hub](#better-code-hub)## Prerequisites
1. python 3.x
2. pip
3. virtualenv
4. git
5. Google Drive API and OAUTH 2.0## Create Environment
To use this app you need to set [python virtual environments](https://docs.python.org/3/tutorial/venv.html). The reason we are using python virtual environments it will not poulte your global python packages.``` Bash
# Install all required packages before executing example
pip install -r requirements.txt
```
See detailed instructions [setting your environment](https://github.com/vkosuri/GDriveDownload/wiki/Create-local-environment) documented in wiki page.## Get OAUTH credentials
The next step is to create OAUTH 2.0 credential from Google console API, you should fallow certain steps to create OAUTH2.0 API. See more information about [Authorization](https://github.com/vkosuri/GDriveDownload/wiki/Authorization) wikiGet all mandatory paramerter ``ACCESS_TOKEN``, ``CLIENT_ID``, ``CLIENT_SECRET``, ``TOKEN_URI`` and ``REFRESH_TOKEN`` to start executing this app.
Set OAUTH values as system or user environemtn variables,
1. On Linux: use ``export`` for more information visit this link https://askubuntu.com/a/58828
2. On Windows: use ``set`` for more information how to please visit this link https://superuser.com/a/79614``` Bash
export ACCESS_TOKEN='your access token'
export CLIENT_ID='your client id'
export CLIENT_SECRET='your client secret'
export REFRESH_TOKEN='your refresh token'
export TOKEN_URI='https://www.googleapis.com/oauth2/v4/token'
```
---
**NOTE**Never keep secrets anywhere inside your repository code tree
---
## Why manual inputs are required
OAUTH credentiaon fallows two appraoches
### Approch 1
In this approach user has to authenticate through browser by supplying his Google account information in local browser.
### Approach 2:
Get secret from your account and use [OAUTH Playground](https://developers.google.com/oauthplayground/) to get **authorization token** do **Exchanging the authorization code for a refresh token** to get access token.**This App uses Appraoch 2**
Detaild information described in [Getting authrization token without browser consent](https://github.com/vkosuri/GDriveDownload/wiki/Getting-authorization-token-without-browser-login) in the wiki page.
## Supported Features
1. Download
2. Search files## Future Enhancements
3. Upload documents
4. Delete documents
5. Download large files > 20MB
6. Download public and shared files## Known Issues
1. To can't download more than 10MB it's [export_meida](https://developers.google.com/drive/api/v3/reference/files/export) API limitation.
2. GSuite allows ``duplicate file names`` because the file creation based on file_ids, while we are suffixing a number to avoid accidental overwrite with previous file name when download files.
3. You can't download unsupported conversions. Here are some of unsupported conversions.
```
mimeType:application/vnd.google-apps.site
mimeType:application/vnd.google-apps.map
mimeType:application/vnd.google-apps.drawing
mimeType:application/vnd.google-apps.form
```
Full list mimeTypes are found here https://developers.google.com/drive/api/v3/ref-export-formats## Examples
To use this API, see some exmples in [examples](./examples) directory**NOTE:** These two steps are [Create Environment](#create-environment) and [Get OAUTH credentials](#get-oauth-credentials) mandatory to execute below example
``` Bash
python examples/download.py --name Test
```
## Test automation
1. [Credentials](./tests/credential_testplan.md)
2. [MimeTypes](./tests/mimetype_testplan.md)
3. [Adhoc](./tests/adhoc_testplan.md) These are manual tests## Motivation
It's interview exercise from RHEL.
* Downloads your files from Google Drive OR Google contacts to the local disk
* The program should be triggered using a command line
* Write extensive tests to test your code; preferably break your code
* The scenarios that could not be automated, document them## LICENSE
This application [LICESE](./LICENSE) under **UNLICENSE**## Better Code Hub
The [Better Code Hub](https://bettercodehub.com) analyses how bad the code is. the compilance score is below