8a49db2a10
rework of SeriesApp.py
2025-11-02 10:20:10 +01:00
2de3317aee
refactoring backup
2025-11-02 09:52:43 +01:00
d5f7b1598f
use of websockets
2025-11-01 19:23:32 +01:00
57c30a0156
call back logs
2025-11-01 19:03:30 +01:00
9fce617949
fix percentage
2025-11-01 18:46:53 +01:00
b76ffbf656
fixed percentage and mb/s view
2025-11-01 16:49:12 +01:00
f0b9d50f85
fix not downloading
2025-11-01 16:43:05 +01:00
6cdb2eb1e1
added logging
2025-11-01 16:29:07 +01:00
a41c86f1da
refactor: remove GlobalLogger and migrate to standard Python logging
...
- Remove src/infrastructure/logging/GlobalLogger.py
- Update SerieScanner.py to use standard logging.getLogger()
- Update aniworld_provider.py to remove custom noKeyFound_logger setup
- Fix test_dependencies.py to properly mock config_service
- Fix code style issues (line length, formatting)
- All 846 tests passing
2025-10-25 17:27:49 +02:00
fecdb38a90
feat: Add comprehensive provider health monitoring and failover system
...
- Implemented ProviderHealthMonitor for real-time tracking
- Monitors availability, response times, success rates
- Automatic marking unavailable after failures
- Background health check loop
- Added ProviderFailover for automatic provider switching
- Configurable retry attempts with exponential backoff
- Integration with health monitoring
- Smart provider selection
- Created MonitoredProviderWrapper for performance tracking
- Transparent monitoring for any provider
- Automatic metric recording
- No changes needed to existing providers
- Implemented ProviderConfigManager for dynamic configuration
- Runtime updates without restart
- Per-provider settings (timeout, retries, bandwidth)
- JSON-based persistence
- Added Provider Management API (15+ endpoints)
- Health monitoring endpoints
- Configuration management
- Failover control
- Comprehensive testing (34 tests, 100% pass rate)
- Health monitoring tests
- Failover scenario tests
- Configuration management tests
- Documentation updates
- Updated infrastructure.md
- Updated instructions.md
- Created PROVIDER_ENHANCEMENT_SUMMARY.md
Total: ~2,593 lines of code, 34 passing tests
2025-10-24 11:01:40 +02:00
ffb182e3ba
cleanup
2025-10-23 19:41:24 +02:00
c81a493fb1
cleanup
2025-10-23 19:00:49 +02:00
3d5c19939c
cleanup
2025-10-23 18:28:17 +02:00
9a64ca5b01
cleanup
2025-10-23 18:10:34 +02:00
5c2691b070
cleanup
2025-10-22 17:39:28 +02:00
6db850c2ad
cleanup
2025-10-22 15:54:36 +02:00
92795cf9b3
Improve docs and security defaults
2025-10-22 15:22:58 +02:00
947a8ff51f
cleanup
2025-10-22 13:49:32 +02:00
04799633b4
cleanup
2025-10-22 13:38:46 +02:00
7437eb4c02
refactor: improve code quality - fix imports, type hints, and security issues
...
## Critical Fixes
- Create error_handler module with custom exceptions and recovery strategies
- Adds RetryableError, NonRetryableError, NetworkError, DownloadError
- Implements with_error_recovery decorator for automatic retry logic
- Provides RecoveryStrategies and FileCorruptionDetector classes
- Fixes critical import error in enhanced_provider.py
- Fix CORS security vulnerability in fastapi_app.py
- Replace allow_origins=['*'] with environment-based config
- Use settings.cors_origins for production configurability
- Add security warnings in code comments
## Type Hints Improvements
- Fix invalid type hint syntax in Provider.py
- Change (str, [str]) to tuple[str, dict[str, Any]]
- Rename GetLink() to get_link() (PEP8 compliance)
- Add comprehensive docstrings for abstract method
- Update streaming provider implementations
- voe.py: Add full type hints, update method signature
- doodstream.py: Add full type hints, update method signature
- Fix parameter naming (embededLink -> embedded_link)
- Both now return tuple with headers dict
- Enhance base_provider.py documentation
- Add comprehensive type hints to all abstract methods
- Add detailed parameter documentation
- Add return type documentation with examples
## Files Modified
- Created: src/core/error_handler.py (error handling infrastructure)
- Modified: 9 source files (type hints, naming, imports)
- Added: QUALITY_IMPROVEMENTS.md (implementation details)
- Added: TEST_VERIFICATION_REPORT.md (test status)
- Updated: QualityTODO.md (progress tracking)
## Testing
- All tests passing (unit, integration, API)
- No regressions detected
- All 10+ type checking violations resolved
- Code follows PEP8 and PEP257 standards
## Quality Metrics
- Import errors: 1 -> 0
- CORS security: High Risk -> Resolved
- Type hint errors: 12+ -> 0
- Abstract method docs: Minimal -> Comprehensive
- Test coverage: Maintained with no regressions
2025-10-22 13:00:09 +02:00
f64ba74d93
refactor: Apply PEP8 naming conventions - convert PascalCase methods to snake_case
...
This comprehensive refactoring applies PEP8 naming conventions across the codebase:
## Core Changes:
### src/cli/Main.py
- Renamed __InitList__() to __init_list__()
- Renamed print_Download_Progress() to print_download_progress()
- Fixed variable naming: task3 -> download_progress_task
- Fixed parameter spacing: words :str -> words: str
- Updated all method calls to use snake_case
- Added comprehensive docstrings
### src/core/SerieScanner.py
- Renamed Scan() to scan()
- Renamed GetTotalToScan() to get_total_to_scan()
- Renamed Reinit() to reinit()
- Renamed private methods to snake_case:
- __ReadDataFromFile() -> __read_data_from_file()
- __GetMissingEpisodesAndSeason() -> __get_missing_episodes_and_season()
- __GetEpisodeAndSeason() -> __get_episode_and_season()
- __GetEpisodesAndSeasons() -> __get_episodes_and_seasons()
- Added comprehensive docstrings to all methods
- Fixed long line issues
### src/core/providers/base_provider.py
- Refactored abstract base class with proper naming:
- Search() -> search()
- IsLanguage() -> is_language()
- Download() -> download()
- GetSiteKey() -> get_site_key()
- GetTitle() -> get_title()
- Added proper type hints (Dict, List, etc.)
- Added comprehensive docstrings explaining contracts
- Fixed newline at end of file
### src/core/providers/aniworld_provider.py
- Renamed public methods to snake_case:
- Search() -> search()
- IsLanguage() -> is_language()
- Download() -> download()
- GetSiteKey() -> get_site_key()
- GetTitle() -> get_title()
- ClearCache() -> clear_cache()
- RemoveFromCache() -> remove_from_cache()
- Renamed private methods to snake_case:
- _GetLanguageKey() -> _get_language_key()
- _GetKeyHTML() -> _get_key_html()
- _GetEpisodeHTML() -> _get_episode_html()
- Fixed import organization
- Improved code formatting and line lengths
- Added docstrings to all methods
### src/core/SeriesApp.py
- Updated all calls to use new snake_case method names
- Updated loader calls: loader.Search() -> loader.search()
- Updated loader calls: loader.Download() -> loader.download()
- Updated scanner calls: SerieScanner.GetTotalToScan() -> SerieScanner.get_total_to_scan()
- Updated scanner calls: SerieScanner.Reinit() -> SerieScanner.reinit()
- Updated scanner calls: SerieScanner.Scan() -> SerieScanner.scan()
### tests/unit/test_series_app.py
- Updated mock calls to use new snake_case method names:
- get_total_to_scan() instead of GetTotalToScan()
- reinit() instead of Reinit()
- scan() instead of Scan()
## Verification:
- All unit tests pass ✅
- All integration tests pass ✅
- All tests pass ✅
- No breaking changes to functionality
## Standards Applied:
- PEP 8: Function/method names use lowercase with underscores (snake_case)
- PEP 257: Added comprehensive docstrings
- Type hints: Proper type annotations where applicable
- Code formatting: Fixed line lengths and spacing
2025-10-22 12:44:42 +02:00
80507119b7
fix: resolve line length violations (80+ characters)
...
- refactor src/cli/Main.py: split long logging config, user prompts, and method calls
- refactor src/config/settings.py: break long Field definitions into multiple lines
- refactor src/core/providers/enhanced_provider.py: split provider lists, headers, and long f-strings
- refactor src/core/providers/streaming/voe.py: format HTTP header setup
- update QualityTODO.md: mark all line length violations as completed
All files now comply with 88-character line limit. Code readability improved with
better-structured multi-line statements and intermediate variables for complex expressions.
2025-10-22 12:16:41 +02:00
a0f32b1a00
feat: Implement comprehensive progress callback system
...
- Created callback interfaces (ProgressCallback, ErrorCallback, CompletionCallback)
- Defined rich context objects (ProgressContext, ErrorContext, CompletionContext)
- Implemented CallbackManager for managing multiple callbacks
- Integrated callbacks into SerieScanner for scan progress reporting
- Enhanced SeriesApp with download progress tracking via callbacks
- Added error and completion notifications throughout core operations
- Maintained backward compatibility with legacy callback system
- Created 22 comprehensive unit tests with 100% pass rate
- Updated infrastructure.md with callback system documentation
- Removed completed tasks from instructions.md
The callback system provides:
- Real-time progress updates with percentage and phase tracking
- Comprehensive error reporting with recovery information
- Operation completion notifications with statistics
- Thread-safe callback execution with exception handling
- Support for multiple simultaneous callbacks per type
2025-10-17 20:05:57 +02:00
59edf6bd50
feat: Enhance SeriesApp with async callback support, progress reporting, and cancellation
...
- Add async_download() and async_rescan() methods for non-blocking operations
- Implement ProgressInfo dataclass for structured progress reporting
- Add OperationResult dataclass for operation outcomes
- Introduce OperationStatus enum for state tracking
- Add cancellation support with cancel_operation() method
- Implement comprehensive error handling with callbacks
- Add progress_callback and error_callback support in constructor
- Create 22 comprehensive unit tests for all functionality
- Update infrastructure.md with core logic documentation
- Remove completed task from instructions.md
This enhancement enables web integration with real-time progress updates,
graceful cancellation, and better error handling for long-running operations.
2025-10-17 19:45:36 +02:00
2867ebae09
health check
2025-10-12 23:06:29 +02:00
7a71715183
backup
2025-10-12 18:05:31 +02:00
3f98dd6ebb
Implement application setup and flow middleware
...
- Add SetupService for detecting application setup completion
- Create ApplicationFlowMiddleware to enforce setup auth main flow
- Add setup processing endpoints (/api/auth/setup, /api/auth/setup/status)
- Add Pydantic models for setup requests and responses
- Integrate middleware into FastAPI application
- Fix logging paths to use ./logs consistently
- All existing templates (setup.html, login.html) already working
2025-10-06 12:48:18 +02:00
00a68deb7b
Fix SeriesApp: Add missing class variable and clean up unused imports
2025-10-06 09:17:35 +02:00
969533f1de
logfile
2025-10-05 22:29:22 +02:00
85f2d2c6f7
cleanup 2
2025-10-05 22:22:04 +02:00
fe2df1514c
cleanup
2025-10-05 21:56:33 +02:00
e477780ed6
refactoring
2025-09-29 21:18:42 +02:00