SashegDev
f6fbb66cdc
Server: PID-based logging - only master logs startup
...
- Only master PID logs blocklist loading, pack scanning, etc.
- Worker processes stay silent during startup
- Much cleaner logs
2026-05-07 17:45:36 +00:00
SashegDev
d7a928cce4
Server: Add file lock for blocklist loading
...
- Only one worker downloads blocklist
- Other workers wait and read from cache
- Prevents duplicate downloads on startup
2026-05-07 17:43:21 +00:00
SashegDev
3bd3d1d0e8
Server: Cache blocklist to file + disable httpx debug logs
...
- Blocklist now cached to data/blocklist_cache.txt
- Only downloads once, then reuses cache
- Disable httpx/httpcore debug logs to reduce noise
2026-05-07 17:42:15 +00:00
SashegDev
df9fa7b867
Server: Fix blocklist loading - only once at startup
...
- Move public blocklist loading into lifespan (not on import)
- Avoids loading 8 times with 4 workers
- Cleaner startup logs
2026-05-07 17:40:32 +00:00
SashegDev
81fbe028e8
Server: Auto-load public IP blocklists
...
- Load known bad IPs from FireHOL blocklists on startup
- ~4400 IPs blocked by default
- Set PUBLIC_BLOCKLIST=false to disable
- Combined with manual BLOCKED_IPS env var
2026-05-07 17:38:08 +00:00
SashegDev
513c07666b
Server: Simplify IP filtering - only blacklist
...
- Remove whitelist (not needed for public launcher)
- Only BLOCKED_IPS env var supported now
2026-05-07 17:14:47 +00:00
SashegDev
04f97c3c80
Server: Add bot protection middleware
...
- Global rate limiting (60 requests/minute per IP)
- IP whitelist/blacklist via ALLOWED_IPS and BLOCKED_IPS env vars
- Bot detection - silent 404 for suspicious paths (.env, phpinfo, etc.)
- Path traversal detection
- Reduced noise in logs from bot scanners
2026-05-07 17:09:45 +00:00
SashegDev
f40cf7afed
Server: Add legacy build support
...
- Add version parsing to distinguish new vs legacy format builds
- New format: ZernMC-win-*.zip (1.0.8+ with bundled JRE21/JavaFX)
- Legacy: ZernMCLauncher-*.zip (< 1.0.8 or with suffix)
- /launcher/download/latest now returns new format by default
- Add /launcher/download/legacy endpoint for old builds
- Add legacy info to /launcher/info and /launcher/version responses
- Update download_zip to accept both ZernMCLauncher- and ZernMC-win- patterns
2026-05-07 16:44:10 +00:00
SashegDev
b4431702dc
feat: add NeoForge support, fix Forge installPack bug, update server proxy
...
- Fix MinecraftLib.installPack() returning false for Forge (was dead code)
- Add NeoForgeInstaller.java with installer download and execution
- Update LaunchCommandBuilder with NeoForge JVM args, classpath, launch args
- Update LaunchMenu with NeoForge option, version selector, support check
- Update Instance.java loader type comment (vanilla, fabric, forge, neoforge)
- Update PackDownloader to handle neoforge loader type
- Update ZHttpClient with NEOFORGE_MAVEN service type and detection
- Add NeoForge proxy endpoints (/proxy/neoforge/versions, /proxy/neoforge/maven)
- Add maven.neoforged.net to proxy allowed_domains
- Add asset_index to PackMeta model and pack_manager scanning
- Include asset_index in /packs list endpoint response
2026-05-04 22:53:22 +00:00
SashegDev
8939e24e69
test(server): add client-facing endpoint tests (20 tests), fix pack contract assertions
...
- Add test_client.py with comprehensive client-server contract tests:
- TestAuthFlowClient: full register → login → refresh → validate → /admin/me → logout lifecycle
- TestPacksClientContract: /packs response fields matching ServerPack.java
- TestPackManifestClientContract: /pack/{name} fields matching PackManifest.java
- TestPackDiffClientContract: /pack/{name}/diff matching DiffResponse/FileInfo.java
(all-new, no-changes, outdated-file, extra-local-file scenarios)
- TestPackFileDownload: file serving, 404, path traversal security
- TestPackPermissions: auth/pass requirements for /packs and /diff
- TestLauncherVersion: /launcher/version endpoint
- TestProxyEndpoints: /proxy/status, /proxy/fabric/versions/loader
- Add logged_in_user_with_pass fixture (role=1) for pack-related tests
- Add pack_fixture: creates temp pack with mod file, scans it, cleans up
- Fix manifest test: files don't have 'url' field (only in diff response)
- Fix /pack/{name} test: endpoint is public, no auth required
Total: 67 tests passing (47 existing + 20 new)
2026-05-04 22:28:12 +00:00
SashegDev
c0310ed573
test(server): add comprehensive test suite (47 tests), fix DB lock and schema bugs
...
- Add pytest test suite: test_auth.py, test_admin.py, test_pass.py,
test_proxy.py, test_rate_limit.py, test_client_contract.py
- Fix SQLite 'database is locked' errors: moved log_audit() calls outside
with get_db() blocks in register, login, logout, refresh, activate_pass
- Enable WAL mode and busy_timeout in get_db() for concurrent access
- Fix /admin/me: removed non-existent 'email' column from query
- Fix /admin/users list: disambiguated activated_at column in JOIN query
- Fix /auth/refresh: now returns refresh_token + expires_in + username/uuid/role
to match AuthManager.AuthSession expectations; revokes old refresh token
- Fix conftest.py: unique usernames per test to avoid conflicts
- All 47 tests passing
2026-05-04 22:14:06 +00:00
SashegDev
c96b502ad4
fix(server,security): add ban check to validate_token, replace rate_limit DB with TTLCache
2026-05-04 21:12:35 +00:00
SashegDev
bfcffdd88d
chore(server): remove unused models, delete http_logger.py, rename viev_logs.py → view_logs.py
2026-05-04 21:10:11 +00:00
SashegDev
331fc9a863
refactor(server): clean main.py — remove duplicate imports, dead code, unify logging, fix proxy lifecycle
2026-05-04 21:09:10 +00:00
SashegDev
e347c042d5
feat(server): add /auth/pass/activate endpoint for pass code activation
2026-05-04 21:06:56 +00:00
SashegDev
bb564e6e9b
feat(server): connect admin_router to FastAPI app
2026-05-04 21:06:02 +00:00
SashegDev
6f53002266
fix(server): add role aliases in roles.py to fix broken admin_router imports
2026-05-04 21:04:44 +00:00
Sashegdev
b60e414d37
last commit to uuuuh idl
2026-05-04 15:19:46 +00:00
Sashegdev
10ec8625b9
The fuck was hapanned тут
2026-04-22 12:54:57 +00:00
Sashegdev
f24cc078c5
Merge branch 'main' into alpha
2026-04-22 15:26:39 +03:00
Sashegdev
adde40d921
Коммит, для того что бы если что роллбекать
2026-04-22 12:23:51 +00:00
Sashegdev
6bf6c1634a
Фиксы проходок (нормально, в отличии от main ветки)
...
ОНО РАБОТАЕТ СУКАААА
2026-04-20 19:30:17 +00:00
Sashegdev
d7a6eb760e
fixes
2026-04-09 18:03:00 +00:00
Sashegdev
c6dd215e9b
рефакторинг + новая система модерации
2026-04-09 17:28:48 +00:00
Sashegdev
89c0057759
Server Fixes
2026-04-08 19:56:38 +00:00
Sashegdev
bf26baaf93
1.0.7 типоооо и фиксы
2026-04-08 19:45:15 +00:00
Sashegdev
9bee361ea4
Попытка добавления проходок, аккаунтов, а так же доработка прокси
2026-04-07 17:50:29 +00:00
Sashegdev
c03d7a788f
ДОБАВЛЕНИЕ ПРОКСИ РЕЖИМА ЙОООУ 1.0.5
2026-04-06 19:57:32 +00:00
Sashegdev
0b4af1353d
Both | БЛЯЯЯ ЗАГРУЗКА ПАКОВ С СЕРВЕРА СЮДААА
2026-04-06 00:32:36 +00:00
Sashegdev
4edbe7e910
Server BugFixes + убрал генерацию sevrer команды т.к это уже в клиенте лол
2026-04-05 22:25:43 +00:00
Sashegdev
7670edbff7
server update
2026-04-04 14:57:15 +00:00