2010-08-03 04:05:54 +00:00
|
|
|
The /camli/preupload endpoint is used to begin uploading a blob.
|
|
|
|
|
|
|
|
A request to this endpoint will instruct the client where to actually upload the blob and what blobs are already present in the store.
|
|
|
|
|
|
|
|
|
|
|
|
Preupload request:
|
|
|
|
|
2010-06-21 06:14:30 +00:00
|
|
|
POST /camli/preupload HTTP/1.1
|
|
|
|
Host: example.com
|
|
|
|
|
|
|
|
camliversion=1&
|
|
|
|
blob1=sha1-9b03f7aca1ac60d40b5e570c34f79a3e07c918e8&
|
2010-07-26 02:03:20 +00:00
|
|
|
blob2=sha1-abcdabcdabcdabcdabcdabcdabcdabcdabcdabcd&
|
|
|
|
blob3=sha1-deadbeefdeadbeefdeadbeefdeadbeefdeadbeef
|
2010-06-21 06:14:30 +00:00
|
|
|
|
2010-08-03 04:05:54 +00:00
|
|
|
Response:
|
|
|
|
|
2010-06-21 06:14:30 +00:00
|
|
|
HTTP/1.1 200 OK
|
|
|
|
Content-Length: ...
|
2010-08-03 04:05:54 +00:00
|
|
|
Content-Type: text/javascript
|
2010-06-21 06:14:30 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
"alreadyHave": [
|
2010-07-26 02:03:20 +00:00
|
|
|
{"blobRef": "sha1-abcdabcdabcdabcdabcdabcdabcdabcdabcdabcd",
|
2010-06-21 06:14:30 +00:00
|
|
|
"size": 12312}
|
|
|
|
],
|
2010-08-03 04:05:54 +00:00
|
|
|
"maxUploadSize": 1048576,
|
2010-07-26 02:03:20 +00:00
|
|
|
"uploadUrl": "http://upload-server.example.com/some/server-chosen/url",
|
2010-06-21 06:17:56 +00:00
|
|
|
"uploadUrlExpirationSeconds": 7200,
|
2010-06-21 06:14:30 +00:00
|
|
|
}
|
|
|
|
|
2010-08-03 04:05:54 +00:00
|
|
|
Response keys:
|
|
|
|
|
|
|
|
alreadyHave required Array of {"blobRef": BLOBREF, "size": INT_bytes}
|
|
|
|
for blobs that the system already has. Empty
|
|
|
|
list if no blobs are already present.
|
|
|
|
maxUploadSize required Integer of max byte size for whole request
|
|
|
|
payload, which may be one or more blobs.
|
|
|
|
uploadUrl required Next URL to use to upload any more blobs.
|
|
|
|
uploadUrlExpirationSeconds
|
|
|
|
required How long the upload URL will be valid for.
|
|
|
|
|
|
|
|
|
|
|
|
Upload request:
|
2010-06-21 06:14:30 +00:00
|
|
|
|
2010-07-26 02:03:20 +00:00
|
|
|
POST /some/server-chosen/url HTTP/1.1
|
|
|
|
Host: upload-server.example.com
|
|
|
|
Content-Type: multipart/form-data; boundary=randomboundaryXYZ
|
2010-06-21 06:14:30 +00:00
|
|
|
|
2010-07-26 02:03:20 +00:00
|
|
|
--randomboundaryXYZ
|
2010-06-21 06:14:30 +00:00
|
|
|
Content-Disposition: form-data; name="sha1-9b03f7aca1ac60d40b5e570c34f79a3e07c918e8"
|
|
|
|
Content-Type: application/octet-stream
|
|
|
|
|
|
|
|
(binary blob data)
|
2010-07-26 02:03:20 +00:00
|
|
|
--randomboundaryXYZ
|
|
|
|
Content-Disposition: form-data; name="sha1-deadbeefdeadbeefdeadbeefdeadbeefdeadbeef"
|
2010-06-21 06:14:30 +00:00
|
|
|
Content-Type: application/octet-stream
|
|
|
|
|
|
|
|
(binary blob data)
|
2010-07-26 02:03:20 +00:00
|
|
|
--randomboundaryXYZ--
|
2010-06-21 06:14:30 +00:00
|
|
|
|
2010-08-03 04:05:54 +00:00
|
|
|
Response (may be a 301/302/303 redirect to this data):
|
|
|
|
|
2010-06-21 06:17:56 +00:00
|
|
|
HTTP/1.1 200 OK
|
|
|
|
Content-Type: text/plain
|
|
|
|
|
|
|
|
{
|
2010-07-26 02:03:20 +00:00
|
|
|
"received": [
|
|
|
|
{"blobRef": "sha1-9b03f7aca1ac60d40b5e570c34f79a3e07c918e8",
|
|
|
|
"size": 12312},
|
|
|
|
{"blobRef": "sha1-deadbeefdeadbeefdeadbeefdeadbeefdeadbeef",
|
|
|
|
"size": 29384933}
|
|
|
|
],
|
2010-06-21 06:17:56 +00:00
|
|
|
"maxUploadSize": 1048576,
|
|
|
|
"uploadUrl": "http://example.com/TheNextUploadUrlRandomString",
|
|
|
|
"uploadUrlExpirationSeconds": 7200,
|
|
|
|
}
|
2010-06-21 06:14:30 +00:00
|
|
|
|
2010-08-03 04:05:54 +00:00
|
|
|
Response keys:
|
|
|
|
|
|
|
|
received required Array of {"blobRef": BLOBREF, "size": INT_bytes}
|
|
|
|
for blobs that were successfully saved. Empty
|
|
|
|
list in the case nothing was received.
|
|
|
|
maxUploadSize required Integer of max byte size for whole request
|
|
|
|
payload, which may be one or more blobs.
|
|
|
|
uploadUrl required Next URL to use to upload any more blobs.
|
|
|
|
uploadUrlExpirationSeconds
|
|
|
|
required How long the upload URL will be valid for.
|
|
|
|
|
|
|
|
|
2010-06-21 06:14:30 +00:00
|
|
|
If connection drops during a POST to an upload URL, you should re-do a
|
2010-06-21 06:17:56 +00:00
|
|
|
preupload request to verify which objects were received by the server
|
2010-07-26 02:03:20 +00:00
|
|
|
and which were not. Also, the URL you received from preupload before
|
|
|
|
might no longer work, so preupload is required to a get a valid upload
|
|
|
|
URL.
|
2010-06-21 06:14:30 +00:00
|
|
|
|
2010-07-26 02:03:20 +00:00
|
|
|
For information on resuming truncated uploads, read blob-upload-resume.txt
|
2010-07-11 04:58:30 +00:00
|
|
|
|