AI Analysis and Content Strategy fixes. Enhanced Strategy Routes refactoring.

This commit is contained in:
ajaysi
2026-01-10 19:32:50 +05:30
parent 0b63ae7fc1
commit 8193cdba67
298 changed files with 45678 additions and 10952 deletions

View File

@@ -0,0 +1,125 @@
# Enhanced Strategy Routes Refactoring Summary
## Overview
Refactored the monolithic `enhanced_strategy_routes.py` (1169 lines) into a modular structure following separation of concerns. All endpoints have been moved to appropriate endpoint files in the `content_strategy/endpoints/` directory.
## Changes Made
### 1. Created Shared Utilities
- **`utils/data_parsers.py`**: Extracted data parsing utilities (`parse_float`, `parse_int`, `parse_json`, `parse_array`, `parse_strategy_data`) to eliminate code duplication
### 2. Updated Strategy CRUD Endpoints
- **File**: `content_strategy/endpoints/strategy_crud.py`
- **Changes**:
- Replaced inline parsing functions with shared `parse_strategy_data()` utility
- All CRUD endpoints already had authentication (Clerk) - maintained
- Improved error handling and response formatting
### 3. Updated Streaming Endpoints
- **File**: `content_strategy/endpoints/streaming_endpoints.py`
- **Changes**:
- All streaming endpoints now require Clerk authentication
- Fixed bug: replaced undefined `user_id` variable with `authenticated_user_id`
- Endpoints: `/stream/strategies`, `/stream/strategic-intelligence`, `/stream/keyword-research`
### 4. Updated Analytics Endpoints
- **File**: `content_strategy/endpoints/analytics_endpoints.py`
- **Changes**:
- Updated implementations to use `EnhancedStrategyDBService` methods
- Improved error handling with `ContentPlanningErrorHandler`
- Added user_id passing for subscription checks in AI generation endpoints
- Endpoints:
- `GET /{strategy_id}/analytics`
- `GET /{strategy_id}/ai-analyses`
- `GET /{strategy_id}/completion`
- `GET /{strategy_id}/onboarding-integration`
- `POST /{strategy_id}/ai-recommendations`
- `POST /{strategy_id}/ai-analysis/regenerate`
### 5. Updated Utility Endpoints
- **File**: `content_strategy/endpoints/utility_endpoints.py`
- **Changes**:
- Cache management endpoint already exists: `POST /cache/clear`
- Endpoints: `/onboarding-data`, `/tooltips`, `/disclosure-steps`
### 6. Autofill Endpoints
- **File**: `content_strategy/endpoints/autofill_endpoints.py`
- **Status**: Already properly modularized
- **Endpoints**:
- `POST /{strategy_id}/autofill/accept`
- `GET /autofill/refresh/stream`
- `POST /autofill/refresh`
### 7. Updated Router
- **File**: `api/router.py`
- **Changes**:
- Removed import of `enhanced_strategy_routes`
- Removed router inclusion for `enhanced_strategy_router`
- All endpoints now served through modular `content_strategy_router`
## Endpoint Mapping
| Original Route (enhanced_strategy_routes.py) | New Location | Status |
|---------------------------------------------|--------------|--------|
| `POST /create` | `strategy_crud.py` | ✅ Moved (with auth) |
| `GET /` | `strategy_crud.py` | ✅ Moved (with auth) |
| `GET /{strategy_id}` | `strategy_crud.py` | ✅ Moved (with auth) |
| `PUT /{strategy_id}` | `strategy_crud.py` | ✅ Moved (with auth) |
| `DELETE /{strategy_id}` | `strategy_crud.py` | ✅ Moved (with auth) |
| `GET /stream/strategies` | `streaming_endpoints.py` | ✅ Moved (with auth) |
| `GET /stream/strategic-intelligence` | `streaming_endpoints.py` | ✅ Moved (with auth) |
| `GET /stream/keyword-research` | `streaming_endpoints.py` | ✅ Moved (with auth) |
| `GET /onboarding-data` | `utility_endpoints.py` | ✅ Already exists |
| `GET /tooltips` | `utility_endpoints.py` | ✅ Already exists |
| `GET /disclosure-steps` | `utility_endpoints.py` | ✅ Already exists |
| `GET /{strategy_id}/analytics` | `analytics_endpoints.py` | ✅ Updated |
| `GET /{strategy_id}/ai-analyses` | `analytics_endpoints.py` | ✅ Updated |
| `GET /{strategy_id}/completion` | `analytics_endpoints.py` | ✅ Updated |
| `GET /{strategy_id}/onboarding-integration` | `analytics_endpoints.py` | ✅ Updated |
| `POST /{strategy_id}/ai-recommendations` | `analytics_endpoints.py` | ✅ Updated |
| `POST /{strategy_id}/ai-analysis/regenerate` | `analytics_endpoints.py` | ✅ Updated |
| `POST /{strategy_id}/autofill/accept` | `autofill_endpoints.py` | ✅ Already exists |
| `GET /autofill/refresh/stream` | `autofill_endpoints.py` | ✅ Already exists |
| `POST /autofill/refresh` | `autofill_endpoints.py` | ✅ Already exists |
| `POST /cache/clear` | `utility_endpoints.py` | ✅ Already exists |
## Authentication & Security
All endpoints now properly:
- ✅ Require Clerk authentication via `get_current_user` dependency
- ✅ Extract `user_id` from authenticated token (not request body)
- ✅ Verify ownership before allowing access to strategies
- ✅ Pass `user_id` to AI service calls for subscription checks
## Benefits
1. **Separation of Concerns**: Each endpoint file has a single responsibility
2. **Code Reusability**: Shared parsing utilities eliminate duplication
3. **Maintainability**: Easier to find and update specific functionality
4. **Security**: Consistent authentication across all endpoints
5. **Testability**: Modular structure makes unit testing easier
## Migration Notes
- **Backward Compatibility**: All endpoint paths remain the same (via router prefixes)
- **API Contracts**: No breaking changes to request/response formats
- **Old File**: `enhanced_strategy_routes.py` can be kept as backup but is no longer used
## Next Steps
1. ✅ All endpoints moved to modular files
2. ✅ Router updated to use modular structure
3. ✅ All endpoints tested and verified
4.`enhanced_strategy_routes.py` deleted (all functionality migrated)
5. ✅ Documentation updated
## Deletion Status
**✅ DELETED**: `enhanced_strategy_routes.py` has been successfully deleted after verification that:
- All 21 endpoints migrated to modular files
- All functionality preserved and enhanced
- Authentication added to all endpoints
- Router updated to use modular structure
- No active code references remain
See `ENHANCED_STRATEGY_ROUTES_DELETION_VERIFICATION.md` for complete verification details.