| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var async = require('async'), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	meta = require('../meta'), | 
					
						
							|  |  |  | 	user = require('../user'), | 
					
						
							|  |  |  | 	groups = require('../groups'), | 
					
						
							|  |  |  | 	categories = require('../categories'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var helpers = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-15 10:38:02 -04:00
										 |  |  | helpers.some = function(tasks, callback) { | 
					
						
							|  |  |  | 	async.some(tasks, function(task, next) { | 
					
						
							|  |  |  | 		task(function(err, result) { | 
					
						
							|  |  |  | 			next(!err && result); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}, function(result) { | 
					
						
							|  |  |  | 		callback(null, result); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | helpers.allowedTo = function(privilege, uid, cid, callback) { | 
					
						
							|  |  |  | 	categories.getCategoryField(cid, 'disabled', function(err, disabled) { | 
					
						
							|  |  |  | 		if (err) { | 
					
						
							|  |  |  | 			return callback(err); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (parseInt(disabled, 10) === 1) { | 
					
						
							|  |  |  | 			return callback(null, false); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-16 15:47:04 -04:00
										 |  |  | 		if (parseInt(uid, 10) === 0) { | 
					
						
							| 
									
										
										
										
											2014-05-17 18:59:34 -04:00
										 |  |  | 			return isGuestAllowedTo(privilege, cid, callback); | 
					
						
							| 
									
										
										
										
											2014-05-16 15:47:04 -04:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 		async.parallel({ | 
					
						
							|  |  |  | 			hasUserPrivilege: function(next) { | 
					
						
							| 
									
										
										
										
											2014-05-15 20:49:47 -04:00
										 |  |  | 				helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:' + privilege, uid, next); | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 			hasGroupPrivilege: function(next) { | 
					
						
							| 
									
										
										
										
											2014-05-15 20:49:47 -04:00
										 |  |  | 				helpers.isMember(groups.isMemberOfGroupList, 'cid:' + cid + ':privileges:groups:' + privilege, uid, next); | 
					
						
							| 
									
										
										
										
											2014-05-16 15:47:04 -04:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 		}, function(err, results) { | 
					
						
							|  |  |  | 			if (err) { | 
					
						
							|  |  |  | 				return callback(err); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-05-15 07:48:21 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			callback(null, (results.hasUserPrivilege === null && results.hasGroupPrivilege === null) || results.hasUserPrivilege || results.hasGroupPrivilege); | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 		}); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-17 18:59:34 -04:00
										 |  |  | function isGuestAllowedTo(privilege, cid, callback) { | 
					
						
							|  |  |  | 	async.parallel([ | 
					
						
							|  |  |  | 		function(next) { | 
					
						
							|  |  |  | 			groups.exists('cid:' + cid + ':privileges:' + privilege, function(err, exists) { | 
					
						
							|  |  |  | 				next(err, !err ? !exists : false); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		function(next) { | 
					
						
							|  |  |  | 			helpers.isMember(groups.isMember, 'cid:' + cid + ':privileges:groups:' + privilege, 'guests', function(err, isMember) { | 
					
						
							|  |  |  | 				next(err, privilege !== 'find' && privilege !== 'read' ? isMember === true : isMember !== false); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	], function(err, results) { | 
					
						
							|  |  |  | 		callback(err, results[0] && (results[1] || results[1] === null)); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-15 20:49:47 -04:00
										 |  |  | helpers.isMember = function(method, group, uid, callback) { | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 	groups.exists(group, function(err, exists) { | 
					
						
							|  |  |  | 		if (err) { | 
					
						
							|  |  |  | 			return callback(err); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (!exists) { | 
					
						
							| 
									
										
										
										
											2014-05-15 07:48:21 -04:00
										 |  |  | 			return callback(null, null); | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-15 10:38:02 -04:00
										 |  |  | 		method(uid, group, callback); | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2014-05-17 18:59:34 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | helpers.hasEnoughReputationFor = function(privilege, uid, callback) { | 
					
						
							|  |  |  | 	if (parseInt(meta.config['privileges:disabled'], 10)) { | 
					
						
							|  |  |  | 		return callback(null, false); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	user.getUserField(uid, 'reputation', function(err, reputation) { | 
					
						
							|  |  |  | 		if (err) { | 
					
						
							|  |  |  | 			return callback(null, false); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		callback(null, parseInt(reputation, 10) >= parseInt(meta.config[privilege], 10)); | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module.exports = helpers; |