Files
luos/rbac/engine/classes/model/RolesPermissions.php

115 lines
3.4 KiB
PHP
Raw Normal View History

2010-12-02 23:34:41 +00:00
<?php
/**
* RolesPermissions.php
2011-01-27 15:31:33 +00:00
* @package rbac-classes-model
*
2010-12-02 23:34:41 +00:00
* ProcessMaker Open Source Edition
2011-01-27 15:31:33 +00:00
* Copyright (C) 2004 - 2011 Colosa Inc.
2010-12-02 23:34:41 +00:00
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* For more information, contact Colosa Inc, 2566 Le Jeune Rd.,
* Coral Gables, FL, 33134, USA, or email info@colosa.com.
*
*/
2011-01-27 15:31:33 +00:00
/**
* @access public
*/
2010-12-02 23:34:41 +00:00
require_once 'classes/model/om/BaseRolesPermissions.php';
/**
* Skeleton subclass for representing a row from the 'ROLES_PERMISSIONS' table.
*
*
*
* You should add additional methods to this class to meet the
* application requirements. This class will only be generated as
* long as it does not already exist in the output directory.
*
2011-01-18 09:10:20 +00:00
* @package rbac-classes-model
2010-12-02 23:34:41 +00:00
*/
2013-04-11 09:51:39 -04:00
class RolesPermissions extends BaseRolesPermissions
{
/**
* The value for the permission_name field.
* @var string
*/
protected $permission_name = '';
/**
*
* @param array $aData
* @return boolean
*/
function create($aData)
{
2010-12-02 23:34:41 +00:00
try {
$oCriteria = new Criteria('rbac');
$oCriteria->add(RolesPermissionsPeer::ROL_UID, $aData['ROL_UID']);
$oCriteria->add(RolesPermissionsPeer::PER_UID, $aData['PER_UID']);
$oDataset = RolesPermissionsPeer::doSelectRS($oCriteria);
$oDataset->setFetchmode(ResultSet::FETCHMODE_ASSOC);
$oDataset->next();
$aRow = $oDataset->getRow();
2013-04-11 09:51:39 -04:00
if (is_array($aRow)) {
return true;
}
2017-02-15 16:41:41 -04:00
$this->permission_name = isset($aData['PER_NAME']) ? $aData['PER_NAME'] : '';
2013-04-11 09:51:39 -04:00
2010-12-02 23:34:41 +00:00
$oRolesPermissions = new RolesPermissions();
$oRolesPermissions->fromArray($aData, BasePeer::TYPE_FIELDNAME);
$iResult = $oRolesPermissions->save();
return true;
}
catch (Exception $oError) {
throw($oError);
}
}
2013-04-11 09:51:39 -04:00
/**
* @return string
*/
public function getPermissionName()
{
if ($this->getPerUid() == '') {
throw (new Exception("Error in getPerName, the PER_UID can't be blank"));
}
$lang = defined('SYS_LANG') ? SYS_LANG : 'en';
$this->permission_name = Content::load('PER_NAME', '', $this->getPerUid(), $lang);
return $this->permission_name;
}
/**
*
* @param string $name
*/
public function setPermissionName($name)
{
if ($this->getPerUid() == '') {
throw (new Exception("Error in setPerTitle, the PER_UID can't be blank"));
}
if ($name !== null && ! is_string($name)) {
$name = (string)$name;
}
if ($this->permission_name !== $name || $name === '') {
$this->permission_name = $name;
$lang = defined('SYS_LANG') ? SYS_LANG : 'en';
$res = Content::addContent('PER_NAME', '', $this->getPerUid(), $lang, $this->permission_name);
}
}
2010-12-02 23:34:41 +00:00
} // RolesPermissions