post_schema.js
3.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
var SchemaObj = {};
SchemaObj.createSchema = function(mongoose) {
// 글 스키마 정의
var PostSchema = mongoose.Schema({
title: {type: String, trim: true, 'default':''}, // 글 제목
contents: {type: String, trim:true, 'default':''}, // 글 내용
writer: {type: String, 'default': ''}, // 글쓴 사람
comments: [{ // 댓글
contents: {type: String, trim:true, 'default': ''}, // 댓글 내용
writer: {type: String, 'default': ''},
created_at: {type: Date, 'default': Date.now}
}],
tags: {type: [], 'default': ''},
created_at: {type: Date, index: {unique: false}, 'default': Date.now},
updated_at: {type: Date, index: {unique: false}, 'default': Date.now}
});
// 필수 속성에 대한 'required' validation
PostSchema.path('title').required(true, '글 제목을 입력하셔야 합니다.');
PostSchema.path('contents').required(true, '글 내용을 입력하셔야 합니다.');
// 스키마에 인스턴스 메소드 추가
PostSchema.methods = {
savePost: function(callback) { // 글 저장
var self = this;
this.validate(function(err) {
if (err) return callback(err);
self.save(callback);
});
},
addComment: function(user, comment, callback) { // 댓글 추가
this.comment.push({
contents: comment.contents,
writer: user._id
});
this.save(callback);
},
removeComment: function(id, callback) { // 댓글 삭제
var index = utils.indexOf(this.comments, {id: id});
if (~index) {
this.comments.splice(index, 1);
} else {
return callback('ID [' + id + '] 를 가진 댓글 객체를 찾을 수 없습니다.');
}
this.save(callback);
}
}
PostSchema.statics = {
// ID로 글 찾기
load: function(id, callback) {
this.findOne({_id: id})
.populate('writer', 'name provider email')
.populate('comments.writer')
.exec(callback);
},
list: function(options, callback) {
var criteria = options.criteria || {};
this.find(criteria)
.populate('writer', 'name provider email')
.sort({'created_at': -1})
.limit(Number(options.perPage))
.skip(options.perPage * options.page)
.exec(callback);
}
}
return PostSchema;
};
// module.exports에 PostSchema 객체 직접 할당
module.exports = SchemaObj;
/**
* 배열 객체 안의 배열 요소가 가지는 인덱스 값 리턴
*/
function indexOf(arr, obj) {
var index = -1;
var keys = Object.keys(obj);
var result = arr.filter(function (doc, idx) {
var matched = 0;
for (var i = keys.length - 1; i >= 0; i--) {
if (doc[keys[i]] === obj[keys[i]]) {
matched++;
if (matched === keys.length) {
index = idx;
return idx;
}
}
}
});
return index;
}
/**
* 배열 안의 요소 중에서 파라미터와 같은 객체를 리턴
*/
function findByParam(arr, obj, callback) {
var index = exports.indexof(arr, obj)
if (~index && typeof callback === 'function') {
return callback(undefined, arr[index])
} else if (~index && !callback) {
return arr[index]
} else if (!~index && typeof callback === 'function') {
return callback('not found')
}
}