Commit Graph

290 Commits

Author SHA1 Message Date
Oleg Proskurin 59874d9437 fix docker 2025-12-15 00:34:45 +07:00
Oleg Proskurin 5e899419a4 fix: remove old metatags 2025-12-15 00:19:15 +07:00
Oleg Proskurin 1f4766a33d fix: viewport 2025-12-15 00:12:58 +07:00
Oleg Proskurin d1d9517926 feat: add metadata 2025-12-15 00:11:11 +07:00
Oleg Proskurin c66a82d736 feat: set homepage 2025-12-15 00:02:55 +07:00
Oleg Proskurin b5e25eacf1 chore: remove wrong files 2025-12-15 00:01:57 +07:00
Oleg Proskurin 257131c12d secure: bump next version 2025-12-14 23:55:47 +07:00
Oleg Proskurin d798faec41 ts fix 2025-12-14 18:11:20 +07:00
Oleg Proskurin 35d28bca80 Merge branch 'feature/homepage' 2025-12-14 16:15:32 +07:00
Oleg Proskurin 6defdbafc4 docs: deploying instruction 2025-12-14 15:03:02 +07:00
Oleg Proskurin 77006e8f47 fix: email storing 2025-12-14 15:02:33 +07:00
Oleg Proskurin 98d8e31373 fix: prod build 2025-12-14 14:17:25 +07:00
Oleg Proskurin 1aa7687dc9 chore: upd scripts 2025-12-14 13:39:38 +07:00
Oleg Proskurin 41f00aa352 feat: store emails 2025-12-14 13:36:34 +07:00
Oleg Proskurin 6650c03188 feat: improve input style 2025-12-14 12:14:33 +07:00
Oleg Proskurin 4a47c53a0a feat: update cards styles 2025-12-14 12:07:31 +07:00
Oleg Proskurin 986a3063bb feat: better card styles 2025-12-14 11:53:32 +07:00
Oleg Proskurin 9c428383d7 feat: styles 2025-12-05 01:38:10 +07:00
Oleg Proskurin 84b34f0115 feat: add images 2025-12-05 01:18:05 +07:00
Oleg Proskurin 3feaed33c8 feat: update hero spacing 2025-12-05 00:10:47 +07:00
Oleg Proskurin 2190a2f55f fix: width 2025-12-04 23:06:36 +07:00
Oleg Proskurin c8d6214322 refactor: split by components 2025-12-04 20:15:35 +07:00
Oleg Proskurin 988c7946b9 feat: add metal effect 2025-12-04 15:08:34 +07:00
Oleg Proskurin b2cab168bc feat: add styles to shape section 2025-12-04 14:40:42 +07:00
Oleg Proskurin 0c656d21a2 fix: ts 2025-12-04 13:18:57 +07:00
Oleg Proskurin 4f59f775ae chore: styles 2025-12-04 13:13:51 +07:00
Oleg Proskurin 7f37a5667b feat: use gloweffect 2025-12-04 13:12:16 +07:00
Oleg Proskurin d688c5890a feat: working glow 2025-12-04 12:56:12 +07:00
Oleg Proskurin 21ac410780 fix: page 2025-12-03 15:08:36 +07:00
Oleg Proskurin 7588817803 feat: add homepage v1 2025-12-03 13:09:11 +07:00
usulpro c148c53013 feature(api): v1 (#1) from feature/api-development into main
Reviewed-on: #1
2025-11-29 23:03:00 +07:00
Oleg Proskurin 1e080bd87c doc: new api 2025-11-28 10:49:01 +07:00
Oleg Proskurin e70610e00d feat: improve tests 2025-11-28 00:37:45 +07:00
Oleg Proskurin 504b1f8395 fix: api & docs 2025-11-28 00:07:06 +07:00
Oleg Proskurin df3737ed44 feat: added manual tests 2025-11-27 00:28:40 +07:00
Oleg Proskurin 0ca1a4576e fix: api 2025-11-26 23:32:13 +07:00
Oleg Proskurin beedac385e fix: basic 2025-11-26 00:22:34 +07:00
Oleg Proskurin 6803a23aa3 fix: basic 2025-11-26 00:11:48 +07:00
Oleg Proskurin 8623442157 fix: aliases 2025-11-25 22:47:54 +07:00
Oleg Proskurin 88cb1f2c61 fix: upload 2025-11-24 00:14:46 +07:00
Oleg Proskurin fba243cfbd feat: add test 2025-11-23 23:01:46 +07:00
Oleg Proskurin 7da1973072 chore: update manual test 2025-11-23 21:44:39 +07:00
Oleg Proskurin 191a745133 fix: remove url field 2025-11-23 21:28:31 +07:00
Oleg Proskurin 5e52d4ff9c fix: show image dimentions 2025-11-23 21:03:55 +07:00
Oleg Proskurin e3ddf1294f fix: prompts storage 2025-11-23 20:47:48 +07:00
Oleg Proskurin 6235736f4f fix: flow creation 2025-11-23 14:34:54 +07:00
Oleg Proskurin 3cd7eb316d feat: new tests 2025-11-18 19:20:18 +07:00
Oleg Proskurin 85e68bcb31 doc: update documentation 2025-11-18 00:04:10 +07:00
Oleg Proskurin a1c47a37f0 docs: update admin documentation with IP rate limiting and scope error codes
Update admin.md to reflect Phase 3 Part 3 implementation changes:

**Rate Limiting Section:**
- Split into two subsections: API Key Rate Limiting and IP-Based Rate Limiting
- API Key Rate Limiting: Expanded affected endpoints list to include scope management
- IP-Based Rate Limiting: New section documenting 10/hour limit for live URLs
  - Separate from API key limits
  - Only cache MISS counts toward limit
  - Supports X-Forwarded-For header
  - In-memory store with automatic cleanup

**Error Codes Section:**
- Reorganized into categorized tables for better clarity
- Added HTTP 409 (Conflict) status code
- Added Authentication Error Codes table
- Added Rate Limiting Error Codes table with both API key and IP limits
- Added Live Scope Error Codes table:
  - SCOPE_INVALID_FORMAT (400)
  - SCOPE_ALREADY_EXISTS (409)
  - SCOPE_NOT_FOUND (404)
  - IMAGE_NOT_IN_SCOPE (400)

**Documentation Improvements:**
- All error responses include standard format
- Rate limit errors include Retry-After header
- Scope endpoints require project key authentication
- Comprehensive notes for each section

All documentation now accurately reflects current API v1 implementation.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-17 23:45:17 +07:00
Oleg Proskurin a92b1bf482 docs: phase 3 part 4 - comprehensive JSDoc documentation for all v1 API endpoints
Add complete JSDoc documentation to all API v1 endpoints with detailed descriptions,
parameters, returns, error codes, and usage examples (Section 12).

**Generation Endpoints (generations.ts):**
- POST / - Create generation with references, aliases, and enhancement
- GET / - List with flow/status filtering and pagination
- GET /:id - Get single generation with full relations
- PUT /:id - Update with auto-regeneration on prompt/aspectRatio change
- POST /:id/regenerate - Regenerate with exact same parameters
- POST /:id/retry - Legacy endpoint (deprecated, delegates to regenerate)
- DELETE /:id - Delete with alias protection rules

**Flow Endpoints (flows.ts):**
- GET / - List flows with computed counts and pagination
- GET /:id - Get single flow with generationCount and imageCount
- GET /:id/generations - List flow's generations with pagination
- GET /:id/images - List flow's images with pagination
- PUT /:id/aliases - Update flow-scoped aliases (JSONB merge)
- DELETE /:id/aliases/:alias - Remove specific flow alias
- POST /:id/regenerate - Regenerate most recent generation in flow
- DELETE /:id - Hard delete flow (generations/images remain)

**Image Endpoints (images.ts):**
- POST /upload - Upload with flowId logic (undefined=auto, null=none, string=specific)
- GET / - List with flow/source/alias filtering and pagination
- GET /resolve/:alias - 3-tier resolution (technical → flow → project)
- GET /:id - Get single image with complete details
- PUT /:id - Update focal point and metadata
- PUT /:id/alias - Assign project-scoped alias (Section 6.1)
- DELETE /:id - Hard delete with MinIO cleanup and cascades

**CDN Endpoints (cdn.ts):**
- GET /:orgSlug/:projectSlug/img/:filenameOrAlias - Public image serving
  - Supports filename and @alias access
  - Long-term browser caching (1 year)
  - No authentication required
- GET /:orgSlug/:projectSlug/live/:scope - Live URL generation
  - Automatic prompt-based caching
  - IP rate limiting (10/hour, cache hits excluded)
  - Lazy scope creation
  - Scope generation limits
  - Cache key from prompt + params
  - X-Cache-Status: HIT|MISS headers

**Scope Management Endpoints (scopes.ts):**
- POST / - Create scope manually with settings
- GET / - List with currentGenerations stats and pagination
- GET /:slug - Get single scope by slug with stats
- PUT /:slug - Update settings (allowNewGenerations, limits)
- POST /:slug/regenerate - Regenerate specific image or all in scope
- DELETE /:slug - Delete scope with cascading image deletion

**JSDoc Standards Applied:**
- Complete function descriptions with use cases
- @route method and path
- @authentication requirements and key types
- @rateLimit specifications where applicable
- @param detailed parameter descriptions with types and optionality
- @returns status codes with response descriptions
- @throws error codes with explanations
- @example realistic usage examples with request/response samples
- @deprecated tags for legacy endpoints

**Documentation Features:**
- Comprehensive parameter descriptions
- Default values clearly indicated
- Type information for all parameters
- Error code documentation
- Multiple examples per complex endpoint
- Response header documentation
- Cache behavior explanations
- Flow logic documentation
- Alias resolution precedence details
- Rate limiting specifics

All JSDoc follows standardized format for consistent API documentation
across the entire v1 API surface. Zero new TypeScript errors introduced.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-17 23:32:13 +07:00