Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Dusk-Labs/dim
Dim, a media manager fueled by dark forces.
https://github.com/Dusk-Labs/dim
mediamanager reactjs rust rust-lang
Last synced: 2 months ago
JSON representation
Dim, a media manager fueled by dark forces.
- Host: GitHub
- URL: https://github.com/Dusk-Labs/dim
- Owner: Dusk-Labs
- License: agpl-3.0
- Created: 2021-01-08T18:40:39.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2024-08-08T13:42:21.000Z (5 months ago)
- Last Synced: 2024-10-29T15:03:19.324Z (2 months ago)
- Topics: mediamanager, reactjs, rust, rust-lang
- Language: Rust
- Homepage:
- Size: 78.3 MB
- Stars: 3,802
- Watchers: 44
- Forks: 161
- Open Issues: 156
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Security: SECURITY.md
Awesome Lists containing this project
- awesome - Dusk-Labs/dim - Dim, a media manager fueled by dark forces. (Rust)
- awesome-pt - Dim
- awesome-github-repos - Dusk-Labs/dim - Dim, a media manager fueled by dark forces. (Rust)
- my-awesome - Dusk-Labs/dim - lang pushed_at:2024-08 star:3.9k fork:0.2k Dim, a media manager fueled by dark forces. (Rust)
README
Dim
![Dashboard](docs/design/dashboard.jpg)
[![Discord](https://img.shields.io/discord/834495310332035123)](https://discord.gg/gBPyQ7NVah)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
* libtheora0You 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
```
Mutiarch image resides at `ghcr.io/dusk-labs/dim:master`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](https://github.com/Dusk-Labs/dim/blob/master/docker-compose-template.yml) 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)
* ffmpegOnce 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](LICENSE.md) or https://opensource.org/licenses/AGPL-3.0)
## Screenshots
![Login_Page](docs/design/login_page.png)
![Add_Library Modal](docs/design/add_library.png)
![Media_Page](docs/design/media_page.jpg)