Mirror of sanic. Find the original here: https://gitlab.com/XenGi/sanic
				https://sanic.club.berlin.ccc.de
			
		| .forgejo/workflows | ||
| static | ||
| .editorconfig | ||
| .gitignore | ||
| architecture.drawio.svg | ||
| cert.pem | ||
| config.ini | ||
| Dockerfile | ||
| favicon.xcf | ||
| flake.lock | ||
| flake.nix | ||
| go.mod | ||
| go.sum | ||
| gomod2nix.toml | ||
| key.pem | ||
| LICENSE | ||
| Makefile | ||
| mpd.conf | ||
| mpd.go | ||
| NOTES.md | ||
| README.md | ||
| server.go | ||
🦔 sanic
chaos music control inspired by relaxx player
✨ Features
- mpd web gui
- search music
- organize playlists
- control current playback queue
 
- no authentication required to control music playback
- add playlists from internet radios (*.m3u,*.pls)
- add music from other sources like youtube (youtube-dl)
🛠️ Development
sanic is developed using Nix, but you can also just use the usual Golang tooling.
Run local MPD instance for testing with make mpd.
Update go depdendencies like this:
go get -u  # or `make update`
go mod tidy  # or `make tidy`
gomod2nix
❄️ w/ Nix
Enter development shell (also has mpc client installed for testing):
nix develop
Build nix flake:
nix build
🐧 w/o Nix
Use these Make targets for convenience:
- run: Run project
- build: Compile project
- tidy: Add missing and remove unused modules
- verify: Verify dependencies have expected content
- test: Run tests
- cert: Create https certificate for local testing
🐳 Container
You can run sanic in a container. Use these Make targets for convenience:
- build-container: Build container image
- run-container: Run container image