LazyLibrarian is a program available for OSX and Linux that is used to automatically search eBooks, audiobooks, and magazines, which are then sent to a torrent or newsbin client. It uses a combination of Goodreads, Librarything, and optionally GoogleBooks as sources for author info and book info. It’s nice to be able to have all of our book in digital form since books are extremely heavy and take up a lot of space, which we are already lacking in the bus.
Some of LazyLibrarian’s features include:
- Import an existing Calibre library.
- Find authors and add them to the database.
- List all books of an author and mark them as ‘wanted’.
Setting up LazyLibrarian is really simple once you have Docker installed. If you’re on a Synology device, this can be done by going to Package Center > Settings > Package Sources
and adding https://packages.synocommunity.com/. Once that resource has been added, search the package center for Docker. Once Docker has been installed, run it and navigate to the registry tab to search for LazyLibrarian. There are many different builds of this program but we suggest the Thraxis build since it also contains Calibre, which can be used to setup a virtual library. Once you find the one you would like, select it and click download it.
After it’s done downloading, it will move into the Image tab. Launch the container to begin configuring it.
Start out by giving the container a name and then clicking Advanced Settings.
Within the Advanced Settings, enable auto-restart, and create a shortcut on desktop (if that interests you). Use your servers IP address followed by the container’s port number 5299
.
Next setup the volumes. These folders all need to be created prior to setting up the container so that they can be browsed to and mounted. It is important to setup the folders in such a way that the Download
folder is a sub folder alongside the Library
folder. This is so that the Usenet client can move files instantly and the torrent client can use hard links, as to not waste space while simultaneously leaving the torrent’s copy to seed in the /completed
folder until X
ratio is met. On a Synology, each share is a BTRFS sub-volume and acts as a different file system. Because of this, copy + move does not execute properly across the different file systems.
The old method used multiple BTRFS shares, and therefore multiple file systems. (DO NOT use this method)
Click Add Folder to begin mounting each path. Use /config
to mount the folder for LazyLibrarian’s configuration files, and /Media
to mount the folder which contains the Downloads
and Library
sub directories. These are CASE SENSITIVE!
Port settings are used to open the container within a browser. This should be left to the default value since LazyLibrarian will be looking for this port. Local Port needs to be changed from Auto to the matching Container Port. If this is not done, your machine may use a random port each time and cause confusion.
Environment is where variables are set that are needed to allow the container to run. For the container to run properly and to access and modify the directories, it must be given user permissions. It is good practice to create a new user that is used exclusively for running the container. This user needs read/write privileges to the Docker’s /config
directory as well as the /Media
directory. The purpose of this is so that in the event the container is compromised, the entire NAS will not be accessible. More on this can be found here.
To obtain the Personal User ID (PUID) and Personal Group ID (PGID) of the user that will be running the container, use Putty or an equivalent program to SSH into your NAS.
Enter the IP address of your NAS in Putty, select the SSH radio button, and click Open.
Enter the admin login information for the NAS. You will not be able to see the password as you type it. Once logged in type id <user>
to show your UID (aka PUID) and the GID (aka PGID) for the selected user. We setup a user named automation
to run the containers. The command for obtaining the UID and GID in this case was id automation
.
Put the IDs from the SSH session into the Environment tab as shown below. It’s also a good idea to input the local timezone, as many containers need this to run. The timezone codes can be found here.
Now that the setup is complete, click ‘ok’ and the container will launch. Read about how to configure LazyLibrarian here.
I added my puid and pgid and my username for those ids have read/write access but the logs in lazylibrarian show permission denied when trying to use the library folder I have given it. Any thoughts on what I should try?
It’s likely a bad path mapping. I would honestly check out Redarr if you can. When it is working a bit better we will be switching over exclusively to that.
But can you do Magazines on Readarr?
This tutorial is not for Readarr.