sugarcraft/sugar-skate

PHP port of charmbracelet/skate — a personal key/value store with multi-database support, binary data, and glob/list filtering.

Maintainers

Package info

github.com/sugarcraft/sugar-skate

pkg:composer/sugarcraft/sugar-skate

Statistics

Installs: 0

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

v0.2.0 2026-05-07 01:36 UTC

This package is not auto-updated.

Last update: 2026-05-07 14:55:31 UTC


README

sugar-skate

CI codecov Packagist Version License PHP

SugarSkate

PHP port of charmbracelet/skate — a personal key/value store with multi-database support, binary data handling, and glob/list filtering.

Features

  • Multi-database — separate stores with @dbname suffix, auto-created on first use
  • Binary data — safely stores and retrieves raw binary (images, files) via base64 encoding
  • Glob pattern matching — list/get/delete keys using * and ? wildcards
  • Ordered listing — forward or reverse lexicographic order
  • Flexible listing — keys only, values only, or key-value pairs
  • SQLite-backed — one SQLite DB per database, stored in $XDG_CONFIG_HOME/skate/ or ~/.config/skate/
  • PHP 8.1+ — pure PHP, no extension required beyond SQLite (php-sqlite3)
  • Iterable streams — list() yields results without loading everything into memory

Install

composer require sugarcraft/sugar-skate

Quick Start

use SugarCraft\Skate\Store;

$skate = new Store();

// Set and get
$skate->set('greeting', 'Hello, World!');
echo $skate->get('greeting'); // Hello, World!

// With a database
$skate->set('token', 'ghp_xxxx', 'passwords');
echo $skate->get('token', 'passwords');

// List all keys
foreach ($skate->list() as $entry) {
    echo "{$entry->key} => {$entry->value}\n";
}

// Glob patterns
foreach ($skate->list(pattern: 'user-*') as $entry) { ... }

// Delete
$skate->delete('greeting');

CLI

skate set <key> [value]          # Set a key
skate get <key>                  # Get a value
skate list [-k|-v] [-r] [-d delim] [pattern]  # List entries
skate delete <key>               # Delete a key
skate list-dbs                   # Show all databases

Data Directory

Default: ~/.config/skate/ (respects $XDG_CONFIG_HOME).

Each database gets its own SQLite file: ~/.config/skate/<dbname>.db.

License

MIT