Store Object
Stores an object under the specified bucket / key. Storing an object comes in two forms, depending on whether you want to use a key of your choosing, or let Riak assign a key to a new object.
Request
POST /types/type/buckets/bucket/keys       # Riak-defined key
PUT /types/type/buckets/bucket/keys/key    # User-defined key
POST /buckets/bucket/keys                  # Riak-defined key
PUT /buckets/bucket/keys/key               # User-defined key
For the sake of compatibility with older clients, POST is also acceptable in
the form where the key is specified.
Important headers:
- Content-Typemust be set for the stored object. Set what you expect to receive back when next requesting it.
- X-Riak-Vclockif the object already exists, the vector clock attached to the object when read.
- X-Riak-Meta-*- any additional metadata headers that should be stored with the object.
- X-Riak-Index-*- index entries under which this object should be indexed. Read more about Secondary Indexing
- Link- user and system-defined links to other resources. Read more about Links.
Optional headers (only valid on PUT):
- If-None-Match,- If-Match,- If-Modified-Since, and- If-Unmodified-Sinceinvoke conditional request semantics, matching on the- ETagand- Last-Modifiedof the existing object. These can be used to prevent overwriting a modified object. If the test fails, you will receive a- 412 Precondition Failedresponse. This does not prevent concurrent writes; it is possible for the condition to evaluate to true for multiple requests if the requests occur at the same time.
Optional query parameters:
- w(write quorum) how many replicas to write to before returning a successful response (default is defined by the bucket level)
- dw(durable write quorum) how many replicas to commit to durable storage before returning a successful response (default is defined at the bucket level)
- pwhow many primary replicas must be online to attempt a write (default is defined at the bucket level)
- returnbody=[true|false]whether to return the contents of the stored object.
This request must include a body (entity).
Response
Normal status codes:
- 201 Created(when submitting without a key)
- 200 OK
- 204 No Content
- 300 Multiple Choices
Typical error codes:
- 400 Bad Request- e.g. when r, w, or dw parameters are invalid (> N)
- 412 Precondition Failedif one of the conditional request headers failed to match (see above)
Important headers:
- Locationa relative URL to the newly-created object (when submitting without a key)
If returnbody=true, any of the response headers expected from HTTP Fetch Object may be present. Like when fetching the object, 300 Multiple Choices
may be returned if siblings existed or were created as part of the operation,
and the response can be dealt with similarly.
Example: Storing Without Key
$ curl -v http://127.0.0.1:8098/buckets/test/keys \
       -H "Content-Type: text/plain" -d 'this is a test'
* About to connect() to 127.0.0.1 port 8098 (#0)
*   Trying 127.0.0.1... connected
* Connected to 127.0.0.1 (127.0.0.1) port 8098 (#0)
> POST /buckets/test/keys HTTP/1.1
> User-Agent: curl/7.19.4 (universal-apple-darwin10.0) libcurl/7.19.4 OpenSSL/0.9.8l zlib/1.2.3
> Host: 127.0.0.1:8098
> Accept: */*
> Content-Type: text/plain
> Content-Length: 14
>
< HTTP/1.1 201 Created
< Vary: Accept-Encoding
< Server: MochiWeb/1.1 WebMachine/1.9.0 (participate in the frantic)
< Location: /buckets/test/keys/bzPygTesROPtGGVUKfyvp2RR49
< Date: Fri, 30 Sep 2011 15:24:35 GMT
< Content-Type: application/json
< Content-Length: 0
<
* Connection #0 to host 127.0.0.1 left intact
* Closing connection #0
Example: Storing With Key
$ curl -v -XPUT -d '{"bar":"baz"}' -H "Content-Type: application/json" -H "X-Riak-Vclock: a85hYGBgzGDKBVIszMk55zKYEhnzWBlKIniO8mUBAA==" http://127.0.0.1:8098/buckets/test/keys/doc?returnbody=true
* About to connect() to 127.0.0.1 port 8098 (#0)
*   Trying 127.0.0.1... connected
* Connected to 127.0.0.1 (127.0.0.1) port 8098 (#0)
> PUT /buckets/test/keys/doc?returnbody=true HTTP/1.1
> User-Agent: curl/7.19.4 (universal-apple-darwin10.0) libcurl/7.19.4 OpenSSL/0.9.8l zlib/1.2.3
> Host: 127.0.0.1:8098
> Accept: */*
> Content-Type: application/json
> X-Riak-Vclock: a85hYGBgzGDKBVIszMk55zKYEhnzWBlKIniO8mUBAA==
> Content-Length: 13
>
< HTTP/1.1 200 OK
< X-Riak-Vclock: a85hYGBgymDKBVIszMk55zKYEhnzWBlKIniO8kGF2TyvHYIKfwcJZwEA
< Vary: Accept-Encoding
< Server: MochiWeb/1.1 WebMachine/1.9.0 (participate in the frantic)
< Link: </buckets/test>; rel="up"
< Date: Fri, 30 Sep 2011 15:24:35 GMT
< Content-Type: application/json
< Content-Length: 13
<
* Connection #0 to host 127.0.0.1 left intact
* Closing connection #0
{"bar":"baz"}