- Created complete documentation in docs/ directory - Added PROJECT_OVERVIEW.md with feature highlights and getting started guide - Added ARCHITECTURE.md with system design and technical details - Added SECURITY.md with comprehensive security implementation guide - Added DEVELOPMENT.md with development workflows and best practices - Added DEPLOYMENT.md with production deployment instructions - Added API.md with complete REST API documentation - Added CONTRIBUTING.md with contribution guidelines - Added CHANGELOG.md with version history and migration notes - Reorganized all documentation files into docs/ directory for better organization - Updated README.md with proper documentation links and quick navigation - Enhanced project structure with professional documentation standards
4.5 KiB
4.5 KiB
EasyStream Donations API Documentation
This API allows external applications to interact with the EasyStream donation system. All requests require authentication using an API key.
Authentication
All API requests must include an API key in the Authorization header:
Authorization: your-api-key-here
Base URL
https://your-domain.com/f_modules/m_frontend/m_donations/api
Endpoints
Analytics
Get Analytics Data
GET /analytics
Query Parameters:
start_date(optional): Start date in YYYY-MM-DD format (default: 30 days ago)end_date(optional): End date in YYYY-MM-DD format (default: today)
Response:
[
{
"date": "2024-03-20",
"total_donations": 5,
"total_amount": 150.00,
"average_donation": 30.00,
"unique_donors": 3
}
]
Get Analytics Summary
GET /analytics/summary
Response:
{
"total_donations": 150,
"total_amount": 5000.00,
"average_donation": 33.33,
"unique_donors": 45,
"largest_donation": 200.00,
"smallest_donation": 5.00
}
Get Top Donors
GET /analytics/top-donors
Query Parameters:
limit(optional): Number of top donors to return (default: 10)
Response:
[
{
"username": "donor1",
"display_name": "John Doe",
"donation_count": 15,
"total_amount": 500.00
}
]
Goals
Get All Goals
GET /goals
Response:
[
{
"goal_id": 1,
"title": "New Equipment",
"description": "Help me upgrade my streaming setup",
"target_amount": 1000.00,
"current_amount": 500.00,
"start_date": "2024-03-01T00:00:00Z",
"end_date": "2024-04-01T00:00:00Z",
"status": "active"
}
]
Create New Goal
POST /goals
Request Body:
{
"title": "New Equipment",
"description": "Help me upgrade my streaming setup",
"target_amount": 1000.00,
"end_date": "2024-04-01"
}
Response:
{
"success": true,
"goal_id": 1
}
Get Active Goals
GET /goals/active
Response:
[
{
"goal_id": 1,
"title": "New Equipment",
"description": "Help me upgrade my streaming setup",
"target_amount": 1000.00,
"current_amount": 500.00,
"start_date": "2024-03-01T00:00:00Z",
"end_date": "2024-04-01T00:00:00Z",
"status": "active"
}
]
Add Milestone to Goal
POST /goals/milestones
Request Body:
{
"goal_id": 1,
"title": "Halfway There",
"description": "Reach 50% of the goal",
"target_amount": 500.00,
"reward_description": "Special shoutout on stream"
}
Response:
{
"success": true,
"milestone_id": 1
}
Notifications
Get All Notifications
GET /notifications
Query Parameters:
limit(optional): Number of notifications to return (default: 20)
Response:
[
{
"notification_id": 1,
"type": "donation",
"title": "New Donation",
"message": "Received $50.00 from John Doe",
"is_read": false,
"created_at": "2024-03-20T15:30:00Z"
}
]
Get Unread Notifications
GET /notifications/unread
Query Parameters:
limit(optional): Number of notifications to return (default: 10)
Response:
[
{
"notification_id": 1,
"type": "donation",
"title": "New Donation",
"message": "Received $50.00 from John Doe",
"is_read": false,
"created_at": "2024-03-20T15:30:00Z"
}
]
Mark Notifications as Read
POST /notifications/unread
Request Body:
{
"notification_ids": [1, 2, 3]
}
Response:
{
"success": true
}
Error Responses
All endpoints may return the following error responses:
400 Bad Request
{
"error": "Missing required fields"
}
401 Unauthorized
{
"error": "API key is required"
}
or
{
"error": "Invalid API key"
}
404 Not Found
{
"error": "Endpoint not found"
}
405 Method Not Allowed
{
"error": "Method not allowed"
}
Rate Limiting
The API is rate limited to 100 requests per minute per API key. When the rate limit is exceeded, the API will return a 429 Too Many Requests response:
{
"error": "Rate limit exceeded"
}
Best Practices
- Always include error handling in your API calls
- Cache responses when appropriate to reduce API calls
- Use appropriate HTTP methods (GET for retrieving data, POST for creating)
- Include proper error messages in your application when API calls fail
- Keep your API key secure and never expose it in client-side code