Проблема с тахтой, не разрешающей ссылки

У меня есть две модели в моей установке Ottoman 1.0.5. Один содержит контактную информацию, которая включает в себя массив документов электронной почты, а затем документ электронной почты. Я могу вставить новые контакты в порядке, а также электронные письма в документах и ​​соответствующую ссылку в контактном документе для нового электронного письма.

Вот моя модель

const ottoman = require("ottoman")
ottoman.bucket = require("../app").bucket
var ContactModel = ottoman.model("Contact",{
    timestamp: {
        type: "Date",
        default: function() {return new Date()}
    },
    first_name : "string",
    last_name : "string",
    emails: [
        {
            ref:"Email"
        }
    ]}  )
var EmailModel = ottoman.model("Email",{
timestamp: {
    type: "Date",
    default: function() {return new Date()}
},
type : "string",
address : "string",
name: "string"
} )
module.exports = {
ContactModel : ContactModel,
EmailModel : EmailModel
}

Теперь, чтобы получить контакт и все его электронные письма, я использую эту функцию

app.get("/contacts/:id",  function(req, res){
model.ContactModel.getById(req.params.id,{load: ["emails"]}, function(error, contact){
if(error) {
res.status(400).json({ Success: false , Error: error, Message: ""})
      }
 res.status(200).json({ Success: true , Error: "", Message: "", Data : contact})
})
})

Что возвращает мне это

{
"Success": true,
"Error": "",
"Message": "",
"Data": {
"timestamp": "2019-01-30T23:59:59.188Z",
"emails": [
    {
        "$ref": "Email",
        "$id": "3ec07ba0-aaec-4fd4-a207-c4272cef8d66"
    }
],
"_id": "0112f774-4b5d-4b73-b784-60fa9fa2f9ff",
"first_name": "Test",
"last_name": "User"
}
}

если я пойду и войду в контакт с моей консолью, я получу это

OttomanModel(`Contact`, loaded, key:Contact|0112f774-4b5d-4b73-b784-60fa9fa2f9ff, {
timestamp: 2019-01-30T23:59:59.188Z,
emails: [ OttomanModel(`Email`, loaded, key:Email|3ec07ba0-aaec-4fd4-a207-c4272cef8d66, {
 timestamp: 2019-01-31T00:36:01.264Z,
 _id: '3ec07ba0-aaec-4fd4-a207-c4272cef8d66',
 type: 'work',
 address: 'test@outlook.com',
 name: 'Test Outlook',
 }),
 OttomanModel(`Email`, loaded, key:Email|93848b71-7696-4ef5-979d-05c19be9d593, {
 timestamp: 2019-01-31T04:12:40.603Z,
 _id: '93848b71-7696-4ef5-979d-05c19be9d593',
 type: 'work',
 address: 'newTest@outlook.com',
 name: 'Test2 Outlook',
 }) ],
 _id: '0112f774-4b5d-4b73-b784-60fa9fa2f9ff',
 first_name: 'Test',
 last_name: 'User',
 })

Это показывает, что электронные письма были разрешены, но почему они не отображаются в возвращенном json. С другой стороны, если я возвращаю contact.emails, я получаю разрешенные электронные письма очень хорошо. Поэтому я надеюсь, что кто-то может пролить свет на то, что мне здесь не хватает

0 ответов

Я задал аналогичный вопрос на форуме couchbase, и я также нашел решение: (небольшая разница в том, что результатом моего поиска является массив, а не объект, как в вашем случае)

forum.couchbase.com

 app.get("/assets", (req, res) => {
    AssetModel.find({}, { load: ["assetModelId", "assetGroupId", "assetTypeId"] }, (err, results) => {
        if (err) return res.status(400).send("no asset found");
        const assets = [];
        results.map(asset => {
            assets.push({...asset});
        });
        res.status(200).send(assets)
    });
});
Другие вопросы по тегам