mirror of
https://git.asonix.dog/asonix/pict-rs
synced 2025-01-08 18:51:24 +00:00
Add a note about imagemagick 7 on ubuntu and debian, add Nix installation method
This commit is contained in:
parent
4680f9c3aa
commit
ee7bd192c4
1 changed files with 30 additions and 0 deletions
30
README.md
30
README.md
|
@ -11,6 +11,7 @@ _a simple image hosting service_
|
||||||
1. [Distro Package](#distro-package)
|
1. [Distro Package](#distro-package)
|
||||||
2. [Binary Download](#binary-download)
|
2. [Binary Download](#binary-download)
|
||||||
3. [Compile from Source](#compile-from-source)
|
3. [Compile from Source](#compile-from-source)
|
||||||
|
4. [Nix](#nix)
|
||||||
2. [Api](#api)
|
2. [Api](#api)
|
||||||
3. [Administration](#administration)
|
3. [Administration](#administration)
|
||||||
1. [Backups](#backups)
|
1. [Backups](#backups)
|
||||||
|
@ -245,6 +246,10 @@ make sure that you have the following dependencies installed:
|
||||||
These binaries are called by pict-rs to process uploaded media, so they must be in the `$PATH`
|
These binaries are called by pict-rs to process uploaded media, so they must be in the `$PATH`
|
||||||
available to pict-rs.
|
available to pict-rs.
|
||||||
|
|
||||||
|
A notable issue here is imagemagick 7, which is not packaged in Debian Sid and therefore unavailable
|
||||||
|
in any version of Debian or Ubuntu. If you are running an ubuntu or debian system, consider using
|
||||||
|
the [Nix](#nix) installation and run method.
|
||||||
|
|
||||||
##### Compile from Source
|
##### Compile from Source
|
||||||
pict-rs can be compiled from source using a recent version of the rust compiler. I do development
|
pict-rs can be compiled from source using a recent version of the rust compiler. I do development
|
||||||
and produce releases on 1.70. pict-rs also requires the `protoc` protobuf compiler to be present at
|
and produce releases on 1.70. pict-rs also requires the `protoc` protobuf compiler to be present at
|
||||||
|
@ -253,6 +258,31 @@ build-time in order to enable use of [`tokio-console`](https://github.com/tokio-
|
||||||
Like the Binary Download option, `imagemagick`, `ffmpeg`, and `exiftool` must be installed for
|
Like the Binary Download option, `imagemagick`, `ffmpeg`, and `exiftool` must be installed for
|
||||||
pict-rs to run properly.
|
pict-rs to run properly.
|
||||||
|
|
||||||
|
##### Nix
|
||||||
|
pict-rs comes with an associated nix flake. This is useful for the development environment, but can
|
||||||
|
also be used to run a "production" version of pict-rs with all the neccessary dependencies already
|
||||||
|
provided.
|
||||||
|
|
||||||
|
The Nix package manager can be installed with [these instructions](https://nixos.org/download.html).
|
||||||
|
After installation, two experimental features must be enabled: `flake` and `nix-command`. These need
|
||||||
|
to be added in `/etc/nix/nix.conf`:
|
||||||
|
```
|
||||||
|
experimental-features = nix-command flakes
|
||||||
|
```
|
||||||
|
|
||||||
|
After enabling flakes, you can run `nix build` from the pict-rs source directory. This will produce
|
||||||
|
a nix package containing pict-rs and its dependencies. It will also create a `result` symlink in the
|
||||||
|
pict-rs directory that links to the newly built package. The contents of `result` should be a single
|
||||||
|
folder `bin` with a single file `pict-rs` inside. This file is a shell script that invokes the
|
||||||
|
`pict-rs` binary with the required `$PATH` to find imagemagick 7, ffmpeg 6, and exiftool. You can
|
||||||
|
treat this shell script as if it were the true pict-rs binary, passing it the same arguments you
|
||||||
|
would pict-rs.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
```
|
||||||
|
./result/bin/pict-rs -c dev.toml run
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
### API
|
### API
|
||||||
pict-rs offers the following endpoints:
|
pict-rs offers the following endpoints:
|
||||||
|
|
Loading…
Reference in a new issue