mirror of
https://github.com/DRYTRIX/TimeTracker.git
synced 2026-01-24 05:29:27 -06:00
Complete reorganization of project documentation to improve discoverability, navigation, and maintainability. All documentation has been restructured into a clear, role-based hierarchy. ## Major Changes ### New Directory Structure - Created `docs/api/` for API documentation - Created `docs/admin/` with subdirectories: - `admin/configuration/` - Configuration guides - `admin/deployment/` - Deployment guides - `admin/security/` - Security documentation - `admin/monitoring/` - Monitoring and analytics - Created `docs/development/` for developer documentation - Created `docs/guides/` for user-facing guides - Created `docs/reports/` for analysis reports and summaries - Created `docs/changelog/` for detailed changelog entries (ready for future use) ### File Organization #### Moved from Root Directory (40+ files) - Implementation notes → `docs/implementation-notes/` - Test reports → `docs/testing/` - Analysis reports → `docs/reports/` - User guides → `docs/guides/` #### Reorganized within docs/ - API documentation → `docs/api/` - Administrator documentation → `docs/admin/` (with subdirectories) - Developer documentation → `docs/development/` - Security documentation → `docs/admin/security/` - Telemetry documentation → `docs/admin/monitoring/` ### Documentation Updates #### docs/README.md - Complete rewrite with improved navigation - Added visual documentation map - Organized by role (Users, Administrators, Developers) - Better categorization and quick links - Updated all internal links to new structure #### README.md (root) - Updated all documentation links to reflect new structure - Fixed 8 broken links #### app/templates/main/help.html - Enhanced "Where can I get additional help?" section - Added links to new documentation structure - Added documentation index link - Added admin documentation link for administrators - Improved footer with organized documentation links - Added "Complete Documentation" section with role-based links ### New Index Files - Created README.md files for all new directories: - `docs/api/README.md` - `docs/guides/README.md` - `docs/reports/README.md` - `docs/development/README.md` - `docs/admin/README.md` ### Cleanup - Removed empty `docs/security/` directory (moved to `admin/security/`) - Removed empty `docs/telemetry/` directory (moved to `admin/monitoring/`) - Root directory now only contains: README.md, CHANGELOG.md, LICENSE ## Results **Before:** - 45+ markdown files cluttering root directory - Documentation scattered across root and docs/ - Difficult to find relevant documentation - No clear organization structure **After:** - 3 files in root directory (README, CHANGELOG, LICENSE) - Clear directory structure organized by purpose and audience - Easy navigation with role-based organization - All documentation properly categorized - Improved discoverability ## Benefits 1. Better Organization - Documentation grouped by purpose and audience 2. Easier Navigation - Role-based sections (Users, Admins, Developers) 3. Improved Discoverability - Clear structure with README files in each directory 4. Cleaner Root - Only essential files at project root 5. Maintainability - Easier to add and organize new documentation ## Files Changed - 40+ files moved from root to appropriate docs/ subdirectories - 15+ files reorganized within docs/ - 3 major documentation files updated (docs/README.md, README.md, help.html) - 5 new README index files created - 2 empty directories removed All internal links have been updated to reflect the new structure.
176 lines
3.9 KiB
Markdown
176 lines
3.9 KiB
Markdown
# API Versioning Strategy
|
|
|
|
## Overview
|
|
|
|
TimeTracker uses URL-based API versioning to ensure backward compatibility while allowing for API evolution.
|
|
|
|
## Version Structure
|
|
|
|
```
|
|
/api/v1/* - Current stable API (v1)
|
|
/api/v2/* - Future version (when breaking changes are needed)
|
|
```
|
|
|
|
## Versioning Policy
|
|
|
|
### When to Create a New Version
|
|
|
|
Create a new API version (e.g., v2) when:
|
|
- **Breaking changes** are required:
|
|
- Removing or renaming fields
|
|
- Changing response structure
|
|
- Changing authentication method
|
|
- Changing required parameters
|
|
- Changing error response format
|
|
|
|
### When NOT to Create a New Version
|
|
|
|
Do NOT create a new version for:
|
|
- Adding new endpoints (add to current version)
|
|
- Adding optional fields (backward compatible)
|
|
- Adding new response fields (backward compatible)
|
|
- Bug fixes (fix in current version)
|
|
- Performance improvements (no API change)
|
|
|
|
## Current Versions
|
|
|
|
### v1 (Current)
|
|
|
|
**Status:** Stable
|
|
**Base URL:** `/api/v1`
|
|
**Documentation:** See `app/routes/api_v1.py`
|
|
|
|
**Features:**
|
|
- Token-based authentication
|
|
- RESTful endpoints
|
|
- JSON responses
|
|
- Pagination support
|
|
- Filtering and sorting
|
|
|
|
**Endpoints:**
|
|
- `/api/v1/projects` - Project management
|
|
- `/api/v1/tasks` - Task management
|
|
- `/api/v1/time-entries` - Time entry management
|
|
- `/api/v1/invoices` - Invoice management
|
|
- `/api/v1/clients` - Client management
|
|
- And more...
|
|
|
|
## Version Negotiation
|
|
|
|
Clients specify API version via:
|
|
1. **URL path** (preferred): `/api/v1/projects`
|
|
2. **Accept header** (future): `Accept: application/vnd.timetracker.v1+json`
|
|
3. **Query parameter** (fallback): `/api/projects?version=1`
|
|
|
|
## Deprecation Policy
|
|
|
|
1. **Deprecation Notice:** Deprecated endpoints return `X-API-Deprecated: true` header
|
|
2. **Deprecation Period:** Minimum 6 months before removal
|
|
3. **Migration Guide:** Documentation provided for migrating to new version
|
|
4. **Removal:** Deprecated endpoints removed only in major version bumps
|
|
|
|
## Migration Example
|
|
|
|
### v1 to v2 (Hypothetical)
|
|
|
|
**v1 Response:**
|
|
```json
|
|
{
|
|
"id": 1,
|
|
"name": "Project",
|
|
"client": "Client Name"
|
|
}
|
|
```
|
|
|
|
**v2 Response (breaking change):**
|
|
```json
|
|
{
|
|
"id": 1,
|
|
"name": "Project",
|
|
"client": {
|
|
"id": 1,
|
|
"name": "Client Name"
|
|
}
|
|
}
|
|
```
|
|
|
|
**Migration:**
|
|
- v1 endpoint remains available
|
|
- v2 endpoint provides new structure
|
|
- Clients migrate at their own pace
|
|
- v1 deprecated but not removed
|
|
|
|
## Best Practices
|
|
|
|
1. **Always use versioned URLs** in client code
|
|
2. **Handle version negotiation** gracefully
|
|
3. **Monitor deprecation headers** in responses
|
|
4. **Plan migrations** well in advance
|
|
5. **Test against specific versions** in CI/CD
|
|
|
|
## Implementation
|
|
|
|
### Current Structure
|
|
|
|
```
|
|
app/routes/
|
|
├── api.py # Legacy API (deprecated)
|
|
├── api_v1.py # v1 API (current)
|
|
└── api/ # Future versioned structure
|
|
└── v1/
|
|
└── __init__.py
|
|
```
|
|
|
|
### Future Structure
|
|
|
|
```
|
|
app/routes/api/
|
|
├── __init__.py
|
|
├── v1/
|
|
│ ├── __init__.py
|
|
│ ├── projects.py
|
|
│ ├── tasks.py
|
|
│ └── invoices.py
|
|
└── v2/
|
|
├── __init__.py
|
|
├── projects.py
|
|
└── ...
|
|
```
|
|
|
|
## Version Detection
|
|
|
|
```python
|
|
from flask import request
|
|
|
|
def get_api_version():
|
|
"""Get API version from request"""
|
|
# Check URL path
|
|
if request.path.startswith('/api/v1'):
|
|
return 'v1'
|
|
elif request.path.startswith('/api/v2'):
|
|
return 'v2'
|
|
|
|
# Check Accept header
|
|
accept = request.headers.get('Accept', '')
|
|
if 'vnd.timetracker.v1' in accept:
|
|
return 'v1'
|
|
elif 'vnd.timetracker.v2' in accept:
|
|
return 'v2'
|
|
|
|
# Default to v1
|
|
return 'v1'
|
|
```
|
|
|
|
## Documentation
|
|
|
|
- **OpenAPI/Swagger:** Available at `/api/docs`
|
|
- **Version-specific docs:** `/api/v1/docs` (future)
|
|
- **Migration guides:** In `docs/api/migrations/`
|
|
|
|
---
|
|
|
|
**Last Updated:** 2025-01-27
|
|
**Current Version:** v1
|
|
**Next Version:** v2 (when needed)
|
|
|