1
0
mirror of https://github.com/janeczku/calibre-web synced 2025-01-26 17:06:55 +00:00
Web app for browsing, reading and downloading eBooks stored in a Calibre database.
Go to file
2017-01-07 21:28:09 +07:00
cps Bugfix E-Mailsettings 2017-01-06 14:45:43 +01:00
vendor Add .gitempty to vendor dir 2017-01-07 20:43:29 +07:00
.gitignore changes for #77 2016-12-23 09:53:39 +01:00
babel.cfg Made kindlegen working on windows (including paths containing umlauts) 2016-11-12 10:52:59 +01:00
config.ini.example Add ANON_BROWSE configuration option 2016-04-29 22:36:36 +02:00
cps.py Add .gitempty to vendor dir 2017-01-07 20:43:29 +07:00
LICENSE Add GPL v3 License 2016-04-27 17:29:57 +02:00
messages.pot Added code for rearranging shelfs #73 2017-01-03 20:19:32 +01:00
readme.md Add deps installation instruction to README 2017-01-07 20:43:44 +07:00
requirements.txt Trim down requirements.txt 2017-01-07 21:28:09 +07:00

About

Calibre Web is a web app providing a clean interface for browsing, reading and downloading eBooks using an existing Calibre database.

This software is a fork of library and licensed under the GPL v3 License.

screenshot

Features

  • Bootstrap 3 HTML5 interface
  • User management
  • Admin interface
  • User Interface in english, german and french
  • OPDS feed for eBook reader apps
  • Filter and search by titles, authors, tags, series and language
  • Create custom book collection (shelves)
  • Support for editing eBook metadata
  • Support for converting eBooks from EPUB to Kindle format (mobi/azw)
  • Restrict eBook download to logged-in users
  • Support for public user registration
  • Send eBooks to Kindle devices with the click of a button
  • Support for reading eBooks directly in the browser (.txt, .epub, .pdf)
  • Upload new books in PDF format
  • Support for Calibre custom columns
  • Fine grained per-user permissions

Quick start

  1. Install required dependencies by executing pip install -r requirements.txt
  2. Rename config.ini.example to config.ini and set DB_ROOT to the path of the folder where your Calibre library (metadata.db) lives
  3. Execute the command: python cps.py
  4. Point your browser to http://localhost:8083 or http://localhost:8083/opds for the OPDS catalog

Default admin login: Username: admin Password: admin123

Runtime Configuration Options

PUBLIC_REG Set to 1 to enable public user registration. ANON_BROWSE Set to 1 to allow not logged in users to browse the catalog. UPLOADING Set to 1 to enable PDF uploading. This requires the imagemagick library to be installed.

Requirements

Python 2.7+

Optionally, to enable on-the-fly conversion from EPUB to MOBI when using the send-to-kindle feature:

Download Amazon's KindleGen tool for your platform and place the binary named as kindlegen in the vendor folder.

Docker image

Calibre Web can be run as Docker container. The latest image is available on Docker Hub.

Reverse Proxy

Reverse proxy configuration examples for apache and nginx to use calibre-web:

nginx configuration for a local server listening on port 8080, mapping calibre web to /calibre:

http {
    upstream calibre {
        server  127.0.0.1:8083;
    }
    server {
            location /calibre {
                proxy_bind              $server_addr;
                proxy_pass              http://127.0.0.1:8083;
                proxy_set_header        Host            $http_host;
                proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header        X-Scheme        $scheme;
                proxy_set_header        X-Script-Name   /calibre;
        }
    }
}

Apache 2.4 configuration for a local server listening on port 443, mapping calibre web to /calibre-web:

The following modules have to be activated: headers, proxy, proxy_html, proxy_http, rewrite, xml2enc.

Listen 443

<VirtualHost *:443>
    SSLEngine on
    SSLProxyEngine on
    SSLCipherSuite ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP:+eNULL
    SSLCertificateFile "C:\Apache24\conf\ssl\test.crt"
    SSLCertificateKeyFile "C:\Apache24\conf\ssl\test.key"

    <Location /calibre-web>
           ProxyHTMLEnable On
           ProxyPass            http://127.0.0.1:8083/
           ProxyPassReverse     http://127.0.0.1:8083/
           Header edit Location "^http://(.*?)/" "https://$1/calibre-web/"
           ProxyHTMLURLMap      /  /calibre-web/
    </Location>
</VirtualHost>

Start calibre-web as service under Linux

Create a file "cps.service" as root in the folder /etc/systemd/system with the following content:

Description=Calibre-web

[Service]
Type=simple
User=[Username]
ExecStart=[path to python] [/PATH/TO/cps.py]

[Install]
WantedBy=multi-user.target

Replace the user and ExecStart with your user and foldernames.

sudo systemctl enable cps.service

enables the service.