Configuration.
Configuration
While Jelu is provided with sensible defaults you might want to tune things a bit.
It is possible to provide configuration via environment varibles or via an application.yml
file.
If you are running the java version put the application.yml
file next to the jar.
If you are running the docker version either provide environment variables or put an application.yml
file inside the folder you mounted on /config
.
Jelu specific configuration
Env variable | Property | Usage |
---|---|---|
JELU_DATABASE_PATH | jelu.database.path | Path to a folder where the database jelu.db will be created |
JELU_FILES_IMAGES | jelu.files.images | Path to a folder where the book covers and authors pictures will be stored |
JELU_FILES_IMPORTS | jelu.files.imports | Path to a folder where the csv imports will be stored |
JELU_METADATA_CALIBRE_PATH | jelu.metadata.calibre.path | Path to the calibre fetch ebook metadata binary; eg : /usr/bin/fetch-ebook-metadata |
JELU_CORS_ALLOWED-ORIGINS | jelu.cors.allowed-origins | a list of hosts that should be accepted see Installation java for examples |
JELU_SESSION_DURATION | jelu.session.duration | Duration of the frontend session in seconds, default is 604800 which is 7 days |
Spring herited configuration
Jelu is developed using the Spring framework and Spring boot, so all config from spring and spring boot is available.
Here are some configuration keys that may be useful :
Env variable | Property | Usage |
---|---|---|
SERVER_PORT | server.port | The port used by the API and the web frontend, default is 11111 |
SPRING_DATASOURCE_USERNAME | spring.datasource.username | The username of the jelu.db database, default is jelu_user |
SPRING_DATASOURCE_PASSWORD | spring.datasource.password | The password of the jelu.db database, default is mypass1234 |
configuring proxy authentication
Danger
- This is for advanced users, use this only if you know what you are doing
Env variable | Property | Usage |
---|---|---|
JELU_AUTH_LDAP_ENABLED | jelu.auth.ldap.enabled | Activate or not the ldap authent (turn this off if you don’t have a ldap server) |
JELU_AUTH_PROXY_ENABLED | jelu.auth.proxy.enabled | Activate or not proxy authentication |
JELU_AUTH_PROXY_ADMINNAME | jelu.auth.proxy.adminName | Name of the admin user (see below) |
JELU_AUTH_PROXY_HEADER | jelu.auth.proxy.header | Header which stores the proxy authentication username, defaults to X-Authenticated-User if this configuration entry is not set |
In yaml this looks like that :
jelu:
auth:
proxy:
enabled: true
adminName: "adminuser"
header: X-Personal-User
ldap:
enabled: false
How does this works :
You typically use this when you want your reverse proxy to handle the authentication part.
When a request hits your reverse proxy, it redirects the user to an authentication mechanism and sets a header containing the user name.
When Jelu receives a request with the header defined in config (or the default one), it first searches in its database to see if a user with this name exists.
If yes, the session is started with this user.
If no, Jelu automatically creates an user with the name.
If the user name is the same as the adminName from the configuration, then the user is created with admin rights.
Danger
- This allows people to bypass security if anyone finds a way to reach your instance without going through your reverse proxy.
oauth2 additional configuration
Env variable | Property | Usage |
---|---|---|
JELU_AUTH_OAUTH2_ACCOUNT_CREATION | jelu.auth.oauth2AccountCreation | boolean indicating whether Jelu should create new users when a login via OAuth2/OIDC succeeds, but there is no existing user with that email. Such users will be created with a random password, which the user can subsequently change from the Account Settings page later on. default is false |
JELU_AUTH_OIDC_EMAIL_VERIFICATION | jelu.auth.oidcEmailVerification | boolean indicating whether Jelu should check whether the email_verified claim is present and true in the OpenID Connect request. Default is true |
Danger
- only disable oidcEmailVerification with OIDC providers that do not verify emails (like Azure AD)
- only enable account creation with OAuth2 providers you control
Adding other metadata providers
See the Metadata page.
For example, it is possible to use Google book API as a metadata provider.
Tip
- You must obtain an API key from Google to use the Google API provider
- This provider will only search if an ISBN is provided
Once you have an API key you can configure it like this :
jelu:
metadataProviders:
- is-enabled: true
apiKey: "YOUR-API-KEY-HERE"
name: "google"
Then restart Jelu.
There is also a debug plugin (which does nothing except printing the parameters in the logs)
The yaml for plugins configuration is shown below :
jelu:
metadataProviders:
- is-enabled: true
apiKey: ""
order: -100000
name: "jelu-debug"
- is-enabled: true
apiKey: "YOUR_API_KEY_HERE"
order: -10
name: "google"
- name: "inventaireio"
is-enabled: true
order: 200000
config: "fr"
metadata:
calibre:
path: /usr/bin/fetch-ebook-metadata
order: 50000
Tip
The google plugin, the inventaire.io plugin and the jelu-debug plugin names must be the same as in the config above.
If not set the default order priority of the calibre plugin is 1000.
For the other plugins the default order is -1000.
The inventaire.io plugin accepts a config
key.
This key is used to select your preferred language. When several languages are available in the inventaire.io API (for book titles, tags etc…) Jelu will first try to get your preferred language, if it does not exist it will try to get the english version as a fallback.
The accepted values are 2 or 3 letters ISO language codes.
Here is a sample of availables values from the inventaire.io API :
"pt","fr","en","es","ca","it","et","de","nn","ja","cs","fa","bg","mzn","nl","da","sv","zh","ckb","nb","sl","fi","hu","pl","azb","eu","br","gl","uk","ast","ru","ar","pt-br","cy","sq","arz","pap","ka","tr"