Compare commits

...

11 Commits
tui ... master

Author SHA1 Message Date
fde738910d
README: update project url 2025-01-06 16:53:15 +01:00
546d921ec4 flake.lock: Update
Flake lock file updates:

• Updated input 'nixpkgs':
    'github:NixOS/nixpkgs/d8fe5e6c92d0d190646fb9f1056741a229980089' (2024-03-29)
  → 'github:NixOS/nixpkgs/c04d5652cfa9742b1d519688f65d1bbccea9eb7e' (2024-09-19)
2024-09-20 21:52:14 +02:00
cb292a56b1 Merge pull request 'webui: handle playback_pos response with empty contents' (#13) from handle-empty-playback-pos-response into master
Reviewed-on: Projects/grzegorz-clients#13
Reviewed-by: Peder Bergebakken Sundt <pederbs@pvv.ntnu.no>
2024-08-05 21:16:57 +02:00
132cabf434
webui: handle playback_pos response with empty contents 2024-08-05 17:53:15 +02:00
4617f83f5c Merge pull request 'cli: fix relative volume adjustment' (#12) from fix-new-cli-features into master
Reviewed-on: Projects/grzegorz-clients#12
2024-06-02 02:38:17 +02:00
047d09ffb1 cli: fix relative volume adjustment 2024-05-25 23:58:08 +02:00
b9444658fb
Merge pull request #11 from Programvareverkstedet/more_cli_features
More stuff please
2024-05-19 12:48:15 +02:00
0c45cbe1f6 flake: add grzegorzctl-only package which installs shell-completions 2024-05-19 06:39:23 +02:00
ca78aa9e22 cli: allow relative volume adjustment using {+,-}<n>{,%} 2024-05-19 06:15:54 +02:00
2b8ecf124d cli: add function to toggle playback status 2024-05-19 06:15:54 +02:00
1009b29995 cli: fix spelling error in queue adding commands 2024-05-19 06:07:52 +02:00
5 changed files with 43 additions and 13 deletions

View File

@ -13,7 +13,7 @@ A set of simple API endpoints and ready-to-go clients to interface with the [Grz
## How to run this ## How to run this
pip install --user git+https://github.com/Programvareverkstedet/grzegorz_clients.git#master pip install --user git+https://git.pvv.ntnu.no/Grzegorz/grzegorz-clients.git#master
### cli ### cli
@ -23,7 +23,7 @@ A set of simple API endpoints and ready-to-go clients to interface with the [Grz
As the user intended to run the server: As the user intended to run the server:
pip install --user git+https://github.com/Programvareverkstedet/grzegorz_clients.git#master pip install --user git+https://git.pvv.ntnu.no/Grzegorz/grzegorz-clients.git#master
grzegorz-webui --host-name 0.0.0.0 --port 80 grzegorz-webui --host-name 0.0.0.0 --port 80
It's rather insecure and could use a reverse proxy and some whitelisting. ;) It's rather insecure and could use a reverse proxy and some whitelisting. ;)

6
flake.lock generated
View File

@ -2,11 +2,11 @@
"nodes": { "nodes": {
"nixpkgs": { "nixpkgs": {
"locked": { "locked": {
"lastModified": 1711703276, "lastModified": 1726755586,
"narHash": "sha256-iMUFArF0WCatKK6RzfUJknjem0H9m4KgorO/p3Dopkk=", "narHash": "sha256-PmUr/2GQGvFTIJ6/Tvsins7Q43KTMvMFhvG6oaYK+Wk=",
"owner": "NixOS", "owner": "NixOS",
"repo": "nixpkgs", "repo": "nixpkgs",
"rev": "d8fe5e6c92d0d190646fb9f1056741a229980089", "rev": "c04d5652cfa9742b1d519688f65d1bbccea9eb7e",
"type": "github" "type": "github"
}, },
"original": { "original": {

View File

@ -57,14 +57,28 @@
nativeBuildInputs = [ poetry-core ]; nativeBuildInputs = [ poetry-core ];
propagatedBuildInputs = [ setuptools flakes.self.pkgs.remi requests typer rich urllib3 ]; propagatedBuildInputs = [ setuptools flakes.self.pkgs.remi requests typer rich urllib3 ];
}; };
default = flakes.self.pkgs.grzegorz-clients; grzegorzctl = pkgs.runCommandNoCCLocal "grzegorzctl" (
{
nativeBuildInputs = [ pkgs.installShellFiles ];
} //
{ inherit (flakes.self.pkgs.grzegorz-clients) meta; } //
{ meta.mainProgram = "grzegorzctl"; }
)''
mkdir -p $out/bin
ln -s "${flakes.self.pkgs.grzegorz-clients}/bin/grzegorzctl" $out/bin/grzegorzctl
installShellCompletion --cmd grzegorzctl \
--bash <($out/bin/grzegorzctl --show-completion bash) \
--zsh <($out/bin/grzegorzctl --show-completion zsh) \
--fish <($out/bin/grzegorzctl --show-completion fish)
'';
default = flakes.self.pkgs.grzegorzctl;
}); });
apps = forAllSystems ({ system, ...}: rec { apps = forAllSystems ({ system, ...}: rec {
grzegorz-webui.type = "app"; grzegorz-webui.type = "app";
grzegorz-webui.program = "${self.packages.${system}.grzegorz-clients}/bin/grzegorz-webui"; grzegorz-webui.program = "${self.packages.${system}.grzegorz-clients}/bin/grzegorz-webui";
grzegorzctl.type = "app"; grzegorzctl.type = "app";
grzegorzctl.program = "${self.packages.${system}.grzegorz-clients}/bin/grzegorzctl"; grzegorzctl.program = "${self.packages.${system}.grzegorzctl}/bin/grzegorzctl";
default = grzegorzctl; default = grzegorzctl;
}); });

View File

@ -64,7 +64,7 @@ def _add(
api.playlist_goto(current_index if put_pre else current_index + 1) api.playlist_goto(current_index if put_pre else current_index + 1)
api.set_playing(True) api.set_playing(True)
@cli.command(help="Add one ore more items to the playlist") @cli.command(help="Add one or more items to the playlist")
def play( def play(
urls: list[str], urls: list[str],
pre: bool = False, pre: bool = False,
@ -72,14 +72,14 @@ def play(
): ):
_add(urls, put_post=not pre, put_pre=pre, play=True, api_base=api_base) _add(urls, put_post=not pre, put_pre=pre, play=True, api_base=api_base)
@cli.command(help="Add one ore more items to the playlist") @cli.command(help="Add one or more items to the playlist")
def next( def next(
urls: list[str], urls: list[str],
api_base: str = DEFAULT_API_BASE, api_base: str = DEFAULT_API_BASE,
): ):
_add(urls, put_post=True, api_base=api_base) _add(urls, put_post=True, api_base=api_base)
@cli.command(help="Add one ore more items to the playlist") @cli.command(help="Add one or more items to the playlist")
def queue( def queue(
urls: list[str], urls: list[str],
play: bool = True, play: bool = True,
@ -107,6 +107,12 @@ def pause( api_base: str = DEFAULT_API_BASE ):
api.set_endpoint(api_base) api.set_endpoint(api_base)
rich.print(api.set_playing(False), file=sys.stderr) rich.print(api.set_playing(False), file=sys.stderr)
@cli.command(help="Toggle playback")
def toggle(api_base: str = DEFAULT_API_BASE):
api.set_endpoint(api_base)
playing = api.is_playing()
rich.print(api.set_playing(not playing), file=sys.stderr)
@cli.command(help="Goto next item in playlist") @cli.command(help="Goto next item in playlist")
def skip( api_base: str = DEFAULT_API_BASE ): def skip( api_base: str = DEFAULT_API_BASE ):
api.set_endpoint(api_base) api.set_endpoint(api_base)
@ -154,11 +160,21 @@ def status(
@cli.command(help="Set the playback volume") @cli.command(help="Set the playback volume")
def set_volume( def set_volume(
volume: int, volume: str,
api_base: str = DEFAULT_API_BASE, api_base: str = DEFAULT_API_BASE,
): ):
api.set_endpoint(api_base) api.set_endpoint(api_base)
rich.print(api.set_volume(volume), file=sys.stderr)
volume = volume.removesuffix("%")
if volume.startswith("+") or volume.startswith("-"):
current_volume = api.get_volume()
new_volume = max(0, min(100, current_volume + int(volume)))
new_volume = int(new_volume)
else:
new_volume = int(volume)
rich.print(api.set_volume(new_volume), file=sys.stderr)
if __name__ == "__main__": if __name__ == "__main__":

View File

@ -294,7 +294,7 @@ class RemiApp(App):
except api.APIError: except api.APIError:
playback_pos = None playback_pos = None
if playback_pos: if playback_pos and isinstance(playback_pos, dict) and playback_pos["current"] and playback_pos["total"]:
slider_pos = playback_pos["current"] / playback_pos["total"] * 100 slider_pos = playback_pos["current"] / playback_pos["total"] * 100
current = seconds_to_timestamp(playback_pos["current"]) current = seconds_to_timestamp(playback_pos["current"])
total = seconds_to_timestamp(playback_pos["total"]) total = seconds_to_timestamp(playback_pos["total"])