Cloud Sync
We have two things to sync: 1. metadata of papers, 2. PDF files.
For metadata, we can use MongoDB Atlas as the cloud database backend. For PDF files, we recommand to use onedrive (or dropbox etc.) or webDAV to sync your PDF files accross devices.
About why can't you use webdav/dropbox... to sync metadata:
- Cloud storage services are designed for files, not for databases. They cannot merge conflict and the sync delay usually occurs. For example you modified something on PC A, then you modified something on PC B, but without the network connection. Once you connect PC B with network, how to merge these two databases?
- We need a powerful database for fast searching.
- When an APP is reading a database file, there is a file lock. It means that the cloud storage service such as OneDrive will never sync the database file until you exit the APP. So , even if conflict merging does not become a problem, you must ensure that you remember to exit the software in time on any computer. Imagine you forget to close the software on PC B, but leave PC B and go to PC A. You will never be able to access the changes you made on PC B.
Paperlib use MongoDB Atlas as the cloud database backend. You can create your own cloud database and use it to sync your Paperlib data across your devices. The free tier of MongoDB Atlas is enough for Paperlib. When everything is set up, you can safely store the metadata of your papers in the cloud without any maintenance operation.
Create a MongoDB Atlas DB
- Open https://account.mongodb.com/account/login, sign up and login to your account. Close all the guides and click
Create
.
- Choose the free dataset plan. Uncheck the two options in the red box. Select the best server location according to your country. Click
Create Deployment
.
- Close the popup window.
- Go to the App Services page, create an APP.
- Make sure the Data Source is the one you just created. Select the location for deployment. Click
Create App
.
- Close the popup window.
7.Since then, the MongoDB Atlas is ready.
Create a User
A User is a person who can access the cloud database.
- In
App Services
page, clickApp Users
, clickAuthentication Providers
.
- Turn on the
Email Password Authentication
. ChooseAutomatically confirm users
as the user confirmation method.Password Reset URL
is not required, just leave a random URL. ClickSave Draft
.
- Click the upper banner
REVIEW DRAFT & DEPLOY
to apply previous settings.
- Back to the User page, Click
Add New User
to create a user.
- Sinc then, you've created a user.
Create a Data Table.
The data schema can be automatically created based on the data sent by the Paperlib APP.
- In the
Device Sync
page, clickStart Sync
. It enables the your APP to sync data with the backend database cluster. In the popup dialog, clickNo thanks, continue to Sync
.
- Open the
Development Mode
to allow MongoDB Altas automatically create data schema based on the data sent by the Paperlib APP. Other configurations are as shown below. Leave the Queryable Fields setting as default.
Click
Enable Sync
.Click the upper banner
REVIEW DRAFT & DEPLOY
again.In the popup dialog, choose
Users can read and write all data
.Click the upper banner
REVIEW DRAFT & DEPLOY
again.Since then, the cloud database is ready.
Connect Paperlib to your MongoDB Atlas DB
- Open the preference window of Paperlib, click
Cloud
tab, input your MongoDB Atlas APP ID, email and password of the user you created.
- Turn on the
Flexible Sync
.
- Click
Login
. If the sync is successful, you can see some writing logs after importing a paper to Paperlib.
Now, everthing is ready, enjoy Paperlib with cloud sync.
Sync PDF Files
Since PDF storage may cost a lot of cloud space, we recommand to use onedrive (or dropbox etc.) or webDAV to sync your PDF files accross devices.
For example, on device A, choose C:/Onedrive/mypaperlib
as your library folder. On the other device B, choose /user/xxx/Onedrive/mypaperlib
as the library folder.