2016-09-15 5 views
0

私はMEANスタックをかなり新しくしているので、おそらく私は信じられないほどばかげたことをしています。Mongooseネストされたスキーマ検証エラー

私はいくつかの定義されたスキーマ(BlogEntry、ForumPost)を持っていますので、コードの重複を避けるためにコメントスキーマを独自のファイルに移動しました。

var mongoose = require('mongoose'); 
var Schema = mongoose.Schema; 

var BlogEntry = new Schema({ 
    title: String, 
    thumbnailUrl: String, 
    content: String, 
    comments: [ 
     { 
      type: Schema.Types.ObjectId, 
      ref: 'Comment' 
     } 
    ] 
}, { 
    timestamps: true 
}); 


var Blog = new Schema({ 
    createdBy: { 
     type: Schema.Types.ObjectId, 
     ref: 'User' 
    }, 
    name: { 
     type: String, 
     required: true 
    }, 
    headerImageUrl: String, 
    description: String, 
    blogEntries: [BlogEntry] 
}, { 
    timestamps: true 
}); 

module.exports = mongoose.model('Blog', Blog); 

とコメントスキーマがcomment.jsに含まれています:

var mongoose = require('mongoose'); 
var Schema = mongoose.Schema; 

var Comment = new Schema({ 
    commentText: { 
     type: String, 
     required: true 
    }, 
    postedBy: { 
     type: Schema.Types.ObjectId, 
     ref: 'User' 
    }, 
    parentComment: { 
     type: Schema.Types.ObjectId, 
     ref: 'Comment' 
    } 
}, { 
    timestamps: true 
}); 

module.exports = mongoose.model('Comment', Comment); 

私のルータだけBlogEntryの例では、私は私のblog.jsモデルで以下のいる探し

ブログの情報を処理するため、次のものが含まれます

var express = require('express'); 
var bodyParser = require('body-parser'); 
var mongoose = require('mongoose'); 
var Blog = require('../models/blog'); 
var Verify = require('./verify'); 
var blogRouter = express.Router(); 
blogRouter.use(bodyParser.json()); 

blogRouter.route('/') 
.get(function(req, res, next) { 
    Blog.find(req.query) 
     .populate('createdBy') 
     .exec(function(err, blog) { 
      if(err) return next(err); 
      res.json(blog); 
     }); 
}) 

.post(Verify.verifyOrdinaryUser, function(req, res, next) { 
    req.body.createdBy = req.decoded._id; 
    Blog.create(req.body, function(err, blog) { 
     if(err) return next(err); 
     console.log("Blog created"); 
     var id = blog._id; 
     res.writeHead(200, { 'Content-Type': 'text/plain'}); 
     res.end('Added the blog with id: ' + id); 
    }); 
}); 

module.exports = blogRouter; 

コメントスキーマがseparatであります私はcomment.jsファイルを取り除く場合は、しかし、

{ 
    "name": "A Cheesemaker's Adventure", 
    "headerImageUrl": "images/cheeseAdven.png", 
    "description": "The story of a man's transformation from a miserable, downtrodden software engineer to a bouyant, joy-filled cheesemaker.", 
    "blogEntries" : [ 
     { 
      "title": "I like cheese", 
      "content": "Here is my story...blah blah blah...", 
      "comments": [ 
       { 
       "commentText": "Who's is this guy kidding!" 
       } 
      ] 
     } 
    ] 
} 


<!DOCTYPE html><html><head><title></title><link rel="stylesheet" href="/stylesheets/style.css"></head><body><h1>Blog validation failed</h1><h2></h2><pre>ValidationError: Blog validation failed 
    at MongooseError.ValidationError (C:\Development\hcj-express\node_modules\mongoose\lib\error\validation.js:22:11) 
    at model.Document.invalidate (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:1410:32) 
    at EmbeddedDocument.invalidate (C:\Development\hcj-express\node_modules\mongoose\lib\types\embedded.js:190:19) 
    at EmbeddedDocument.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:703:10) 
    at EmbeddedDocument.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:548:18) 
    at EmbeddedDocument.Document (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:67:10) 
    at new EmbeddedDocument (C:\Development\hcj-express\node_modules\mongoose\lib\types\embedded.js:30:12) 
    at EmbeddedDocument (C:\Development\hcj-express\node_modules\mongoose\lib\schema\documentarray.js:27:17) 
    at DocumentArray.cast (C:\Development\hcj-express\node_modules\mongoose\lib\schema\documentarray.js:254:22) 
    at DocumentArray.SchemaType.applySetters (C:\Development\hcj-express\node_modules\mongoose\lib\schematype.js:628:12) 
    at model.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:695:18) 
    at model.Document.set (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:548:18) 
    at model.Document (C:\Development\hcj-express\node_modules\mongoose\lib\document.js:67:10) 
    at model.Model (C:\Development\hcj-express\node_modules\mongoose\lib\model.js:41:12) 
    at new model (C:\Development\hcj-express\node_modules\mongoose\lib\model.js:3175:11) 
    at C:\Development\hcj-express\node_modules\mongoose\lib\model.js:1847:51</pre></body></html> 

などのように、blog.jsファイルにコメントスキーマを移動:電子ファイル、と私は、私は、検証エラーを次のリクエストGET、POST上記のメッセージと全く同じメッセージを投稿することができますが、検証エラーは消え、データを正常に投稿します。

var mongoose = require('mongoose'); 
var Schema = mongoose.Schema; 

var Comment = new Schema({ 
    commentText: { 
     type: String, 
     required: true 
    }, 
    postedBy: { 
     type: Schema.Types.ObjectId, 
     ref: 'User' 
    }, 
    parentComment: { 
     type: Schema.Types.ObjectId, 
     ref: 'Comment' 
    } 
}, { 
    timestamps: true 
}); 

var BlogEntry = new Schema({ 
    title: String, 
    thumbnailUrl: String, 
    content: String, 
    comments: [Comment] 
}, { 
    timestamps: true 
}); 

var Blog = new Schema({ 
    createdBy: { 
     type: Schema.Types.ObjectId, 
     ref: 'User' 
    }, 
    name: { 
     type: String, 
     required: true 
    }, 
    headerImageUrl: String, 
    description: String, 
    blogEntries: [BlogEntry] 
}, { 
    timestamps: true 
}); 

module.exports = mongoose.model('Blog', Blog); 

Sooo ...私はここで間違っていますか?

答えて

0

別々のファイルを使用して作業している場合、 'BlogEntry'スキーマの前に 'コメント'スキーマがロードされていることを保証する必要があります。

BlogEntry.jsの上部にrequire('./comment.js')を追加するだけで済みます。例:

var mongoose = require('mongoose'); 
var Schema = mongoose.Schema; 
var Comment = require('./comment.js'); 

var BlogEntry = new Schema({ 
    title: String, 
    thumbnailUrl: String, 
    content: String, 
    comments: [Comment] 
}, { 
    timestamps: true 
}); 
+0

上記の変更を行い、サーバーに展開しても同じエラーが発生します。興味深いことに、Userへのネストされた参照は、それが別のファイルにあってもうまく動作し、このスキーマファイルに明示的に必要とされていません。 –

+0

コード内の別のポイントでUserを使用している場合は(確かにverifyOrdinaryUser関数に)その後、以前の 'require'がそれをmongooseキャッシュに追加しました。 '' 'require( './ comment.js')' ''のままにして、 '' 'コメントを変更しよう:[Comment]' '' '' 'コメント:[{ type:Schema.Types。 ObjectId、 ref: 'Comment' }] '' ' –

+0

@Rafaelには同意しますが、これはcomment.jsの最初の使用ですので、requireステートメントに含める必要があります。私はコメント:[Comment]とコメント:[{type:Schema.Types.ObjectId、ref: 'Comment'}] 'の両方を使用しようとしましたが、どちらの場合も同じエラーが発生します。 –

関連する問題