Skip to content

Layr-Labs/clout-cards

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

clout-cards

Development

Quick Start: Reset Development Environment

To completely reset your development environment (tear down Docker, restart services, migrate database, and deploy contract):

npx ts-node scripts/reset-dev-env.ts

This script will:

  1. Stop and remove all Docker containers and volumes
  2. Start fresh Docker containers (PostgreSQL and Anvil)
  3. Wait for services to be ready
  4. Run database migrations
  5. Deploy the CloutCards contract (using --default-anvil-key --skip-confirmation for automation)
  6. Display the contract proxy address

After running, you can start the dev server with the displayed contract address.

Note: The reset script runs without user interaction. For manual contract deployments, see Deployment Guide.

Setup & Local Testing

  1. Install dependencies:
npm install
cd frontend && npm install && cd ..
  1. Reset development environment (recommended for fresh start):
npx ts-node scripts/reset-dev-env.ts

Or manually:

Start local services (PostgreSQL and Anvil):

docker-compose up -d

Deploy contract (in a new terminal):

# Get TEE public key from backend (if running)
TEE_PUBLIC_KEY=$(curl -s http://localhost:8000/tee/publicKey | jq -r '.publicKey' || echo "0x0487Ecf457cEAdc4Be25676EDE5F634fdcDdbF4d")

# Deploy contract
npx ts-node scripts/deploy-clout-cards.ts \
  http://localhost:8545 \
  $TEE_PUBLIC_KEY \
  --default-anvil-key

# Copy the proxy address from output
  1. Start full dev server (backend + frontend):
# Option 1: Set inline (one-time use)
IS_LOCAL=true CLOUTCARDS_CONTRACT_ADDRESS=0xYourProxyAddress npm run dev:full

# Option 2: Export for current shell session
export IS_LOCAL=true
export CLOUTCARDS_CONTRACT_ADDRESS=0xYourProxyAddress
npm run dev:full

# Option 3: One-liner with export
export IS_LOCAL=true && export CLOUTCARDS_CONTRACT_ADDRESS=0xYourProxyAddress && npm run dev:full

# Option 4: Add to .env file (persists across sessions)
echo "IS_LOCAL=true" >> .env
echo "CLOUTCARDS_CONTRACT_ADDRESS=0xYourProxyAddress" >> .env
npm run dev:full

The dev:full script starts both backend (port 8000) and frontend (port 5173) concurrently.

Individual Services

# Backend only
npm run dev:backend

# Frontend only
npm run dev:frontend

Docker Testing

docker build -t my-app .
docker run --rm --env-file .env my-app

Prerequisites

Before deploying, you'll need:

Deployment

# Store your private key (generate new or use existing)
eigenx auth generate --store
# OR: eigenx auth login (if you have an existing key)

eigenx app deploy username/image-name

The CLI will automatically detect the Dockerfile and build your app before deploying.

Management & Monitoring

App Lifecycle

eigenx app list                    # List all apps
eigenx app info [app-name]         # Get app details
eigenx app logs [app-name]         # View logs
eigenx app start [app-name]        # Start stopped app
eigenx app stop [app-name]         # Stop running app
eigenx app terminate [app-name]    # Terminate app
eigenx app upgrade [app-name] [image] # Update deployment
eigenx app configure tls            # Configure TLS

App Profile

eigenx app profile set [app-id]  # Set app name, website, description, social links, and icon

TLS Configuration (Optional)

This project includes optional automatic TLS certificate management using Caddy. The Caddyfile is not required - if you don't need TLS termination or prefer to handle it differently, you can simply delete the Caddyfile.

How It Works

When a Caddyfile is present in your project root:

  • Caddy will automatically start as a reverse proxy
  • It handles TLS certificate acquisition and renewal via Let's Encrypt
  • Your app runs on APP_PORT and Caddy forwards HTTPS traffic to it
  • Certificates are stored persistently in the TEE's encrypted storage

Without a Caddyfile:

  • Your application runs directly on the configured ports
  • You can handle TLS in your application code or use an external load balancer

Deployment Checklist

Before deploying with TLS:

  1. Configure TLS: Run eigenx app configure tls to add the necessary configuration files for domain setup with private traffic termination in the TEE.

  2. DNS: Ensure A/AAAA record points to your instance (or reserved static IP). Note: If this is your first deployment, you will need to get your IP after deployment from the eigenx app info command.

  3. Required configuration in .env:

    DOMAIN=mydomain.com          # Your domain name
    APP_PORT=8000               # Your app's port
    ACME_STAGING=true           # Test with staging first to avoid rate limits
    ENABLE_CADDY_LOGS=true      # Enable logs for debugging
  4. Optional ACME configuration (all optional, with sensible defaults):

    # ACME email for Let's Encrypt notifications
    ACME_EMAIL=admin@example.com
    
    # Certificate Authority directory URL
    # Default: https://acme-v02.api.letsencrypt.org/directory
    ACME_CA=https://acme-v02.api.letsencrypt.org/directory
    
    # ACME Challenge Type
    # How to prove domain ownership to Let's Encrypt
    # Both result in the same TLS certificate, just different validation methods:
    # - http-01: Uses port 80 (default)
    # - tls-alpn-01: Uses port 443
    ACME_CHALLENGE=http-01
    
    # Use Let's Encrypt Staging (for testing)
    # Set to true to use staging environment (certificates won't be trusted by browsers)
    # Great for testing without hitting rate limits
    ACME_STAGING=true
    
    # Force certificate reissue
    # Set to true to force a new certificate even if one exists
    # This will delete the existing certificate from storage and get a new one
    ACME_FORCE_ISSUE=true
  5. Customize Caddyfile (optional):

    • Edit Caddyfile to match your application port
    • Modify security headers as needed
    • Configure rate limiting or other middleware

TLS Testing & Debugging

  • Enable Caddy logs to see TLS-related output:

    ENABLE_CADDY_LOGS=true
  • Use Let's Encrypt staging for testing (avoids rate limits, but certificates won't be trusted by browsers):

    ACME_STAGING=true

Local Development

For local development without TLS, leave DOMAIN empty or set to localhost in your .env file.

Custom Certificates

To use custom certificates instead of Let's Encrypt, modify the Caddyfile:

tls /path/to/cert.pem /path/to/key.pem

Documentation

About

An EigenCompute betting Texas Hold'em Game with X integration

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published