Функции обновления, вызываемые из расширения MyCouch
Я пытаюсь вызвать функции обновления из MyCouch. В документации Mycouch указан только устаревший пример с методом Post на_design
документы. Но как использовать функцию обновления
{
"_id": "_design/artists",
"language": "javascript",
"views": {
"albums": {
"map": "function(doc) { if(doc.$doctype !== 'artist') return; emit(doc.name, doc.albums);}"
}
}
};
client.Documents.Post(designDocumentAsJson);
Как выполнить функцию обновления в _design couchDB, отправив новый документ?
В документации couchDB говорится об этом вызове.
PUT /{db}/_design/{ddoc}/_update/{func}/{docid}
1 ответ
Решение
PUT /{db}/_design/{ddoc}/_update/{func}/{docid}
Executes update function on server side for the specified document.
Parameters:
db – Database name
ddoc – Design document name
func – Update function name
docid – Document ID
Вы можете вставить документ Design, как показано ниже, в базу данных: https://docs.couchdb.org/en/stable/api/ddoc/render.html
{
"_id": "_design/albums",
"language": "javascript",
"updates": {
"addAlbum": "function(doc, req) {\n if (!doc){\n return [null, {'code': 400,\n 'json': {'error': 'missed',\n 'reason': 'no document to update'}}]\n } else {\n var body = JSON.parse(req.body);\n doc.albums.push(body.album);\n return [doc, {'json': {'status': 'ok'}}];\n }\n}\n"
}
}
функция (без строкового преобразования):
function(doc, req) {
if (!doc){
return [null, {'code': 400,
'json': {'error': 'missed',
'reason': 'no document to update'}}]
} else {
var body = JSON.parse(req.body);
doc.albums.push(body.album);
return [doc, {'json': {'status': 'ok'}}];
}
}
Пример документа:
{
"_id": "albumsId1",
"albums": [
1
]
}
После Api
Запрос:
POST http://localhost:5984/test/_design/albums/_update/addAlbum/albumsId1
Content-Type:application/json
Accept:application/json
{"album":2}
Отклик:
{
"status": "ok"
}
документ после обновления
{
"_id": "albumsId1",
"_rev": "19-7edb16db3bae388685f554138d562bd0",
"albums": [
1,
2
]
}