挿入を行う流星メソッドがあります。フォームの検証にRegulate.jsを使用しています。
game_id フィールドを Meteor.uuid() に設定して一意の値を作成し、Iron Router を使用して /game_show/:game_id にもルーティングします。
ご覧のとおり、ゲームの詳細をログに記録していますが、これは正常に機能します。(以下のログへの画像リンク)
ファイル: /lib/methods.js
Meteor.methods({
create_game_form : function(data){
Regulate.create_game_form.validate(data, function (error, data) {
if (error) {
console.log('Server side validation failed.');
} else {
console.log('Server side validation passed!');
// Save data to database or whatever...
//console.log(data[0].value);
var new_game = {
game_id: Meteor.uuid(),
name : data[0].value,
game_type: data[1].value,
creator_user_id: Meteor.userId(),
user_name: Meteor.user().profile.name,
created: new Date()
};
console.log("NEW GAME BEFORE INSERT: ", new_game);
GamesData.insert(new_game, function(error, new_id){
console.log("GAMES NEW MONGO ID: ", new_id)
var game_data = GamesData.findOne({_id: new_id});
console.log('NEW GAME AFTER INSERT: ', game_data);
Session.set('CURRENT_GAME', game_data);
});
}
});
}
});
この時点で console.log から出力されるすべてのデータは正常に動作します
このメソッドを呼び出した後、クライアントは /game_show/:game_id にルーティングします
Meteor.call('create_game_form', data, function(error){
if(error){
return alert(error.reason);
}
//console.log("post insert data for routing variable " ,data);
var created_game = Session.get('CURRENT_GAME');
console.log("Session Game ", created_game);
Router.go('game_show', {game_id: created_game.game_id});
});
このビューで、挿入したばかりの game_id でドキュメントを読み込もうとします
Template.game_start.helpers({
game_info: function(){
console.log(this.game_id);
var game_data = GamesData.find({game_id: this.game_id});
console.log("trying to load via UUID ", game_data);
return game_data;
}
});
申し訳ありませんが、画像をアップロードできません... :-(
以下のコンソール ログの画像からわかるように、すべてが一致しています。
- 挿入前に記録された ID
- findOne() を使用して挿入コールバックに記録された ID
- URL で渡された ID
ただし、挿入したmongo IDとUUIDは存在しません。そこにある唯一のドキュメントには、これら2つを除いて他のすべてのフィールドが一致しています!
何が間違っているのかわかりません。ありがとう!