Calibre web frontend, Go (golang) https://bouquins.meutel.net
Go to file
Meutel fb2e8ff85f
All checks were successful
continuous-integration/drone/push Build is passing
Merge branch 'feature/yaml' of meutel/go-bouquins into master
2019-09-12 12:43:31 +00:00
assets Gitea oauth2 provider 2019-09-08 11:31:14 +02:00
bouquins Config yaml 2019-09-12 14:34:26 +02:00
templates Design provider page 2017-09-09 12:28:46 +02:00
.drone.yml Docker build 2019-09-11 18:02:29 +02:00
.gitignore Config yaml 2019-09-12 14:34:26 +02:00
Dockerfile Certs for oauth2 2019-07-03 20:08:23 +02:00
go.mod Config yaml 2019-09-12 14:34:26 +02:00
go.sum Config yaml 2019-09-12 14:34:26 +02:00
LICENSE Initial commit 2017-07-30 20:15:54 +02:00
main.go Config yaml 2019-09-12 14:34:26 +02:00
README.md minify css 2017-09-09 18:09:03 +02:00

go-bouquins

Bouquins in Go

TODO

  • translations
  • tests
  • csrf
  • userdb commands (init, migrate, add/remove user/email)
  • error pages

Minify

Deployment archive

tar czf ~/tmp/go-bouquins.tar.gz go-bouquins assets/ templates/

Configuration

JSON config file: default ./bouquins.json, or binary argument

Example:

{
  "calibre-path": "/usr/home/meutel/data/calibre",
  "bind-address": ":8080",
  "prod": true,
  "cookie-secret": "random",
  "external-url":"https://bouquins.meutel.net",
  "providers": [
    {
      "name": "github",
      "client-id": "ID client",
      "client-secret": "SECRET"
    },
    {
      "name": "google",
      "client-id":"ID client",
      "client-secret":"SECRET"
    }
  ]
}

Options:

  • calibre-path path to calibre data
  • db-path path to calibre SQLite database (default /metadata.db)
  • user-db-path path to users SQLite database (default ./users.db)
  • bind-address HTTP socket bind address
  • prod (boolean) use minified javascript/CSS
  • cookie-secret random string for cookie encryption
  • external-url URL used by client browsers
  • providers configuration for OAuth 2 providers
    • name provider name
    • client-id OAuth client ID
    • client-secret OAuth secret

Users SQL

CREATE TABLE accounts (id varchar(36) PRIMARY KEY NOT NULL, name varchar(255) NOT NULL); CREATE TABLE authentifiers (id varchar(36) NOT NULL, authentifier varchar(320) PRIMARY KEY NOT NULL, FOREIGN KEY(id) REFERENCES account(id));