Giter Club home page Giter Club logo

kobocloud's Introduction

KoboCloud

A set of scripts to synchronize a kobo reader with popular cloud services.

The following cloud services are supported:

  • Dropbox (two methods)
  • Google Drive
  • NextCloud/OwnCloud
  • pCloud
  • Box

Installation

Download the latest KoboRoot.tgz from the Release page (or using this direct link).

Copy it into the Kobo device:

  • Connect the Kobo device and mount it (you should be able to access to the kobo filesystem)
  • Copy the .tgz archive in the .kobo directory(1) of your device
  • Unplug and restart your Kobo device

(1) It is a hidden directory, so you have to enable the visualization of hidden files

Note for Mac/Safari users: Safari automatically unpacks KoboRoot.tgz into KoboRoot.tar after downloading. Please make sure that you transfer the .tgz file to your Kobo, and not the .tar. Either use a different browser to download the package, or re-pack it (using gzip) before transferring.

Configuration

After the installation process:

  • Plug your Kobo back into the computer
  • Open the configuration file located at .add/kobocloud/kobocloudrc
  • Add the links to the cloud services (one per line)

Configuration example:

# Lines starting with '#' are ignored
# Google drive:
https://drive.google.com/drive/folders/<ID>?usp=sharing
# Dropbox:
https://www.dropbox.com/sh/pgSHORTENED
REMOVE_DELETED

Some important advice:

  • make sure that there are no spaces before or after the link on the line
  • no subdirectories are supported at the moment, your books must be all in the same directories that you are sharing
  • restart your Kobo after any kobocloudrc changes to to make them effective

Dropbox public folder (limited)

To add a Dropbox public link:

  • Open your dropbox in a browser
  • Select the folder that you want to share and click "Share" and "Send link"
  • Copy the link that appears into the kobocloudrc file

Note: this method does not work for folders with more than ~30 books, see fsantini#123.

Dropbox private folder

This method will create a folder /Applications/Kobo Cloud Sync in your Dropbox and sync with it.

  • Open this link
  • Paste the command in a terminal
  • Copy the line starting with DropboxApp: from your terminal
  • Add it to your kobocloudrc file

Google Drive

  • Use the "link sharing" option on a Google Drive folder
  • Select the option "anyone with the link can view."
  • Copy-paste the link in the kobocloudrc file

Subdirectories are supported for Google Drive. Important: Folders with many files might not work.

Nextcloud (Owncloud)

To add a NextCloud (ownCloud) link:

  • Open your nextcloud website in a browser
  • Select the folder that you want to share
  • Click on "Share" and select "Share with link"
  • Copy the link into the kobocloudrc file

Please note that you need a recent NextCloud (OwnCloud) version. Subdirectories are supported for NextCloud (OwnCloud).

Important: Webdav for public folders should be enabled, see: https://docs.nextcloud.com/server/20/user_manual/en/files/access_webdav.html#accessing-public-shares-over-webdav for more info.

pCloud

Files added into a subfolder of the public folder of pCloud are also supported.

Box

  • On a Box folder, click "Create link" in the sidebar and enable "Share Link"
  • Select the options "People with the link" and "can view and download"
  • Copy-paste the link in the kobocloudrc file

Please note that, even though the script supports folders where the file list has multiple pages, having a list with many pages might not work.

Matching remote server

To delete files from library when they are no longer in the remote server:

  • Edit the kobocloudrc file so it contains the phrase REMOVE_DELETED in a single line (all capital, no spaces before or after).
  • Restart your Kobo.

The next time the Kobo is connected to the internet, it will delete any files (it will not delete directories) that are not in the remote server.

Usage

The new files will be downloaded when the kobo connects to the Internet for a sync. Sometimes few minutes is needed after the sync process for the device to recognize and import new downloaded content.

Uninstallation

To properly uninstall KoboCloud:

  • Edit the kobocloudrc file so that it contains the word UNINSTALL in a single line (all capital, no spaces before or after)
  • Restart your Kobo

The next time the Kobo is connected to the Internet, the program will delete itself.

Note: The directory .add/kobocloud will not be deleted: after connecting the device to a computer, you should move the files from the Library subfolder in order not to lose your content, and delete the whole kobocloud directory manually.

Installation from source code

To install KoboCloud from source code:

  • Download this repository
  • Compile the code into an archive format (instructions below)
  • Follow installation instructions

Compiling

  • Move to the project directory root
  • Open the configuration file located at src/usr/local/kobocloud/kobocloudrc.tmpl
  • Add the links to the cloud services (see the configuration example that follow below)
  • Run sh ./makeKoboRoot.sh

The last command will create a KoboRoot.tgz archive.

Now you can follow installation instructions.

Troubleshooting

KoboCloud keeps a log of each session in the .add/kobocloud/get.log file. If something goes wrong, useful information can be found there. Please send a copy of this file with every bug report.

Known issues

  • No subdirectories are supported
  • Some versions of Kobo make the same book appear twice in the library. This is because it scans the internal directory where the files are saved as well as the "official" folders. To solve this problem find the Kobo eReader.conf file inside your .kobo/Kobo folder and make sure the following line (which prevents the syncing of dotfiles and dotfolders) is set in the [FeatureSettings] section:
  ExcludeSyncFolders=\\.(?!add|adobe).*?

Acknowledgment

Thanks to the defunct SendToKobo service for the inspiration of the project and for the basis of the scripts. Curl for Kobo was downloaded from here: https://www.mobileread.com/forums/showthread.php?p=3734553 . Thanks to NiLuJe for providing it! Thanks to Christoph Burschka for the help in updating this tool to the recent versions of kobo and nextcloud.

kobocloud's People

Contributors

danielemegna avatar desyncr avatar fsantini avatar ghchinoy avatar groentebroer avatar kjeldahl avatar louisabraham avatar pedrosousa avatar vpeeters avatar ws-jy avatar wzzza avatar zimm-lostpolygon avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.