Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dreikanter/dbarc
Dropbox incremental archiver for Raspberry Pi
https://github.com/dreikanter/dbarc
Last synced: 9 days ago
JSON representation
Dropbox incremental archiver for Raspberry Pi
- Host: GitHub
- URL: https://github.com/dreikanter/dbarc
- Owner: dreikanter
- License: mit
- Created: 2013-09-17T11:49:41.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2013-09-25T13:20:06.000Z (over 11 years ago)
- Last Synced: 2024-11-15T06:42:41.127Z (2 months ago)
- Language: Python
- Size: 114 KB
- Stars: 2
- Watchers: 3
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Dropbox Archiver
This is a script to create incremental local copies for Dropbox contents. It does not require Dropbox client to be installed, and runs almost anywhere including Raspberry Pi.
## Getting Started
Ensure Python 3.3, git and pip are up and running, and execute the following command to install the package from GitHub:
```bash
pip install -e git+git://github.com/dreikanter/dbarc#egg=dbarc
```Create a new app with [Dropbox App Console](https://www.dropbox.com/developers/apps) and get your app key and app secret.
Run the following command to acquire API access token (use the actual values for `` and ``):
```bash
dbarc init
```This will ask you to open a specific URL in the browser, authorize the tool to access your Dropbox contents, and copy authorization code back to console. Dropbox access token will be saved to the current user home directory: `~/.dbarc` (`%userprofile%/.dbarc` on Windows). This path could be overridden with `--token` command line parameter.
Here is an example:
```bash
$ dbarc init kjdfake8gkjssf e23aksfakelak9
1. Go to: https://www.dropbox.com/1/oauth2/authorize?response_type=code&client_id=1
2. Click "Allow" (you might have to log in first)
3. Copy the authorization code.
Enter the authorization code here:
KHFAKERIYEPIUQDH4FAKEFOHDIUAW7IUAHEEFAKEDIW
Linked account: John Doe
```### Running the Script on Raspberry Pi
Default python3 version on Raspberry Pi at the moment is 3.2.3, and you will need to upgrade it to 3.3+. The easiest way to do this is [pyenv](https://github.com/yyuu/pyenv). Pyenv will download and build python versions from source code.
There could be errors due insufficient dependencies on Raspbian Wheezy. If you encounter something like "ImportError: No module named 'readline'" during python build, use the following command to install these libraries manually:
```
sudo apt-get install libreadline-gplv2-dev libssl-dev sqlite3 libsqlite3-dev \
python-setuptools python-dev build-essential libxml2-dev libxslt1-dev libbz2-dev \
libjpeg62-dev wv poppler-utils python-imaging
```## Usage
Te following command will download files from `` path inside your Dropbox to `/YYYY.MM/` directories where `YYYY.MM` is file last modification date.
```bash
dbarc download
```Example:
```bash
$ dbarc download /snippets ~/snippets-archive
dropbox://snippets/ClassExt.cs -> /home/pi/snippets-archive/2013-02/ClassExt.cs
dropbox://snippets/DateExt.cs -> /home/pi/snippets-archive/2013-02/DateExt.cs
dropbox://snippets/EnumExt.cs -> /home/pi/snippets-archive/2013-02/EnumExt.cs
...
```Cron tab example to run the script every day at 23:59:00:
```bash
59 23 * * * dbarc download
```## License
Copyright © 2013 by [Alex Musayev](http://alex.musayev.com).
License: [MIT](http://opensource.org/licenses/MIT).
Project home: [https://github.com/dreikanter/dbarc](https://github.com/dreikanter/dbarc).