Server : Apache System : Linux indy02.toastserver.com 3.10.0-962.3.2.lve1.5.85.el7.x86_64 #1 SMP Thu Apr 18 15:18:36 UTC 2024 x86_64 User : palandch ( 1163) PHP Version : 7.1.33 Disable Function : NONE Directory : /home/palandch/www/core/model/modx/processors/security/access/usergroup/category/ |
<?php /** * @package modx * @subpackage processors.security.group.category */ if (!$modx->hasPermission('access_permissions')) return $modx->error->failure($modx->lexicon('permission_denied')); $modx->lexicon->load('access','user','category'); /* validate for empty fields */ if (!isset($scriptProperties['principal'])) $modx->error->addField('principal',$modx->lexicon('usergroup_err_ns')); if (empty($scriptProperties['policy'])) $modx->error->addField('policy',$modx->lexicon('access_policy_err_ns')); if (!isset($scriptProperties['authority'])) $modx->error->addField('authority',$modx->lexicon('authority_err_ns')); if ($modx->error->hasError()) return $modx->error->failure(); /* validate for invalid data */ if (!empty($category)) { $category = $modx->getObject('modCategory',$scriptProperties['target']); if (empty($category)) $modx->error->addField('target',$modx->lexicon('category_err_nf')); if (!$category->checkPolicy('view')) $modx->error->addField('target',$modx->lexicon('access_denied')); } $policy = $modx->getObject('modAccessPolicy',$scriptProperties['policy']); if (empty($policy)) $modx->error->addField('policy',$modx->lexicon('access_policy_err_nf')); $alreadyExists = $modx->getObject('modAccessCategory',array( 'principal' => $scriptProperties['principal'], 'principal_class' => 'modUserGroup', 'target' => $scriptProperties['target'], 'policy' => $scriptProperties['policy'], 'context_key' => $scriptProperties['context_key'], )); if ($alreadyExists) $modx->error->addField('target',$modx->lexicon('access_category_err_ae')); if ($modx->error->hasError()) return $modx->error->failure(); /* create object */ $acl = $modx->newObject('modAccessCategory'); $acl->fromArray($scriptProperties); $acl->set('principal_class','modUserGroup'); if ($acl->save() == false) { return $modx->error->failure($modx->lexicon('access_category_err_save')); } return $modx->error->success('',$acl);