Skip to content

Latest commit

 

History

History
41 lines (21 loc) · 2.08 KB

05.md

File metadata and controls

41 lines (21 loc) · 2.08 KB

BUD-05

Media optimization endpoints

draft optional

Defines the PUT /media endpoint for processing and optimizing media

PUT /media

The PUT /media endpoint MUST accept binary data in the body of the request and MAY use the Content-Type and Content-Length headers to get the MIME type and size of the media

The server should preform any optimizations or conversions it deems necessary in order to make the media more suitable for distribution

The endpoint MUST respond with a 2xx status and a blob descriptor of the new processed blob

Servers MAY reject media uploads for any reason and should respond with the appropriate HTTP 4xx status code and an error message explaining the reason for the rejection

Upload Authorization

Servers MAY require an upload authorization event to identify the uploader

If a server requires an upload authorization event it MUST preform all the checks outlined in the /upload endpoint

Limitations

This endpoint is intentionally limited to optimizing a single blob with the goal of making it easier to distribute

How the blob is optimized is the sole respirability of the server and the client should have no say in what optimization process is used

The goal of this endpoint is to provide a simple "trusted" optimization endpoint clients can use to optimize media for distribution

If a longer optimization or transformation process is needed, or if the client needs to specify how a blob should be transformed. there are other tools and protocol that should be used.

Client Implementation

Clients MAY let a user selected a "trusted processing" server for uploading images or short videos

Once a server has been selected, the client can upload the original media to the /media endpoint of the trusted server and get the optimized blob back

Then optionally the client can ask the user to sign another upload authorization event for the new optimized blob and call the /mirror endpoint on other servers to distribute the blob