mirror of
https://github.com/TheAnachronism/docspell.git
synced 2024-11-13 02:31:10 +00:00
235 lines
6.2 KiB
Markdown
235 lines
6.2 KiB
Markdown
---
|
||
layout: docs
|
||
title: Nix/NixOS
|
||
permalink: doc/nix
|
||
---
|
||
|
||
# {{ page.title }}
|
||
|
||
## Install via Nix
|
||
|
||
Docspell can be installed via the [nix](https://nixos.org/nix) package
|
||
manager, which is available for Linux and OSX. Docspell is currently not
|
||
part of the [nixpkgs collection](https://nixos.org/nixpkgs/), but you
|
||
can use the derivation from this repository. This is sometimes
|
||
referred to as [import from
|
||
derivation](https://nixos.wiki/wiki/Import_From_Derivation).
|
||
|
||
For example, the `builtins.fetchTarball` function can be used to
|
||
retrieve the files; then import the `release.nix` file:
|
||
|
||
``` nix
|
||
let
|
||
docspellsrc = builtins.fetchTarball "https://github.com/eikek/docspell/archive/master.tar.gz";
|
||
in
|
||
import "${docspellsrc}/nix/release.nix";
|
||
```
|
||
|
||
This creates a set containing a function for creating a derivation for
|
||
docspell. This then needs to be called like other custom packages. For
|
||
example, in your `~/.nixpkgs/config.nix` you could write this:
|
||
|
||
``` nix
|
||
let
|
||
docspellsrc = builtins.fetchTarball "https://github.com/eikek/docspell/archive/master.tar.gz";
|
||
docspell = import "${docspellsrc}/nix/release.nix";
|
||
in
|
||
{ packageOverrides = pkgs:
|
||
let
|
||
callPackage = pkgs.lib.callPackageWith(custom // pkgs);
|
||
custom = {
|
||
docspell = callPackage docspell.currentPkg {};
|
||
};
|
||
in custom;
|
||
}
|
||
```
|
||
|
||
The `docspell` custom package is again a set that contains derivations
|
||
for all 3 installable docspell programs: the restserver, joex and the
|
||
tools.
|
||
|
||
Then you can install docspell via `nix-shell` or `nix-env`, for example:
|
||
|
||
``` bash
|
||
$ nix-env -iA nixpkgs.docspell.server nixpkgs.docspell.joex nixpkgs.docspell.tools
|
||
```
|
||
|
||
You may need to replace `nixpkgs` with `nixos` when you're on NixOS.
|
||
|
||
The expression `docspell.currentPkg` refers to the most current release
|
||
of Docspell. So even if you use the tarball of the current master
|
||
branch, the `release.nix` file only contains derivations for releases.
|
||
The expression `docspell.currentPkg` is a shortcut for selecting the
|
||
most current release. For example it translates to `docspell.pkg
|
||
docspell.cfg.v@PVERSION@` – if the current version is `@VERSION@`.
|
||
|
||
|
||
## Docspell as a service on NixOS
|
||
|
||
If you are running [NixOS](https://nixos.org), there is a module
|
||
definition for installing Docspell as a service using systemd.
|
||
|
||
There are the following modules provided:
|
||
|
||
- restserver
|
||
- joex
|
||
- consumedir
|
||
|
||
The `consumedir` module defines a systemd unit that starts the
|
||
`consumedir.sh` script to watch one or more directories for new files.
|
||
|
||
You need to import the `release.nix` file as described above in your
|
||
`configuration.nix` and then append the docspell module to your list of
|
||
modules. Here is an example:
|
||
|
||
```nix
|
||
{ config, pkgs, ... }:
|
||
let
|
||
docspellsrc = builtins.fetchTarball "https://github.com/eikek/docspell/archive/master.tar.gz";
|
||
docspell = import "${docspellsrc}/nix/release.nix";
|
||
in
|
||
{
|
||
imports = [ mymodule1 mymodule2 ] ++ docspell.modules;
|
||
|
||
nixpkgs = {
|
||
config = {
|
||
packageOverrides = pkgs:
|
||
let
|
||
callPackage = pkgs.lib.callPackageWith(custom // pkgs);
|
||
custom = {
|
||
docspell = callPackage docspell.currentPkg {};
|
||
};
|
||
in custom;
|
||
};
|
||
};
|
||
|
||
services.docspell-restserver = {
|
||
enable = true;
|
||
base-url = "http://docspelltest:7880";
|
||
# ... more settings here
|
||
};
|
||
services.docspell-joex = {
|
||
enable = true;
|
||
base-url = "http://docspelltexst:7878";
|
||
# ... more settings here
|
||
};
|
||
services.docspell-consumedir = {
|
||
enable = true;
|
||
watchDirs = ["/tmp/test"];
|
||
urls = ["http://localhost:7880/api/v1/open/upload/item/the-source-id"];
|
||
};
|
||
|
||
...
|
||
}
|
||
|
||
```
|
||
|
||
Please see the `nix/module-server.nix` and `nix/module-joex.nix` files
|
||
for the set of options. The nixos options are modelled after the
|
||
default configuration file.
|
||
|
||
|
||
## NixOs Example
|
||
|
||
This is a example system configuration that installs docspell with a
|
||
postgres database. This snippet can be used to create a vm (using
|
||
`nixos-rebuild build-vm` as shown above) or a container, for example.
|
||
|
||
``` nix
|
||
{ config, pkgs, ... }:
|
||
let
|
||
docspellsrc = builtins.fetchTarball "https://github.com/eikek/docspell/archive/master.tar.gz";
|
||
docspell = import "${docspellsrc}/nix/release.nix";
|
||
in
|
||
{
|
||
imports = docspell.modules;
|
||
|
||
nixpkgs = {
|
||
config = {
|
||
packageOverrides = pkgs:
|
||
let
|
||
callPackage = pkgs.lib.callPackageWith(custom // pkgs);
|
||
custom = {
|
||
docspell = callPackage docspell.currentPkg {};
|
||
};
|
||
in custom;
|
||
};
|
||
};
|
||
|
||
##### just for the example…
|
||
users.users.root = {
|
||
password = "root";
|
||
};
|
||
#####
|
||
|
||
# install docspell-joex and enable the systemd service
|
||
services.docspell-joex = {
|
||
enable = true;
|
||
base-url = "http://localhost:7878";
|
||
bind = {
|
||
address = "0.0.0.0";
|
||
port = 7878;
|
||
};
|
||
scheduler = {
|
||
pool-size = 1;
|
||
};
|
||
jdbc = {
|
||
url = "jdbc:postgresql://localhost:5432/docspell";
|
||
user = "docspell";
|
||
password = "docspell";
|
||
};
|
||
};
|
||
|
||
# install docspell-restserver and enable the systemd service
|
||
services.docspell-restserver = {
|
||
enable = true;
|
||
base-url = "http://localhost:7880";
|
||
bind = {
|
||
address = "0.0.0.0";
|
||
port = 7880;
|
||
};
|
||
auth = {
|
||
server-secret = "b64:EirgaudMyNvWg4TvxVGxTu-fgtrto4ETz--Hk9Pv2o4=";
|
||
};
|
||
backend = {
|
||
signup = {
|
||
mode = "invite";
|
||
new-invite-password = "dsinvite2";
|
||
invite-time = "30 days";
|
||
};
|
||
jdbc = {
|
||
url = "jdbc:postgresql://localhost:5432/docspell";
|
||
user = "docspell";
|
||
password = "docspell";
|
||
};
|
||
};
|
||
};
|
||
|
||
# install postgresql and initially create user/database
|
||
services.postgresql =
|
||
let
|
||
pginit = pkgs.writeText "pginit.sql" ''
|
||
CREATE USER docspell WITH PASSWORD 'docspell' LOGIN CREATEDB;
|
||
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO docspell;
|
||
GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO docspell;
|
||
CREATE DATABASE DOCSPELL OWNER 'docspell';
|
||
'';
|
||
in {
|
||
enable = true;
|
||
package = pkgs.postgresql_11;
|
||
enableTCPIP = true;
|
||
initialScript = pginit;
|
||
port = 5432;
|
||
authentication = ''
|
||
host all all 0.0.0.0/0 md5
|
||
'';
|
||
};
|
||
|
||
|
||
networking = {
|
||
hostName = "docspellexample";
|
||
firewall.allowedTCPPorts = [7880];
|
||
};
|
||
}
|
||
```
|