mirror of
https://github.com/navidrome/navidrome.git
synced 2026-01-03 06:15:22 +00:00
242 lines
6.3 KiB
Python
242 lines
6.3 KiB
Python
# Code generated by ndpgen. DO NOT EDIT.
|
|
#
|
|
# This file contains client wrappers for the KVStore host service.
|
|
# It is intended for use in Navidrome plugins built with extism-py.
|
|
#
|
|
# IMPORTANT: Due to a limitation in extism-py, you cannot import this file directly.
|
|
# The @extism.import_fn decorators are only detected when defined in the plugin's
|
|
# main __init__.py file. Copy the needed functions from this file into your plugin.
|
|
|
|
from dataclasses import dataclass
|
|
from typing import Any
|
|
|
|
import extism
|
|
import json
|
|
|
|
|
|
class HostFunctionError(Exception):
|
|
"""Raised when a host function returns an error."""
|
|
pass
|
|
|
|
|
|
@extism.import_fn("extism:host/user", "kvstore_set")
|
|
def _kvstore_set(offset: int) -> int:
|
|
"""Raw host function - do not call directly."""
|
|
...
|
|
|
|
|
|
@extism.import_fn("extism:host/user", "kvstore_get")
|
|
def _kvstore_get(offset: int) -> int:
|
|
"""Raw host function - do not call directly."""
|
|
...
|
|
|
|
|
|
@extism.import_fn("extism:host/user", "kvstore_delete")
|
|
def _kvstore_delete(offset: int) -> int:
|
|
"""Raw host function - do not call directly."""
|
|
...
|
|
|
|
|
|
@extism.import_fn("extism:host/user", "kvstore_has")
|
|
def _kvstore_has(offset: int) -> int:
|
|
"""Raw host function - do not call directly."""
|
|
...
|
|
|
|
|
|
@extism.import_fn("extism:host/user", "kvstore_list")
|
|
def _kvstore_list(offset: int) -> int:
|
|
"""Raw host function - do not call directly."""
|
|
...
|
|
|
|
|
|
@extism.import_fn("extism:host/user", "kvstore_getstorageused")
|
|
def _kvstore_getstorageused(offset: int) -> int:
|
|
"""Raw host function - do not call directly."""
|
|
...
|
|
|
|
|
|
@dataclass
|
|
class KVStoreGetResult:
|
|
"""Result type for kvstore_get."""
|
|
value: bytes
|
|
exists: bool
|
|
|
|
|
|
def kvstore_set(key: str, value: bytes) -> None:
|
|
"""Set stores a byte value with the given key.
|
|
|
|
Parameters:
|
|
- key: The storage key (max 256 bytes, UTF-8)
|
|
- value: The byte slice to store
|
|
|
|
Returns an error if the storage limit would be exceeded or the operation fails.
|
|
|
|
Args:
|
|
key: str parameter.
|
|
value: bytes parameter.
|
|
|
|
Raises:
|
|
HostFunctionError: If the host function returns an error.
|
|
"""
|
|
request = {
|
|
"key": key,
|
|
"value": value,
|
|
}
|
|
request_bytes = json.dumps(request).encode("utf-8")
|
|
request_mem = extism.memory.alloc(request_bytes)
|
|
response_offset = _kvstore_set(request_mem.offset)
|
|
response_mem = extism.memory.find(response_offset)
|
|
response = json.loads(extism.memory.string(response_mem))
|
|
|
|
if response.get("error"):
|
|
raise HostFunctionError(response["error"])
|
|
|
|
|
|
|
|
def kvstore_get(key: str) -> KVStoreGetResult:
|
|
"""Get retrieves a byte value from storage.
|
|
|
|
Parameters:
|
|
- key: The storage key
|
|
|
|
Returns the value and whether the key exists.
|
|
|
|
Args:
|
|
key: str parameter.
|
|
|
|
Returns:
|
|
KVStoreGetResult containing value, exists,.
|
|
|
|
Raises:
|
|
HostFunctionError: If the host function returns an error.
|
|
"""
|
|
request = {
|
|
"key": key,
|
|
}
|
|
request_bytes = json.dumps(request).encode("utf-8")
|
|
request_mem = extism.memory.alloc(request_bytes)
|
|
response_offset = _kvstore_get(request_mem.offset)
|
|
response_mem = extism.memory.find(response_offset)
|
|
response = json.loads(extism.memory.string(response_mem))
|
|
|
|
if response.get("error"):
|
|
raise HostFunctionError(response["error"])
|
|
|
|
return KVStoreGetResult(
|
|
value=response.get("value", b""),
|
|
exists=response.get("exists", False),
|
|
)
|
|
|
|
|
|
def kvstore_delete(key: str) -> None:
|
|
"""Delete removes a value from storage.
|
|
|
|
Parameters:
|
|
- key: The storage key
|
|
|
|
Returns an error if the operation fails. Does not return an error if the key doesn't exist.
|
|
|
|
Args:
|
|
key: str parameter.
|
|
|
|
Raises:
|
|
HostFunctionError: If the host function returns an error.
|
|
"""
|
|
request = {
|
|
"key": key,
|
|
}
|
|
request_bytes = json.dumps(request).encode("utf-8")
|
|
request_mem = extism.memory.alloc(request_bytes)
|
|
response_offset = _kvstore_delete(request_mem.offset)
|
|
response_mem = extism.memory.find(response_offset)
|
|
response = json.loads(extism.memory.string(response_mem))
|
|
|
|
if response.get("error"):
|
|
raise HostFunctionError(response["error"])
|
|
|
|
|
|
|
|
def kvstore_has(key: str) -> bool:
|
|
"""Has checks if a key exists in storage.
|
|
|
|
Parameters:
|
|
- key: The storage key
|
|
|
|
Returns true if the key exists.
|
|
|
|
Args:
|
|
key: str parameter.
|
|
|
|
Returns:
|
|
bool: The result value.
|
|
|
|
Raises:
|
|
HostFunctionError: If the host function returns an error.
|
|
"""
|
|
request = {
|
|
"key": key,
|
|
}
|
|
request_bytes = json.dumps(request).encode("utf-8")
|
|
request_mem = extism.memory.alloc(request_bytes)
|
|
response_offset = _kvstore_has(request_mem.offset)
|
|
response_mem = extism.memory.find(response_offset)
|
|
response = json.loads(extism.memory.string(response_mem))
|
|
|
|
if response.get("error"):
|
|
raise HostFunctionError(response["error"])
|
|
|
|
return response.get("exists", False)
|
|
|
|
|
|
def kvstore_list(prefix: str) -> Any:
|
|
"""List returns all keys matching the given prefix.
|
|
|
|
Parameters:
|
|
- prefix: Key prefix to filter by (empty string returns all keys)
|
|
|
|
Returns a slice of matching keys.
|
|
|
|
Args:
|
|
prefix: str parameter.
|
|
|
|
Returns:
|
|
Any: The result value.
|
|
|
|
Raises:
|
|
HostFunctionError: If the host function returns an error.
|
|
"""
|
|
request = {
|
|
"prefix": prefix,
|
|
}
|
|
request_bytes = json.dumps(request).encode("utf-8")
|
|
request_mem = extism.memory.alloc(request_bytes)
|
|
response_offset = _kvstore_list(request_mem.offset)
|
|
response_mem = extism.memory.find(response_offset)
|
|
response = json.loads(extism.memory.string(response_mem))
|
|
|
|
if response.get("error"):
|
|
raise HostFunctionError(response["error"])
|
|
|
|
return response.get("keys", None)
|
|
|
|
|
|
def kvstore_get_storage_used() -> int:
|
|
"""GetStorageUsed returns the total storage used by this plugin in bytes.
|
|
|
|
Returns:
|
|
int: The result value.
|
|
|
|
Raises:
|
|
HostFunctionError: If the host function returns an error.
|
|
"""
|
|
request_bytes = b"{}"
|
|
request_mem = extism.memory.alloc(request_bytes)
|
|
response_offset = _kvstore_getstorageused(request_mem.offset)
|
|
response_mem = extism.memory.find(response_offset)
|
|
response = json.loads(extism.memory.string(response_mem))
|
|
|
|
if response.get("error"):
|
|
raise HostFunctionError(response["error"])
|
|
|
|
return response.get("bytes", 0)
|