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/policy/ |
<?php /** * Update a policy attribute value * * @param integer $id The ID of the policy * @param string $key The attribute key * @param boolean $value The value of the attribute * * @package modx * @subpackage processors.security.access.policy */ if (!$modx->hasPermission('policy_save')) return $modx->error->failure($modx->lexicon('permission_denied')); $modx->lexicon->load('policy'); if (!isset($scriptProperties['id'])) return $modx->error->failure($modx->lexicon('policy_err_ns')); /* get policy */ $policy = $modx->getObject('modAccessPolicy',$scriptProperties['id']); if ($policy == null) return $modx->error->failure($modx->lexicon('policy_err_nf')); /* parse data from JSON */ $ar = $policy->get('data'); if (!isset($ar[$scriptProperties['key']])) return $modx->error->failure($modx->lexicon('policy_err_nf')); /* format policy value */ if ($scriptProperties['value'] === 'true') $scriptProperties['value'] = true; if ($scriptProperties['value'] === 'false') $scriptProperties['value'] = false; /* set policy value */ $ar[$scriptProperties['key']] = $scriptProperties['value']; $policy->set('data',$modx->toJSON($ar)); /* save policy */ if ($policy->save() == false) { return $modx->error->failure($modx->lexicon('policy_err_save')); } return $modx->error->success();