Перейти к основному содержанию
GET
/
v1
/
storage
/
files
Получить список файлов
curl --request GET \
  --url https://polza.ai/api/v1/storage/files \
  --header 'Authorization: Bearer <token>'
[
  {
    "id": "file_123abc",
    "fileType": "IMAGE",
    "mimeType": "image/jpeg",
    "source": "USER_UPLOAD",
    "storagePolicy": "TEMP_UPLOAD",
    "url": "https://s3.polza.ai/f/211837/2026/01/t_c2446f3cf93ac9f5.png",
    "size": 154832,
    "createdAt": "2025-01-03T12:00:00.000Z",
    "updatedAt": "2025-01-03T12:00:00.000Z",
    "externalUserId": "external_user_456",
    "expiresAt": "2025-01-03T14:00:00.000Z"
  }
]

Параметры запроса

Пагинация

ПараметрТипПо умолчаниюОписание
pageinteger1Номер страницы (от 1)
limitinteger20Количество записей на странице (1-100)

Фильтрация

ПараметрТипОписание
fileTypestringТип файла: IMAGE, VIDEO, AUDIO
sourcestringИсточник: USER_UPLOAD, AI_GENERATION
storagePolicystringПолитика: TEMP_UPLOAD, TEMP_GENERATION, PERMANENT
externalUserIdstringID внешнего пользователя (макс. 128 символов)

Сортировка

ПараметрТипПо умолчаниюОписание
sortBystringcreatedAtПоле: createdAt, size, expiresAt, externalUserId
sortOrderstringdescНаправление: asc, desc

Пример

curl "https://polza.ai/api/v1/storage/files?fileType=IMAGE&page=1&limit=10&sortBy=createdAt&sortOrder=desc" \
  -H "Authorization: Bearer YOUR_API_KEY"

Ответ (200)

{
  "data": [
    {
      "id": "file_abc123",
      "fileType": "IMAGE",
      "mimeType": "image/png",
      "source": "USER_UPLOAD",
      "storagePolicy": "PERMANENT",
      "url": "https://cdn.polza.ai/files/file_abc123.png",
      "size": 245760,
      "externalUserId": null,
      "expiresAt": null,
      "createdAt": "2025-01-15T10:30:00Z",
      "updatedAt": "2025-01-15T10:30:00Z"
    }
  ],
  "meta": {
    "page": 1,
    "limit": 10,
    "total": 42,
    "totalPages": 5
  }
}

Авторизации

Authorization
string
header
обязательно

API ключ передаётся в заголовке: Authorization: Bearer <POLZA_AI_API_KEY>

Параметры запроса

page
number

Номер страницы (начиная с 1)

Пример:

1

limit
number

Лимит записей на странице (1-100)

Пример:

20

externalUserId
string

Фильтр по ID внешнего пользователя

Пример:

"user_123"

fileType
enum<string>

Фильтр по типу файла

Доступные опции:
IMAGE,
VIDEO,
AUDIO
Пример:

"IMAGE"

source
enum<string>

Фильтр по источнику файла

Доступные опции:
USER_UPLOAD,
AI_GENERATION
Пример:

"USER_UPLOAD"

storagePolicy
enum<string>

Фильтр по политике хранения

Доступные опции:
TEMP_UPLOAD,
TEMP_GENERATION,
PERMANENT
Пример:

"TEMP_UPLOAD"

sortBy
enum<string>

Поле для сортировки

Доступные опции:
createdAt,
size,
expiresAt,
externalUserId
Пример:

"createdAt"

sortOrder
enum<string>

Порядок сортировки

Доступные опции:
asc,
desc
Пример:

"desc"

Ответ

200 - application/json
id
string
обязательно

ID файла

Пример:

"file_123abc"

fileType
string
обязательно

Тип файла (IMAGE, VIDEO, AUDIO)

Пример:

"IMAGE"

mimeType
string
обязательно

MIME-тип файла

Пример:

"image/jpeg"

source
string
обязательно

Источник файла (USER_UPLOAD, AI_GENERATION)

Пример:

"USER_UPLOAD"

storagePolicy
string
обязательно

Политика хранения (TEMP_UPLOAD, TEMP_GENERATION, PERMANENT)

Пример:

"TEMP_UPLOAD"

url
string
обязательно

URL файла

Пример:

"https://s3.polza.ai/f/211837/2026/01/t_c2446f3cf93ac9f5.png"

size
number
обязательно

Размер файла в байтах

Пример:

154832

createdAt
string<date-time>
обязательно

Дата создания

Пример:

"2025-01-03T12:00:00.000Z"

updatedAt
string<date-time>
обязательно

Дата обновления

Пример:

"2025-01-03T12:00:00.000Z"

externalUserId
object

ID внешнего пользователя клиента (для группировки файлов)

Пример:

"external_user_456"

expiresAt
object

Дата истечения срока действия файла

Пример:

"2025-01-03T14:00:00.000Z"