Dim, a media manager fueled by dark forces

rodrimarchese 040f5f8488 add loader when creating a library 1 year ago
.cargo 3b5b711dd6 build: allow compiling dim by defaulting DATABASE_URL to target/dim_dev.db 1 year ago
.github bd8754799a Re-enabling multiarch support (#456) 1 year ago
.vscode 3fde64a02f refactor(db): rewrite user.rs 3 years ago
auth d85f847ca2 dim: raise fd limits to max allowed 1 year ago
database 3b5b711dd6 build: allow compiling dim by defaulting DATABASE_URL to target/dim_dev.db 1 year ago
dim b70391d109 return library id on creation 1 year ago
docs 89c1a2623f Reduce size of design images 15x 2 years ago
events d85f847ca2 dim: raise fd limits to max allowed 1 year ago
extra a025615a6e added some extras needed for compilation on windows to work 3 years ago
ui 040f5f8488 add loader when creating a library 1 year ago
.dockerignore e3c11f9144 Fix dockerfile, start.sh and build.rs 3 years ago
.gitattributes 6f89227c26 track lfs 3 years ago
.gitignore dffbcf3ef4 Refactor scanners (#447) 1 year ago
.mailmap 8bc8cce20f chore: add mailmap 2 years ago
.rgignore 4e5b077016 forgot to remove the constraint lol 3 years ago
CONTRIBUTING.md 671ccb8acf update CONTRIBUTING.md 3 years ago
Cargo.lock d85f847ca2 dim: raise fd limits to max allowed 1 year ago
Cargo.toml d85f847ca2 dim: raise fd limits to max allowed 1 year ago
Dockerfile bd8754799a Re-enabling multiarch support (#456) 1 year ago
LICENSE.md 1bcb31ccf0 chore(license): change the license for dim from GPLv2 to AGPLv3 (#439) 2 years ago
README.md 843fc2cee4 chore(licence): update README.md to align with new licence (#452) 2 years ago
deny.toml c00ee8fd83 Added a deny lint file 4 years ago
docker-compose-template.yml a457534f36 Fix template docker-compose file (#412) 2 years ago
rust-toolchain dffbcf3ef4 Refactor scanners (#447) 1 year ago
yarn.lock 3232e926e0 Implement new matching/rematching UI (#420) 2 years ago

README.md

Dim

Dashboard Discord

Dim is a self-hosted media manager. With minimal setup, Dim will organize and beautify your media collections, letting you access and play them anytime from anywhere.

Running from binaries

Dependencies

  • libva2
  • libva-drm2
  • libharfbuzz
  • libfontconfig
  • libfribidi
  • libtheora
  • libvorbis
  • libvorbisenc
  • libtheora0

You can then obtain binaries from the release tab in github:

  1. Unpack with unzip ./release-linux.zip && tar -xvzf ./release.tar.gz
  2. Run cd release && ./dim
  3. Then you can access the Dim web UI through your browser with http://0.0.0.0:8000 (assuming it's running locally.)

Running with docker

The following command runs dim on port 8000, storing configuration in $HOME/.config/dim. You may change that path if you'd like to store configuration somewhere else. You can mount as many directories containing media as you like by repeating the -v HOST_PATH:CONTAINER_PATH option. In this example, the path /media on the host is made available at the same path inside the Docker container. This name "media" is arbitrary and you can choose whatever you like.

docker run -d -p 8000:8000/tcp -v $HOME/.config/dim:/opt/dim/config -v /media:/media:ro ghcr.io/dusk-labs/dim:dev

To use hardware acceleration, mount the relevant device:

docker run -d -p 8000:8000/tcp -v $HOME/.config/dim:/opt/dim/config -v /media:/media:ro --device=/dev/dri/renderD128 ghcr.io/dusk-labs/dim:dev

Refer to docker-compose-template.yaml to run dim using Docker Compose.

Running from source

Dependencies

To run from source, you'll first need to install the following dependencies on your system:

  • sqlite
  • cargo
  • rustc (nightly)
  • yarn, npm
  • libssl-dev
  • libva2 (only if you're using Linux)
  • libva-dev (only if you're using Linux)
  • libva-drm2 (only if you're using Linux)
  • ffmpeg

Once the dependencies are installed, clone the repository and build the project:

git clone https://github.com/Dusk-Labs/dim
yarn --cwd ui/ && yarn --cwd ui/ build
mkdir utils && ln -nfs $(which ffmpeg) utils/ffmpeg && ln -nfs $(which ffprobe) utils/ffprobe

If you're on Linux, run dim with:

cargo run --features vaapi --release

On other platforms where libva isn't available, run dim with:

cargo run --release

License

Dim is licensed under the AGPLv3 license (see LICENSE.md or https://opensource.org/licenses/AGPL-3.0)

Screenshots

Login_Page Add_Library Modal Media_Page