Creating design documents
To create a new design document, use the PUT /bucket/_design/[ddoc-name] HTTP method and URI on the 8092 port.
Description
Design documents are used to store one or more view definitions. Views can be defined within a design document and uploaded to the server.
Design documents are validated before being created or updated in the system. The validation checks for valid JavaScript and for the use of valid built-in reduce functions. Any validation failure is reported as an error.
The format of the design document should include all the views defined in the design document, incorporating both the map and reduce functions for each named view.
HTTP method and URI
PUT /bucket/_design/[ddoc-name]| Request data | Design document definition (JSON) | 
| Response data | Success and stored design document ID | 
| Authentication required | Optional | 
Syntax
Curl request syntax:
curl -X PUT
	-u [admin]:[password]
	-H 'Content-Type: application/json'
	http://[localhost]:8092/[bucket-name/_design/[ddoc-name]
			Example
A design document, byfield can be created using a text file (byfield.ddoc ) with design document content. In this example, the view is a development view. Development view names must have the dev_.
Curl request example:
curl -X PUT
	-H 'Content-Type: application/json'
	http://user:[email protected]:8092/sales/_design/dev_byfield
	-d @byfield.ddoc
As a PUT command, the URL is also significant, in that the location designates the name of the design document. In the example, the URL includes the name of the bucket ( sales ) and the name of the design document being created is dev_byfield.
In the above example:
- -X PUT
					Indicates that an HTTP PUT operation is requested. 
- -H 'Content-Type: application/json'
					Specifies the HTTP header information. Couchbase Server requires the information to be sent and identified as the application/json datatype. Information not supplied with the content-type set in this manner is rejected. 
- http://user:[email protected]:8092/sales/_design/dev_byfield 
					The URL, including authentication information, of the bucket where you want the design document uploaded. The user and password are either the administration privileges or the bucket name and bucket password for SASL protected buckets. If the bucket does not have a password, then authentication information is not required. 
- -d @byfield.ddoc
				Specifies that the data payload should be loaded from the file byfield.ddoc. 
Response
If successful, the HTTP response code is 201 OK (created) and the returned JSON fields are ok and ID.
{
    "ok":true,
    "id":"_design/dev_byfield"
}
The top-level views field lists one or more view definitions (the byloc view in this example), and for each view, a corresponding map() function. For example:
{
   "views" : {
      "byloc" : {
         "map" : "function (doc, meta) {\n  if (meta.type == \"json\") 
         	{\n    emit(doc.city, doc.sales);\n  } else 
         	{\n    emit([\"blob\"]);\n  }\n}"
      }
   }
}
Response codes
| Response codes | Description | 
|---|---|
| 201 | Document created successfully. | 
| 401 | The item requested not available using the supplied authorization or authorization not supplied. | 
In the event of an error, the returned JSON includes the field error with a short description and the field reason with a longer description of the problem.