Skip to main content

Channel engagement currency microservice for CyTube channels

Project description

kryten-economy

Python 3.11+ License: MIT Tests

Channel engagement currency microservice for CyTube, built on the kryten ecosystem.

What It Does

kryten-economy turns passive viewers into active participants by rewarding channel presence, chat activity, and social interaction with Z-Coins — a fully configurable virtual currency. Users spend Z on queueing media, vanity items, tipping, and gambling. A B-movie-themed rank system (Extra → Stunt Double → … → Director) grants real perks like queue discounts and extra queue slots.

Feature Highlights

  • Presence earning — per-minute Z rewards with night-watch bonuses and hourly milestones
  • Chat triggers — 12+ earning triggers for long messages, kudos, laughs, conversation starters, and more
  • Daily streaks — consecutive-day bonuses with milestone multipliers and bridge recovery
  • Gambling — slot machine, coin flip, player duels, and cooperative channel heists
  • Media queue — search and queue content from a MediaCMS instance, paid with Z
  • Tipping — alias-aware peer-to-peer transfers with self-tip prevention
  • Vanity shop — custom greetings, chat colors, titles, channel GIFs (with admin approval)
  • Achievements — one-time badges with Z rewards for milestones
  • Rank progression — automatic rank-ups with CyTube rank promotions
  • Multiplier events — scheduled and ad-hoc earning multipliers, daily competitions, user bounties
  • Admin tooling — 16 admin commands for grants, bans, economy health, trigger analytics, config hot-reload
  • Monitoring — Prometheus metrics endpoint with per-trigger, per-command, and per-channel gauges

Everything is configurable via a single YAML file — every rate, threshold, reward, cost, and message template.

Requirements

  • Python 3.11+
  • NATS server (via kryten infrastructure)
  • kryten-py >= 0.11.5 — CyTube ↔ NATS client library
  • kryten-robot — event source bridging CyTube websocket events to NATS
  • kryten-userstats — alias resolution for tip self-transfer prevention
  • Optional: MediaCMS instance for content queue features

Installation

From PyPI

pip install kryten-economy

From GitHub

pip install git+https://github.com/grobertson/kryten-economy.git

Development Install

git clone https://github.com/grobertson/kryten-economy.git
cd kryten-economy
python -m venv .venv
source .venv/bin/activate   # Linux/macOS
# .venv\Scripts\activate    # Windows
pip install -e ".[dev]"

Quick Start

# 1. Copy the example config
cp config.example.yaml config.yaml

# 2. Edit with your NATS and channel settings
$EDITOR config.yaml

# 3. Run
kryten-economy --config config.yaml

# Or as a module
python -m kryten_economy --config config.yaml

systemd Deployment

sudo cp systemd/kryten-economy.service /etc/systemd/system/
sudo systemctl daemon-reload
sudo systemctl enable --now kryten-economy

The included service file has resource limits (MemoryMax=512M, CPUQuota=50%) and security hardening (NoNewPrivileges, ProtectSystem=strict).

Configuration

See config.example.yaml for the complete reference with inline documentation. Key sections:

Section Controls
currency Name, symbol, starting balance, daily cap
presence Base rate, night watch, milestones, greeting absence
streaks Streak bonuses, milestones, bridge recovery
chat_triggers 12 chat-based earning triggers with cooldowns
content_triggers Media interaction rewards
social_triggers Kudos, laughs, greetings, mentions
gambling Slot payouts, flip odds, challenge/heist rules
spending Queue costs, tip limits, vanity shop items
ranks Tier names, thresholds, perks, CyTube promotions
achievements Badge conditions and rewards
events Scheduled multipliers, competitions, bounties
announcements Public chat templates and toggle gates
admin Owner level, digest schedules
commands PM rate limit
metrics Prometheus endpoint port

Environment variable substitution is supported: ${NATS_URL}, ${VAR:-default}.

PM Commands

User Commands

Command Description
help Brief command overview
balance / bal Current balance, rank, and streak
rank Rank progress and perks
profile Full user summary
achievements Earned badges and progress
top / leaderboard Leaderboards
history Recent transaction history
search <query> Search MediaCMS catalog
queue <id> Queue content (costs Z)
tip @user <amount> Transfer Z to another user
shop Browse vanity items
buy <item> Purchase a vanity item
spin [wager] Slot machine
flip <wager> Coin flip
challenge @user <wager> Player duel
bounty <amount> "<desc>" Create a bounty
bounties List open bounties
events View active multipliers

Admin Commands (CyTube Rank ≥ 4)

Command Description
grant @user <amount> [reason] Credit Z to a user
deduct @user <amount> [reason] Debit Z from a user
rain <amount> Distribute Z equally to all present users
set_balance @user <amount> Hard-set a user's balance
set_rank @user <rank> Override a user's economy rank
ban @user [reason] / unban @user Economy access control
reload Hot-reload config without restart
announce <message> Post a message in public chat
econ:stats Economy overview dashboard
econ:user <name> Full user inspection
econ:health Inflation/deflation indicators
econ:triggers Trigger hit analytics with dead-trigger detection
econ:gambling Actual vs. configured house edge
event start/stop <name> Ad-hoc multiplier events
claim_bounty <id> @user Award a bounty to winner
approve_gif @user / reject_gif @user Manage GIF purchase approvals

Testing

# Run all 574 tests
pytest

# With coverage
pytest --cov=kryten_economy --cov-report=term-missing

# Specific sprint area
pytest tests/test_gambling_engine.py tests/test_slots.py tests/test_flip.py -v

All tests use mocks — no NATS server, database, or external services required.

Monitoring

Prometheus metrics served at http://localhost:28286/metrics (port configurable).

Counters: Z earned by trigger, Z spent by type, gamble in/out, events processed, commands processed, trigger hits, achievements awarded, rank promotions, competitions, bounties.

Gauges: Active users, total circulation, median balance, participation rate, active multiplier, rank distribution — all per-channel.

Architecture

kryten-economy/
├── kryten_economy/
│   ├── __init__.py              # Version from metadata
│   ├── __main__.py              # CLI entry, signal handling
│   ├── main.py                  # EconomyApp orchestrator
│   ├── config.py                # Pydantic config models
│   ├── database.py              # SQLite WAL, 12 tables
│   ├── presence_tracker.py      # Dwell tracking, join debounce
│   ├── earning_engine.py        # Centralized earning + multipliers
│   ├── spending_engine.py       # Spending validation + rank discounts
│   ├── gambling_engine.py       # Slots, flip, challenge, heist
│   ├── pm_handler.py            # 34 PM commands + rate limiting
│   ├── command_handler.py       # NATS request-reply API
│   ├── achievement_engine.py    # One-time badges
│   ├── rank_engine.py           # B-movie rank progression
│   ├── multiplier_engine.py     # Multiplier stack
│   ├── competition_engine.py    # Daily competitions
│   ├── bounty_manager.py        # User bounties
│   ├── event_announcer.py       # Chat announcements (dedup + batching)
│   ├── greeting_handler.py      # Custom greetings on join
│   ├── admin_scheduler.py       # Snapshots + digests
│   ├── scheduled_event_manager.py  # Cron-based events
│   ├── metrics_server.py        # Prometheus endpoint
│   ├── media_client.py          # MediaCMS API client
│   └── utils.py                 # Shared utilities
├── tests/                       # 65 test files, 574 tests
├── config.example.yaml          # Full reference config (~570 lines)
├── systemd/
│   └── kryten-economy.service   # Production systemd unit
├── pyproject.toml
├── LICENSE
└── CHANGELOG.md

Design Principles

  • Zero raw NATS — all messaging through kryten-py wrappers
  • Atomic debits — single-transaction debit-or-fail prevents negative balances
  • SQLite WAL — write-ahead logging with busy_timeout=30s for concurrent access
  • Error isolation — every event handler wrapped in try/except; one bad event never crashes the service
  • Hot-reloadable config — admin reload command re-validates via Pydantic and applies without restart

Publishing to PyPI

# Build
python -m build

# Upload to TestPyPI first
python -m twine upload --repository testpypi dist/*

# Upload to PyPI
python -m twine upload dist/*

License

MIT

Contributing

This is part of the kryten ecosystem. Issues and PRs welcome at github.com/grobertson/kryten-economy.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kryten_economy-0.7.1.tar.gz (351.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kryten_economy-0.7.1-py3-none-any.whl (106.6 kB view details)

Uploaded Python 3

File details

Details for the file kryten_economy-0.7.1.tar.gz.

File metadata

  • Download URL: kryten_economy-0.7.1.tar.gz
  • Upload date:
  • Size: 351.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kryten_economy-0.7.1.tar.gz
Algorithm Hash digest
SHA256 d5e8b7ecf6b2dcc2f19eace1d1f7e1b0782e26ecb9886909643812bb6cc8ab64
MD5 cb1d3b3be0ab0bb9c0efa58aa23a2cdf
BLAKE2b-256 6d1c9cb355cb1285a25f996a92983ce30b86074940b909c83b413631601b457c

See more details on using hashes here.

Provenance

The following attestation bundles were made for kryten_economy-0.7.1.tar.gz:

Publisher: publish.yml on grobertson/kryten-economy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kryten_economy-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: kryten_economy-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 106.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kryten_economy-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 84f2ea58aeea3d2e1cf790b57dd48b1dfa0eff41e728d3a54624dba55a0910df
MD5 f2f5df8e7ffdb46103349a127406754c
BLAKE2b-256 c4da8ae48936e60fb2e7acba1ac042e2ec233f160a710fed0f74c94df7c7a068

See more details on using hashes here.

Provenance

The following attestation bundles were made for kryten_economy-0.7.1-py3-none-any.whl:

Publisher: publish.yml on grobertson/kryten-economy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page