api_key.py 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. from datetime import datetime
  2. from pydantic import BaseModel
  3. class APIKeyCreate(BaseModel):
  4. """Schema for creating a new API key."""
  5. name: str
  6. can_queue: bool = True
  7. can_control_printer: bool = False
  8. can_read_status: bool = True
  9. can_access_cloud: bool = False # Read /cloud/* on the creator's behalf — default off (#1182)
  10. printer_ids: list[int] | None = None # null = all printers
  11. expires_at: datetime | None = None
  12. class APIKeyUpdate(BaseModel):
  13. """Schema for updating an API key."""
  14. name: str | None = None
  15. can_queue: bool | None = None
  16. can_control_printer: bool | None = None
  17. can_read_status: bool | None = None
  18. can_access_cloud: bool | None = None
  19. printer_ids: list[int] | None = None
  20. enabled: bool | None = None
  21. expires_at: datetime | None = None
  22. class APIKeyResponse(BaseModel):
  23. """Schema for API key response (without full key)."""
  24. id: int
  25. name: str
  26. key_prefix: str # First 8 chars for identification
  27. user_id: int | None # Owner — NULL on legacy keys created before per-user ownership (#1182)
  28. can_queue: bool
  29. can_control_printer: bool
  30. can_read_status: bool
  31. can_access_cloud: bool
  32. printer_ids: list[int] | None
  33. enabled: bool
  34. last_used: datetime | None
  35. created_at: datetime
  36. expires_at: datetime | None
  37. class Config:
  38. from_attributes = True
  39. class APIKeyCreateResponse(APIKeyResponse):
  40. """Response when creating a key - includes full key (shown only once)."""
  41. key: str # Full API key, only shown on creation