Usage
Managing media, playlists and bindings
You can manage media, playlists and bindings using
the /media, /playlists and /bindings endpoints.
The API follows RESTful conventions,
so you can use the following HTTP methods:
GETto retrieve a resource or a list of resourcesPOSTto create a new resourcePATCHto update an existing resourceDELETEto delete an existing resource
For example, to create a new media,
you can use curl
to send a POST request to the /media endpoint:
curl \
--request POST \
--header "Content-Type: application/json" \
--data '{"name": "My Media"}' \
http://localhost:10200/media
Uploading and downloading media content
You can upload and download media content
using the /media/:id/content endpoint.
To upload media content, you can use
curl to send a PUT request
streaming the content from a file:
curl \
--request PUT \
--header "Content-Type: audio/mpeg" \
--header "Transfer-Encoding: chunked" \
--upload-file my-media.mp3 \
http://localhost:10200/media/d06997da-6072-4a06-b7d4-6dd46cbbf716/content
To download media content, you can use
curl to send a GET request
and save the response body to a file:
curl \
--request GET \
--output my-media.mp3 \
http://localhost:10200/media/d06997da-6072-4a06-b7d4-6dd46cbbf716/content
Retrieving playlists in M3U format
You can retrieve playlists in M3U format
using the /playlists/:id/m3u endpoint.
To retrieve a playlist in M3U format,
you can use curl
to send a GET request and save the response body to a file:
curl \
--request GET \
--output my-playlist.m3u \
http://localhost:10200/playlists/944f57ed-56eb-43a4-bc80-0667b9f0c1e7/m3u
Ping
You can check the status of the service by sending
either a GET or HEAD request to the /ping endpoint.
The service should respond with a 204 No Content status code.
For example, you can use curl to do that:
curl --request HEAD --head http://localhost:10200/ping
Server-Sent Events
You can subscribe to
Server-Sent Events (SSE)
by sending a GET request to the /sse endpoint.
The service should send you the events as they happen.
For example, you can use curl to do that:
curl --request GET --no-buffer http://localhost:10200/sse
OpenAPI
You can view the OpenAPI
documentation made with Scalar
by navigating to the /openapi endpoint in your browser.
You can also download the specification in JSON format
by sending a GET request to the /openapi/openapi.json endpoint.
For example, you can use curl to do that:
curl --request GET http://localhost:10200/openapi/openapi.json