| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 'use strict'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-23 12:12:46 +02:00
										 |  |  | var async = require('async'); | 
					
						
							| 
									
										
										
										
											2016-08-27 12:58:08 +03:00
										 |  |  | var groups = require('../groups'); | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | var helpers = module.exports; | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-13 11:43:39 +02:00
										 |  |  | helpers.some = function (tasks, callback) { | 
					
						
							|  |  |  | 	async.some(tasks, function (task, next) { | 
					
						
							| 
									
										
										
										
											2017-01-02 22:23:17 -07:00
										 |  |  | 		task(next); | 
					
						
							|  |  |  | 	}, callback); | 
					
						
							| 
									
										
										
										
											2014-05-15 10:38:02 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-13 11:43:39 +02:00
										 |  |  | helpers.isUserAllowedTo = function (privilege, uid, cid, callback) { | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | 	if (Array.isArray(privilege) && !Array.isArray(cid)) { | 
					
						
							|  |  |  | 		isUserAllowedToPrivileges(privilege, uid, cid, callback); | 
					
						
							|  |  |  | 	} else if (Array.isArray(cid) && !Array.isArray(privilege)) { | 
					
						
							|  |  |  | 		isUserAllowedToCids(privilege, uid, cid, callback); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		return callback(new Error('[[error:invalid-data]]')); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function isUserAllowedToCids(privilege, uid, cids, callback) { | 
					
						
							| 
									
										
										
										
											2014-07-29 21:51:46 -04:00
										 |  |  | 	if (parseInt(uid, 10) === 0) { | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | 		return isGuestAllowedToCids(privilege, cids, callback); | 
					
						
							| 
									
										
										
										
											2014-07-29 21:51:46 -04:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-17 20:20:42 -07:00
										 |  |  | 	var userKeys = []; | 
					
						
							|  |  |  | 	var groupKeys = []; | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 	cids.forEach(function (cid) { | 
					
						
							|  |  |  | 		userKeys.push('cid:' + cid + ':privileges:' + privilege); | 
					
						
							|  |  |  | 		groupKeys.push('cid:' + cid + ':privileges:groups:' + privilege); | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	checkIfAllowed(uid, userKeys, groupKeys, callback); | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function isUserAllowedToPrivileges(privileges, uid, cid, callback) { | 
					
						
							|  |  |  | 	if (parseInt(uid, 10) === 0) { | 
					
						
							|  |  |  | 		return isGuestAllowedToPrivileges(privileges, cid, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-17 20:20:42 -07:00
										 |  |  | 	var userKeys = []; | 
					
						
							|  |  |  | 	var groupKeys = []; | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 	privileges.forEach(function (privilege) { | 
					
						
							|  |  |  | 		userKeys.push('cid:' + cid + ':privileges:' + privilege); | 
					
						
							|  |  |  | 		groupKeys.push('cid:' + cid + ':privileges:groups:' + privilege); | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 	checkIfAllowed(uid, userKeys, groupKeys, callback); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | function checkIfAllowed(uid, userKeys, groupKeys, callback) { | 
					
						
							|  |  |  | 	async.waterfall([ | 
					
						
							|  |  |  | 		function (next) { | 
					
						
							|  |  |  | 			async.parallel({ | 
					
						
							|  |  |  | 				hasUserPrivilege: function (next) { | 
					
						
							|  |  |  | 					groups.isMemberOfGroups(uid, userKeys, next); | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				hasGroupPrivilege: function (next) { | 
					
						
							|  |  |  | 					groups.isMemberOfGroupsList(uid, groupKeys, next); | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, next); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		function (results, next) { | 
					
						
							|  |  |  | 			var result = userKeys.map(function (key, index) { | 
					
						
							|  |  |  | 				return results.hasUserPrivilege[index] || results.hasGroupPrivilege[index]; | 
					
						
							|  |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 			next(null, result); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	], callback); | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-13 11:43:39 +02:00
										 |  |  | helpers.isUsersAllowedTo = function (privilege, uids, cid, callback) { | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 	async.waterfall([ | 
					
						
							|  |  |  | 		function (next) { | 
					
						
							|  |  |  | 			async.parallel({ | 
					
						
							|  |  |  | 				hasUserPrivilege: function (next) { | 
					
						
							|  |  |  | 					groups.isMembers(uids, 'cid:' + cid + ':privileges:' + privilege, next); | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				hasGroupPrivilege: function (next) { | 
					
						
							|  |  |  | 					groups.isMembersOfGroupList(uids, 'cid:' + cid + ':privileges:groups:' + privilege, next); | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, next); | 
					
						
							| 
									
										
										
										
											2014-09-09 15:19:57 -04:00
										 |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 		function (results, next) { | 
					
						
							|  |  |  | 			var result = uids.map(function (uid, index) { | 
					
						
							|  |  |  | 				return results.hasUserPrivilege[index] || results.hasGroupPrivilege[index]; | 
					
						
							|  |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2014-09-09 15:19:57 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 			next(null, result); | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	], callback); | 
					
						
							| 
									
										
										
										
											2014-09-09 15:19:57 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | function isGuestAllowedToCids(privilege, cids, callback) { | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 	var groupKeys = cids.map(function (cid) { | 
					
						
							|  |  |  | 		return 'cid:' + cid + ':privileges:groups:' + privilege; | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2016-08-27 12:58:08 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-11 17:25:16 -05:00
										 |  |  | 	groups.isMemberOfGroups('guests', groupKeys, callback); | 
					
						
							| 
									
										
										
										
											2014-07-29 21:51:46 -04:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2014-05-14 17:53:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | function isGuestAllowedToPrivileges(privileges, cid, callback) { | 
					
						
							| 
									
										
										
										
											2017-05-25 21:17:20 -04:00
										 |  |  | 	var groupKeys = privileges.map(function (privilege) { | 
					
						
							|  |  |  | 		return 'cid:' + cid + ':privileges:groups:' + privilege; | 
					
						
							|  |  |  | 	}); | 
					
						
							| 
									
										
										
										
											2016-09-15 14:01:56 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	groups.isMemberOfGroups('guests', groupKeys, callback); | 
					
						
							|  |  |  | } |