Customization

Note synchronization

Inkdrop lets you sync notes across multiple computers via Cloud. By default, Inkdrop stores your data in Inkdrop sync server. You can configure synchronizations in the Preferences window like this:

Sync Preferences

There are three sync options:

  • Don't Sync - Store Inkdrop data only in your local computer
  • Inkdrop Sync Server - Sync with Inkdrop's own service
  • Advanced (CouchDB) - Sync with your own compatible server

How to Set Up Your Own Sync Server

Inkdrop lets you store your notes in your own database compatible with CouchDB API instead of Inkdrop's own service. CouchDB is just another open-source NoSQL database so you can deploy it on your environment for free. See CouchDB's installation guide for more informations. Using DBaaS instead of operating database by yourself is good choice. For instance, Cloudant is one of fully-managed DBaaS providers.

Use this feature at your own risk. Inkdrop itself doesn't protect data from other people on your server. To protect your data, read Security section at the bottom of this page.improvements.

Create a database

Once you got your CouchDB server, let's create a database for storing your notes. You need only one database for Inkdrop. For example, run below command to create a database:

> curl -X PUT http://localhost:5984/my-inkdrop-notes

Note

If you are running CouchDB not on localhost and port 5984 (default), replace localhost:5984 to your server address and port.

Retrieving the list of databases shows some useful results this time:

> curl -X GET http://127.0.0.1:5984/_all_dbs
["my-inkdrop-notes"]

Return to the Inkdrop sync preferences, you can input the URL to your database to the Address section:

http://localhost:5984/my-inkdrop-notes

Sync with custom server on the desktop app

Then, push the Apply button.

Please read CouchDB's tutorial for more information.

Configure security

As you may know, CouchDB is running with the Admin Party by default. It means Everybody has privileges to do anything. Please read the CouchDB's documentation. To keep your notes secure, we recommend that you create an admin user with a username and password as your credentials.

Now let’s create an admin user. We’ll call her anna, and her password is secret:

> curl -X PUT http://127.0.0.1:5984/_config/admins/anna -d '"secret"'

Now we have an admin user named anna, let's give her an admin access to my-inkdrop-notes:

> curl -X PUT http://127.0.0.1:5984/my-inkdrop-notes/_security -d '{ "admins": { "names": [ "anna" ] } }'

It restricts access from people without the valid credentials:

> curl -X PUT http://127.0.0.1:5984/my-inkdrop-notes
{"error":"unauthorized","reason":"You are not a server admin."}

That looks about right. Now we try again with the correct credentials:

> HOST="http://anna:secret@127.0.0.1:5984"
> curl -X PUT $HOST/my-inkdrop-notes
{"ok":true}

Looks good!

Return to the Inkdrop sync preferences, you can input the URL to your database to the Address section:

http://anna:secret@127.0.0.1:5984/my-inkdrop-notes

Please don't omit the port number.

Enable SSL

If you would like to make your database accessible to the public, we encourage you to configure SSL. CouchDB provides SSL by default but it's not recommended since there's a problem with the replication with clients. We recommend nginx as a reverse-proxy server. Your configuration will look like:

server {
  listen 6984;
  ssl on;
  ssl_certificate /path/to/fullchain.pem;
  ssl_certificate_key /path/to/privkey.pem;
  ssl_protocols TLSv1.1 TLSv1.2 SSLv3;
  ssl_session_cache shared:SSL:1m;

  server_name ***;

  location / {
    proxy_pass http://localhost:5984;
    proxy_redirect off;
    proxy_set_header Host $host;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Ssl on;
  }

  location ~ ^/(.*)/_changes {
    proxy_pass http://localhost:5984;
    proxy_redirect off;
    proxy_buffering off;
    proxy_set_header Host $host;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Ssl on;
  }
}

Your server URL would be like so:

https://anna:secret@your-server.com:6984/my-inkdrop-notes

Note

You can neither create design documents nor add attachments on the Inkdrop-hosted database.

Support mobile sync

If you would like to sync your custom database with the mobile app, please create a design document on your database:

{
  "_id": "_design/mobile",
  "filters": {
    "sync": "function (doc) { return doc._id.indexOf('file:') === -1 }"
  }
}

Also, please don't forget your server to enable SSL because iOS requires it for App Transport Security.

To configure the mobile app to sync with your database:

  1. Go to Preferences → Synchronization
  2. Select Advanced (CouchDB)
  3. Input your database URL to the input field at the ADDRESS section.
  4. Press Apply button

Sync with custom server on the mobile app

Debugging the database connections

If the app won't sync with the database, there are two ways to debug the issue:

  1. Run Network diagnosis
  2. Enable main process logging

Get help

Got any questions about this page? Feel free to ask them on the user forum here.
Previous
Customize keybindings