Skip to content

tamnd/deezer-cli

Repository files navigation

deezer

A command line for deezer.

deezer is a single pure-Go binary. It reads public deezer data over plain HTTPS, shapes it into clean records, and prints output that pipes into the rest of your tools. No API key, nothing to run alongside it.

The same package is also a resource-URI driver, so a host program like ant can address deezer as deezer:// URIs.

Install

go install github.com/tamnd/deezer-cli/cmd/deezer@latest

Or grab a prebuilt binary from the releases, or run the container image:

docker run --rm ghcr.io/tamnd/deezer:latest --help

Usage

deezer page <path>                      # fetch one page as a record
deezer page <path> -o json              # as JSON, ready for jq
deezer page <path> --template '{{.Body}}'  # just the readable body text
deezer links <path>                     # the pages it links to, one per line
deezer --help                           # the whole command tree

Every command shares one output contract: -o table|json|jsonl|csv|tsv|url|raw, --fields to pick columns, --template for a custom line, and -n to limit. The default adapts to where output goes (a table on a terminal, JSONL in a pipe), so the same command reads well by hand and parses cleanly downstream.

This is a fresh scaffold. It ships one example resource type, page, wired end to end. Model the real deezer records in deezer/ and declare their operations in deezer/domain.go; each one becomes a command, an HTTP route, and an MCP tool at once.

Serve it

The same operations are available over HTTP and as an MCP tool set for agents, with no extra code:

deezer serve --addr :7777    # GET /v1/page/<path>  returns NDJSON
deezer mcp                   # speak MCP over stdio

Use it as a resource-URI driver

deezer registers a deezer domain the way a program registers a database driver with database/sql. A host enables it with one blank import:

import _ "github.com/tamnd/deezer-cli/deezer"

Then ant (or any program that links the package) dereferences deezer:// URIs without knowing anything about deezer:

ant get deezer://page/<path>   # fetch the record
ant cat deezer://page/<path>   # just the body text
ant ls  deezer://page/<path>   # the pages it links to, each addressable
ant url deezer://page/<path>   # the live https URL

Development

cmd/deezer/   thin main: hands cli.NewApp to kit.Run
cli/                 assembles the kit App from the deezer domain
deezer/                the library: HTTP client, data models, and domain.go (the driver)
docs/                tago documentation site
make build      # ./bin/deezer
make test       # go test ./...
make vet        # go vet ./...

Releasing

Push a version tag and GitHub Actions runs GoReleaser, which builds the archives, Linux packages, the multi-arch GHCR image, checksums, SBOMs, and a cosign signature:

git tag v0.1.0
git push --tags

The Homebrew and Scoop steps self-disable until their tokens exist, so the first release works with no extra secrets.

License

Apache-2.0. See LICENSE.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors