Skip to content

antpb/XR-Publisher-API

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

World and Character Management System

Overview

The World and Character Management System is a comprehensive solution built on Cloudflare Workers and R2 storage, designed to handle both virtual world publishing and AI character management. This system provides endpoints for managing worlds (3D environments), user authentication, and interactive AI characters.

Prerequisites

Before you begin, ensure you have the following:

  • A Cloudflare account with Workers and R2 enabled
  • Node.js (version 12 or later) and npm installed
  • Wrangler CLI installed and authenticated with your Cloudflare account

Configuration

The wrangler.toml file contains the configuration for your worker and R2 bucket. Key configurations include:

KV Namespaces

  • VISIT_COUNTS: Tracks world visits
  • DOWNLOAD_RATELIMIT: Manages rate limiting
  • DOWNLOAD_QUEUE: Handles download queues

Durable Objects

  • WORLD_REGISTRY: Class name (WorldRegistryDO)
  • USER_AUTH: Class name (UserAuthDO)
  • CHARACTER_REGISTRY: Class name (CharacterRegistryDO)

Environment Variables Required

  • CHARACTER_SALT: Secret for character encryption
  • USER_KEY_SALT: Secret for user key generation
  • API_SECRET: Admin API secret
  • CF_ACCOUNT_ID: Cloudflare account ID
  • CF_GATEWAY_ID: Cloudflare gateway ID
  • OPENAI_API_KEY: OpenAI API key (for character AI)
  • ANTHROPIC_API_KEY: Anthropic API key (for character AI)

World Management Endpoints

GET Endpoints

  • /: Homepage with author listings and world directory
  • /world-data: Retrieve world metadata (cached)
  • /author-data: Retrieve author data (cached)
  • /authors-list: Get a list of all authors (cached)
  • /directory/{author}/{slug}: Get HTML page for a specific world (cached)
  • /author/{author}: Get HTML page for a specific author (cached)
  • /version-check: Compare new version against author/slug/metadata.json
  • /download: Download a world file
  • /download-count: Get download count for a world
  • /search: Search worlds with optional tag filtering
  • /directory/search: Get HTML search results page
  • /visit-count: Get visit count for a world

POST Endpoints

  • /upload-world: Upload a world's HTML content and assets
  • /world-metadata: Update world metadata
  • /update-active-users: Update active users count for a world
  • /world-upload-assets: Upload world assets (previews, etc.)
  • /update-author-info: Update author information
  • /backup-world: Create backup of currently live files
  • /delete-world: Remove a specific world

Character Management Endpoints

GET Endpoints

  • /character-data: Get character metadata and configuration
  • /featured-characters: Get list of featured characters
  • /author-characters: Get all characters for an author
  • /characters/{author}/{name}: Get character profile page

POST Endpoints

  • /create-character: Create new character
  • /update-character: Update existing character
  • /update-character-metadata: Update character metadata only
  • /update-character-images: Update character profile/banner images
  • /update-character-secrets: Update character API keys and credentials
  • /delete-character: Remove character and associated data
  • /api/character/session: Initialize new character session
  • /api/character/message: Send message to character
  • /api/character/memory: Create memory for character
  • /api/character/memories: Get character memories
  • /api/character/memories/by-rooms: Get memories across multiple rooms

Authentication System

Public Endpoints

  • /register: Get registration page HTML
  • /create-user: Register new user (requires invite code)
  • /roll-api-key: Get API key roll interface
  • /roll-key-with-token: Complete key roll with verification token
  • /initiate-key-roll: Start key recovery process
  • /verify-key-roll: Complete key recovery with GitHub verification

Authenticated Endpoints

  • /rotate-key: Standard API key rotation
  • /delete-user: Remove user and associated data (admin only)
  • /admin-update-user: Update user details (admin only)

Authentication Requirements

Most POST endpoints require authentication via API key in the Authorization header:

curl -X POST https://your-worker.dev/endpoint \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json"

Admin-only endpoints require the main API secret:

curl -X POST https://your-worker.dev/admin-update-user \
  -H "Authorization: Bearer YOUR_API_SECRET" \
  -H "Content-Type: 'application/json"

User Management

The Plugin Publishing System includes a robust user management system with secure registration, API key management, and GitHub-based verification.

Registration

New users can register through the /register endpoint which provides a web interface for:

  • Creating a new author account
  • Setting up GitHub integration
  • Generating initial API credentials
  • Requiring invite codes for controlled access

Registation workflow:

  1. User visits the registration page
  2. Provides username, email, GitHub username, and invite code
  3. System validates credentials and invite code
  4. Generates initial API key
  5. Downloads configuration file with credentials

Character System Features

Character Configuration

Characters support rich configuration including:

  • Basic info (name, bio, status)
  • Model provider selection (OpenAI/Anthropic)
  • Communication channels (Discord, Direct)
  • Personality traits and topics
  • Message examples
  • Style settings
  • Custom API keys per character

Memory System

Characters maintain:

  • Conversation history
  • User-specific memories
  • Room-based context
  • Memory importance scoring
  • Cross-room memory retrieval

Session Management

  • Secure session initialization
  • Nonce-based message validation
  • Room-based conversations
  • Auto-cleanup of expired sessions

Database Schema

World Registry

CREATE TABLE worlds (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    author TEXT NOT NULL,
    slug TEXT NOT NULL,
    name TEXT NOT NULL,
    short_description TEXT,
    version TEXT NOT NULL,
    visit_count INTEGER DEFAULT 0,
    active_users INTEGER DEFAULT 0,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    UNIQUE(author, slug)
);

Character Registry

CREATE TABLE characters (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    author TEXT NOT NULL,
    name TEXT NOT NULL,
    model_provider TEXT NOT NULL,
    bio TEXT,
    settings TEXT,
    vrm_url TEXT,
    profile_img TEXT,
    banner_img TEXT,
    status TEXT DEFAULT 'private',
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    UNIQUE(author, name)
);

CREATE TABLE character_secrets (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    character_id INTEGER NOT NULL,
    salt TEXT NOT NULL,
    model_keys TEXT,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY(character_id) REFERENCES characters(id)
);

CREATE TABLE character_sessions (
    id TEXT PRIMARY KEY,
    character_id INTEGER,
    room_id TEXT,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    last_active TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY(character_id) REFERENCES characters(id)
);

User Authentication

CREATE TABLE users (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    username TEXT NOT NULL UNIQUE,
    email TEXT NOT NULL,
    github_username TEXT,
    key_id TEXT NOT NULL UNIQUE,
    key_hash TEXT NOT NULL,
    invite_code_used TEXT NOT NULL,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    last_key_rotation TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

API Key Management

The system provides several methods for managing API keys:

Standard Key Rotation

  • Endpoint: POST /rotate-key
  • Requires current API key authentication
  • Generates new credentials immediately
  • Invalidates previous key

GitHub-Based Key Recovery

For users who need to recover access, the system provides a secure GitHub-based verification:

  1. Initiate Recovery

    • Endpoint: POST /initiate-key-roll
    • Required fields:
      {
        "username": "string",
        "email": "string"
      }
    • Returns verification instructions and token
  2. Create Verification Gist

    • User creates a public GitHub gist
    • Filename must match pattern: plugin-publisher-verify-{username}.txt
    • Content must include provided verification token
  3. Complete Verification

    • Endpoint: POST /verify-key-roll
    • Required fields:
      {
        "gistUrl": "string",
        "verificationToken": "string"
      }
    • System verifies:
      • Gist ownership matches registered GitHub username
      • Verification token is valid and not expired
      • File content matches expected format
    • Returns new API key upon successful verification

Roll Key Gist Example

Caching

The system implements caching for GET requests with:

  • CDN edge caching (1-hour TTL)
  • Version-based cache keys
  • Automatic invalidation on content updates
  • Auth-based cache bypassing

Cache is automatically invalidated when:

  • A new world/character is published
  • Author information is updated
  • A GET request contains a valid API secret

Rate Limiting

  • IP-based rate limiting using Cloudflare KV
  • 5 downloads per hour per IP/world combination
  • Message rate limiting for character interactions

Security Features

  • HMAC-based API key validation
  • Nonce-based message authentication
  • Salt-based secret encryption
  • GitHub-based key recovery verification
  • CSP headers for world rendering
  • Invite code system for registration

Error Handling

All endpoints return standardized error responses:

{
    "error": "Error description",
    "details": "Detailed error message"
}

Best Practices

  1. Always verify API keys before sensitive operations
  2. Use appropriate content-type headers
  3. Implement proper error handling
  4. Clear cache after content updates
  5. Regular key rotation
  6. Monitor rate limits
  7. Backup important worlds before updates

Troubleshooting

  1. Wrangler not found: Ensure Wrangler is installed globally: npm install -g wrangler
  2. Deployment fails: Verify you're logged in to your Cloudflare account: npx wrangler login
  3. R2 bucket creation fails: Confirm R2 is enabled for your Cloudflare account
  4. API requests fail: Double-check you're using the correct API Secret in your requests

Limitations

  • The setup script assumes you have the necessary permissions to create resources and deploy workers in your Cloudflare account.
  • The script does not provide options for cleaning up resources if the setup fails midway.
  • Existing resources with the same names may be overwritten without warning.
  • Caching is set to a fixed duration (1 hour). Adjust the max-age value in the code if you need different caching behavior.

Support

For issues or assistance:

  1. Check the Troubleshooting section
  2. Review the Cloudflare Workers documentation
  3. Contact Cloudflare support for platform-specific issues

About

XR Publisher api

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published