✨ Major Features Added: - Complete magical theming and rebranding from LifeRPG to The Wizard's Grimoire - Production-grade React frontend with Tailwind CSS v4 and magical aesthetics - Comprehensive analytics dashboard with Recharts integration (ScryingPortal) - Push notifications system with PWA service worker support - Drag & drop functionality using @dnd-kit for habit reordering - Social features with friends system and leaderboards - Performance optimization tools and monitoring - Mobile app enhancement with PWA installation support 🏗️ Technical Infrastructure: - Advanced service worker with offline support and background sync - Zustand state management for scalable application state - Production-ready UI component system with enhanced Button, Card, Input - Progressive Web App (PWA) with manifest and app installation - FastAPI backend with comprehensive API endpoints - Docker containerization and CI/CD pipeline setup 📱 Progressive Web App Features: - Offline functionality with intelligent caching - Push notification support for habit reminders - App installation on mobile and desktop platforms - Background sync for offline data management - Performance monitoring and optimization tools 🎨 User Experience: - Magical wizard/grimoire theming throughout application - Responsive design optimized for all device sizes - Drag & drop habit management with smooth animations - Interactive analytics with multiple chart types - Social connectivity with friends and competitive features - Comprehensive notification and performance settings 🔧 Developer Experience: - Modern development stack with Vite and React - Comprehensive testing setup and CI/CD pipelines - Code quality tools with pre-commit hooks - Docker development environment - Detailed documentation and implementation guides This represents a complete transformation from prototype to production-ready application with enterprise-grade features and magical user experience.
10 KiB
LifeRPG API Documentation
This document provides comprehensive documentation for the LifeRPG REST API.
Base URL
http://localhost:8000/api/v1
Authentication
Most endpoints require authentication using a Bearer token in the Authorization header:
Authorization: Bearer <your-jwt-token>
Endpoints
Authentication
POST /auth/login
Authenticate a user and return a JWT token.
Request Body:
{
"email": "user@example.com",
"password": "password123"
}
Response:
{
"token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9...",
"user": {
"id": 1,
"email": "user@example.com",
"display_name": "User Name",
"role": "user"
}
}
POST /auth/register
Register a new user account.
Request Body:
{
"email": "user@example.com",
"password": "password123",
"display_name": "User Name"
}
Response:
{
"token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9...",
"user": {
"id": 1,
"email": "user@example.com",
"display_name": "User Name",
"role": "user"
}
}
GET /me
Get current user information.
Headers: Authorization: Bearer <token>
Response:
{
"id": 1,
"email": "user@example.com",
"display_name": "User Name",
"role": "user"
}
Habits
GET /habits
Get all habits for the current user.
Headers: Authorization: Bearer <token>
Response:
[
{
"id": 1,
"title": "Exercise",
"description": "Daily exercise routine",
"category": "health",
"target_frequency": "daily",
"streak": 5,
"total_completions": 10,
"created_at": "2025-08-29T10:00:00Z",
"updated_at": "2025-08-30T10:00:00Z"
}
]
POST /habits
Create a new habit.
Headers: Authorization: Bearer <token>
Request Body:
{
"title": "Read Books",
"description": "Read for 30 minutes daily",
"category": "learning",
"target_frequency": "daily"
}
Response:
{
"id": 2,
"title": "Read Books",
"description": "Read for 30 minutes daily",
"category": "learning",
"target_frequency": "daily",
"streak": 0,
"total_completions": 0,
"created_at": "2025-08-30T10:00:00Z",
"updated_at": "2025-08-30T10:00:00Z"
}
POST /habits/{habit_id}/complete
Mark a habit as completed for today.
Headers: Authorization: Bearer <token>
Response:
{
"success": true,
"message": "Habit completed successfully",
"xp_earned": 20,
"new_streak": 6,
"achievement_unlocked": {
"id": "streak_5",
"title": "Streak Master",
"description": "Complete a habit 5 days in a row"
}
}
Gamification
GET /gamification/profile
Get user's gamification profile.
Headers: Authorization: Bearer <token>
Response:
{
"level": 5,
"xp": 1250,
"xp_to_next_level": 250,
"total_achievements": 8,
"current_streaks": 3,
"longest_streak": 15
}
GET /gamification/achievements
Get user's achievements.
Headers: Authorization: Bearer <token>
Response:
[
{
"id": "first_habit",
"title": "First Steps",
"description": "Create your first habit",
"icon": "🎯",
"unlocked_at": "2025-08-29T10:00:00Z"
}
]
GET /gamification/leaderboard
Get the global leaderboard.
Headers: Authorization: Bearer <token>
Response:
[
{
"rank": 1,
"user_id": 1,
"display_name": "User One",
"level": 10,
"xp": 5000,
"total_achievements": 25
}
]
Analytics
GET /analytics/habits/heatmap
Get habit completion heatmap data.
Headers: Authorization: Bearer <token>
Query Parameters:
start_date: Start date (YYYY-MM-DD)end_date: End date (YYYY-MM-DD)
Response:
{
"2025-08-29": {
"completed": 3,
"total": 5
},
"2025-08-30": {
"completed": 4,
"total": 5
}
}
GET /analytics/habits/trends
Get habit completion trends over time.
Headers: Authorization: Bearer <token>
Query Parameters:
period: Time period ('week', 'month', 'year')
Response:
[
{
"date": "2025-08-29",
"completions": 3,
"total_habits": 5,
"completion_rate": 0.6
}
]
Telemetry
POST /telemetry/events
Send telemetry events.
Headers: Authorization: Bearer <token>
Request Body:
{
"events": [
{
"event_type": "habit_completed",
"timestamp": "2025-08-30T10:00:00Z",
"properties": {
"habit_id": 1,
"category": "health"
}
}
]
}
Response:
{
"success": true,
"events_processed": 1
}
GET /telemetry/summary
Get telemetry summary (admin only).
Headers: Authorization: Bearer <token>
Response:
{
"total_events": 1500,
"events_today": 45,
"active_users": 12,
"top_events": [
{
"event_type": "habit_completed",
"count": 500
}
]
}
Plugins
GET /plugins
Get all plugins.
Headers: Authorization: Bearer <token>
Query Parameters:
status: Filter by status ('active', 'disabled', 'pending_review', 'rejected')
Response:
[
{
"id": "com.example.myplugin",
"name": "My Custom Plugin",
"version": "1.0.0",
"author": "Plugin Author",
"description": "A custom plugin for LifeRPG",
"status": "active",
"permissions": ["habits:read", "ui:dashboard"],
"created_at": "2025-08-30T10:00:00Z"
}
]
POST /plugins
Register a new plugin.
Headers: Authorization: Bearer <token>
Request: Multipart form data
metadata: JSON metadatawasm_file: WASM binary file
Response:
{
"id": "com.example.myplugin",
"status": "registered"
}
PATCH /plugins/{plugin_id}/status
Update plugin status.
Headers: Authorization: Bearer <token>
Request Body:
{
"status": "active"
}
Response:
{
"id": "com.example.myplugin",
"status": "active"
}
GET /plugins/extension-points
Get all extension points from loaded plugins.
Headers: Authorization: Bearer <token>
Response:
{
"extension_points": {
"dashboard": [
{
"id": "myplugin_widget",
"plugin_id": "com.example.myplugin",
"config": {
"title": "My Widget",
"size": "medium"
}
}
]
}
}
Error Responses
All endpoints may return error responses in the following format:
{
"detail": "Error message describing what went wrong"
}
Common HTTP Status Codes
200 OK: Request successful201 Created: Resource created successfully400 Bad Request: Invalid request data401 Unauthorized: Authentication required or invalid token403 Forbidden: Insufficient permissions404 Not Found: Resource not found422 Unprocessable Entity: Validation error500 Internal Server Error: Server error
Rate Limiting
The API implements rate limiting to prevent abuse:
- Authenticated requests: 1000 requests per hour per user
- Unauthenticated requests: 100 requests per hour per IP
Rate limit headers are included in responses:
X-RateLimit-Limit: Request limit per windowX-RateLimit-Remaining: Requests remaining in current windowX-RateLimit-Reset: Window reset time (Unix timestamp)
Examples
Complete Workflow Example
- Register a new user:
curl -X POST http://localhost:8000/api/v1/auth/register \
-H "Content-Type: application/json" \
-d '{"email":"user@example.com","password":"password123","display_name":"Test User"}'
- Create a habit:
curl -X POST http://localhost:8000/api/v1/habits \
-H "Authorization: Bearer YOUR_TOKEN" \
-H "Content-Type: application/json" \
-d '{"title":"Exercise","description":"Daily workout","category":"health","target_frequency":"daily"}'
- Complete the habit:
curl -X POST http://localhost:8000/api/v1/habits/1/complete \
-H "Authorization: Bearer YOUR_TOKEN"
- Check your gamification profile:
curl -X GET http://localhost:8000/api/v1/gamification/profile \
-H "Authorization: Bearer YOUR_TOKEN"
WebSocket Events (Future)
The API will support real-time updates via WebSocket connections:
habit.completed: When a habit is completedachievement.unlocked: When an achievement is unlockedlevel.up: When user levels upplugin.loaded: When a plugin is loaded/unloaded
Plugin API
Plugins have access to a subset of the API through host functions:
Available Host Functions
get_habits(): Get user's habitscreate_habit(name): Create a new habitregister_dashboard_widget(config): Register a dashboard widgetconsole_log(message): Log a messageconsole_error(message): Log an error
Plugin Permissions
Plugins must request specific permissions:
habits:read: Read habit datahabits:write: Create/modify habitsprojects:read: Read project dataprojects:write: Create/modify projectsui:dashboard: Add dashboard widgetsui:settings: Add settings pagesstorage:plugin: Use plugin storagenetwork:same-origin: Make same-origin requestsnetwork:external: Make external requests
SDK and Tools
Frontend SDK
import { LifeRPGClient } from '@liferpg/client-sdk';
const client = new LifeRPGClient({
baseURL: 'http://localhost:8000/api/v1',
token: 'your-jwt-token'
});
// Create a habit
const habit = await client.habits.create({
title: 'Exercise',
category: 'health'
});
// Complete a habit
await client.habits.complete(habit.id);
Plugin SDK
import { LifeRPG, PluginContext } from '@liferpg/plugin-sdk';
export function initialize(context: PluginContext): void {
// Register a dashboard widget
context.ui.registerDashboardWidget({
id: 'my-widget',
title: 'My Custom Widget',
render: () => '<div>Widget content</div>'
});
}
Support
For API support and questions:
- Documentation: https://liferpg.dev/docs
- GitHub Issues: https://github.com/TLimoges33/LifeRPG/issues
- Community Discord: https://discord.gg/liferpg (placeholder)
Changelog
v1.0.0 (2025-08-30)
- Initial API release
- Authentication endpoints
- Habits CRUD operations
- Gamification system
- Analytics endpoints
- Telemetry system
- Plugin system with WASM support