/** * Module dependencies */ var mongoose = require('mongoose') , Schema = mongoose.Schema; var AccessSchema = new Schema({ user: { type: Schema.ObjectId, ref: 'User' }, creator: { type: Schema.ObjectId, ref: 'User' }, project: { type: Schema.ObjectId, ref: 'Project' }, permissions: { type: Number, default: '3' }, created: { type: Date, default: Date.now }, updated: { type: Date, default: Date.now } }); // the four validations below only apply if you are signing up traditionally AccessSchema.statics = { /** * Load ALL accesses for a single user * * @param {ObjectId} id * @param {Function} callback * @api private */ loadUser: function(id, callback) { this.find({ user: id }) .populate('project') .sort({ 'created': -1 }) // sort by date .exec(callback); }, /** * Check to see if user has access to a particular project * * @param {ObjectId} user * @param {ObjectId} project * @return {Boolean} * @api public */ checkAccess: function(user, project) { console.log('inni checkAccess!') this.findOne({ user: user }).where('project').equals(project).exec(function(err, access) { if (err || !access) return false; else return true; }); } } mongoose.model('Access', AccessSchema);