The MK.IO APIs are separated by product area, but they share one operating model. Once you know how paths are scoped, how list responses are shaped, and how long-running resources expose state, you can move between the APIs without learning a new set of conventions each time.
One base URL
Section titled “One base URL”All MK.IO APIs share the same base URL:
https://app.mk.ioThe resource path is what differs between them:
| API | Path prefix | Scope |
|---|---|---|
| Media API | /api/v1/projects/{project_name}/media/ | Project |
| Management API | /api/v1/ | Organization and project |
| Fleets API | /api/v1/projects/{project_name}/fleet/ | Project |
| Infrastructure API | /api/v1/projects/{project_name}/infra/ | Project |
When a path includes /projects/{project_name}/, the request is project-scoped. When it does not, it usually targets organization-level or user-level configuration through the Management API.
Authentication is shared
Section titled “Authentication is shared”The APIs use bearer authentication:
Authorization: Bearer <YOUR_TOKEN>A single token works across setup and operational workflows. The same token can create a project through the Management API and then list assets through the Media API, as long as the issuing user has access to both operations. See Authentication for how to create one.
Requests are HTTP plus JSON
Section titled “Requests are HTTP plus JSON”The request shape follows a small set of rules:
GETreads a resource or lists a collection.PUTcreates or replaces a resource whose name is part of the URL.PATCHapplies a partial update where the endpoint supports it.POSTruns an action, such asstart,stop,allocate,scale,backup, orrestore.DELETEremoves a resource.
Send Content-Type: application/json on any request that has a JSON body.
List responses share a shape
Section titled “List responses share a shape”A list endpoint returns the resources in value and metadata in supplemental:
value: the array of resources on the current page.supplemental: counts and pagination metadata, includingsupplemental.paginationwithstart,end,records, andtotal.
That shared shape gives you one client pattern for every collection: read value, then use supplemental.pagination to decide whether to request the next page. See Pagination and filtering for the query parameters and the paging mechanism.
Many resources expose a lightweight state endpoint
Section titled “Many resources expose a lightweight state endpoint”Several resources expose a /state endpoint next to the main resource, including assets, content key policies, jobs, live events, live outputs, streaming endpoints, and streaming locators. These endpoints let you monitor a long-running resource without retrieving the full object each time. See Resource states.
Long-running workflows are common
Section titled “Long-running workflows are common”Several important workflows are not single calls:
- A job moves from queued work, through processing, to a terminal state.
- A live event is created, then started, then paired with one or more live outputs.
- A streaming endpoint is created and started before playback works.
Designing around these workflows means combining list or get operations with either polling on /state or subscribing to webhooks.
Where to go next
Section titled “Where to go next”- Authentication: create a token and make your first call.
- Error handling: the shared error body and status codes.
- Pagination and filtering: page and narrow list responses.
- Resource states: read lifecycle state and design around it.