DEV Community

nabbisen
nabbisen

Posted on • Edited on • Originally published at obsd.solutions

pict-rs 0.3.2 on OpenBSD 7.2: Install

Summary

This post is a part of Lemmy 0.16.7 on OpenBSD 7.2 about Lemmy.

Premise

The server is OpenBSD and Rust (rustlang) is installed. Also, there is _lemmy user whose home directory is /var/lemmy.

Environment

  • OS: OpenBSD 7.2
  • Object Storage: MinIO - AWS S3-compatible (Optional)
  • Apps
    • pict-rs: 0.3.2
    • based on Rust 1.63 + Actix Web 4 + Actix 0.13

Tutorial

pict-rs server

Lemmy uses pict-rs to store image. It is a simple image hosting service which is open source and written in Rust, too.

Prepare for the dependencies

You have to install protobuf, "Protocol Buffers - Google's data interchange format"

Therefore switch back to your own user if you are acting as _lemmy to install it:

$ exit  $ doas pkg_add protobuf 
Enter fullscreen mode Exit fullscreen mode

The output was:

quirks-6.42 signed on 2023-01-13T18:22:41Z protobuf-3.21.6: ok 
Enter fullscreen mode Exit fullscreen mode

Build pict-rs server

Switch to _lemmy:

$ doas su - _lemmy 
Enter fullscreen mode Exit fullscreen mode

Get the source of the stable version (v0.4 didn't work in my case):

$ git clone https://git.asonix.dog/asonix/pict-rs.git --branch v0.3.2 --single-branch 
Enter fullscreen mode Exit fullscreen mode

The output was:

Cloning into 'pict-rs'... remote: Enumerating objects: 2707, done. remote: Counting objects: 100% (2707/2707), done. remote: Compressing objects: 100% (1932/1932), done. remote: Total 2707 (delta 1806), reused 1077 (delta 687), pack-reused 0 Receiving objects: 100% (2707/2707), 2.21 MiB | 114.00 KiB/s, done. Resolving deltas: 100% (1806/1806), done. Note: switching to '4dff8de9851041911b8243a35bf9f6df4d612268'. You are in 'detached HEAD' state. You can look around, make experimental changes and commit them, and you can discard any commits you make in this state without impacting any branches by switching back to a branch. (...) 
Enter fullscreen mode Exit fullscreen mode

Go inside:

$ cd pict-rs 
Enter fullscreen mode Exit fullscreen mode

Then run to build:

$ cargo build --release 
Enter fullscreen mode Exit fullscreen mode

The output was:

 Updating git repository `https://github.com/asonix/rust-s3` (...) Compiling rustls v0.20.6 (...) Compiling actix-web v4.1.0 (...) Compiling pict-rs v0.3.2 (/var/lemmy/pict-rs) Finished release [optimized] target(s) in 20m 35s 
Enter fullscreen mode Exit fullscreen mode

Now you can run pict-rs server with -p option to specify data directory:

$ cargo run --release -- -p data 
Enter fullscreen mode Exit fullscreen mode

The output was:

 Finished release [optimized] target(s) in 0.24s Running `target/release/pict-rs -p data` 2023-01-14T12:51:58.377271Z INFO restructure{store=FileStore { path_gen: "generator", root_dir: "data" }}: pict_rs::store::file_store::restructure: new 2023-01-14T12:51:58.377478Z INFO restructure{store=FileStore { path_gen: "generator", root_dir: "data" }}: pict_rs::store::file_store::restructure: close time.busy=11.3µs time.idle=197µs 2023-01-14T12:51:58.377627Z INFO actix_server::builder: Starting 1 workers 2023-01-14T12:51:58.377736Z INFO actix_server::server: Actix runtime found; starting in Actix runtime 
Enter fullscreen mode Exit fullscreen mode

Additionally, you can specify address to listen:

$ cargo run --release -- -a 127.0.0.1:8080 -p data 
Enter fullscreen mode Exit fullscreen mode

Additionally, you can modify its configuration:

$ nvim pict-rs.toml 
Enter fullscreen mode Exit fullscreen mode

For example:

- api_key = 'API_KEY'  - image_format = 'jpeg'  - opentelemetry_url = 'http://localhost:4317/' + opentelemetry_url = 'http://127.0.0.1:4317/' 
Enter fullscreen mode Exit fullscreen mode
Integrate pict-rs with MinIO (Optional)

pict-rs stores image files in their local directory by default.

Well, there is a way to introduce MinIO bucket usage by editting pict-rc.toml as below:

- type = "file_store" + type = "s3_store" + + region = "https://(minio-fqdn)" + bucket_name = "(...)" + access_key = "(...)" + secret_key = "(...)" 
Enter fullscreen mode Exit fullscreen mode

and, of course, creating MinIO bucket and service account, with bucket policy like:

{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "admin:*" ] }, { "Effect": "Allow", "Action": [ "s3:*" ], "Resource": [ "arn:aws:s3:::{bucket-name}", "arn:aws:s3:::{bucket-name}/*" ] } ] } 
Enter fullscreen mode Exit fullscreen mode

Conclusion

Well done :) Go on to the next step.

[Return](https://obsd.solutions/en/blog/2023/01/15/lemmy-0167-on-openbsd-72/index.html)

Top comments (0)