getGenericObject( 'PermissionControlListFactory', $this->getPermissionControl(), 'permission_control_obj' ); } /** * @return bool */ function getUserObject() { return $this->getGenericObject( 'UserListFactory', $this->getUser(), 'user_obj' ); } /** * @return mixed */ function getPermissionControl() { return TTUUID::castUUID( $this->getGenericDataValue( 'permission_control_id' ) ); } /** * @param string $value UUID * @return bool */ function setPermissionControl( $value ) { $value = TTUUID::castUUID( $value ); return $this->setGenericDataValue( 'permission_control_id', $value ); } /** * @param string $id UUID * @return bool */ function isUniqueUser( $id ) { $pclf = TTnew( 'PermissionControlListFactory' ); /** @var PermissionControlListFactory $pclf */ $ph = [ 'id' => TTUUID::castUUID( $id ), ]; $query = 'select a.id from ' . $this->getTable() . ' as a, ' . $pclf->getTable() . ' as b where a.permission_control_id = b.id AND a.user_id = ? AND b.deleted = 0'; $user_id = $this->db->GetOne( $query, $ph ); Debug::Arr( $user_id, 'Unique User ID: ' . $user_id, __FILE__, __LINE__, __METHOD__, 10 ); if ( $user_id === false ) { return true; } return false; } /** * @return mixed */ function getUser() { return TTUUID::castUUID( $this->getGenericDataValue( 'user_id' ) ); } /** * @param string $value UUID * @return bool */ function setUser( $value ) { $value = TTUUID::castUUID( $value ); if ( $value != TTUUID::getZeroID() ) { return $this->setGenericDataValue( 'user_id', $value ); } return false; } /** * This table doesn't have any of these columns, so overload the functions. * @return bool */ function Validate() { // // BELOW: Validation code moved from set*() functions. // // Permission Group if ( $this->getPermissionControl() == TTUUID::getZeroID() ) { $pclf = TTnew( 'PermissionControlListFactory' ); /** @var PermissionControlListFactory $pclf */ $this->Validator->isResultSetWithRows( 'permission_control', $pclf->getByID( $this->getPermissionControl() ), TTi18n::gettext( 'Permission Group is invalid' ) ); } // Employee if ( $this->getUser() !== false && $this->getUser() != TTUUID::getZeroID() ) { $ulf = TTnew( 'UserListFactory' ); /** @var UserListFactory $ulf */ $this->Validator->isResultSetWithRows( 'user', $ulf->getByID( $this->getUser() ), TTi18n::gettext( 'Selected Employee is invalid' ) ); if ( $this->Validator->isError( 'user' ) == false ) { $this->Validator->isTrue( 'user', $this->isUniqueUser( $this->getUser() ), TTi18n::gettext( 'Selected Employee is already assigned to another Permission Group' ) ); } } // // ABOVE: Validation code moved from set*() functions. // return true; } /** * @return bool */ function postSave() { if ( is_object( $this->getUserObject() ) ) { $this->removeCache( $this->getUserObject()->getCompany() . $this->getUser() ); //Used in PermissionControlListFactory::getByCompanyIdAndUserId() } return true; } function postDelete() { if ( is_object( $this->getUserObject() ) ) { //Since we often delete the record completely, we need to make sure caching is kept up to date here too. $this->removeCache( $this->getUserObject()->getCompany() . $this->getUser() ); //Used in PermissionControlListFactory::getByCompanyIdAndUserId() } return true; } /** * @return bool */ function getDeleted() { return false; } /** * @param $bool * @return bool */ function setDeleted( $bool ) { return false; } /** * @return bool */ function getCreatedDate() { return false; } /** * @param int $epoch EPOCH * @return bool */ function setCreatedDate( $epoch = null ) { return false; } /** * @return bool */ function getCreatedBy() { return false; } /** * @param string $id UUID * @return bool */ function setCreatedBy( $id = null ) { return false; } /** * @return bool */ function getUpdatedDate() { return false; } /** * @param int $epoch EPOCH * @return bool */ function setUpdatedDate( $epoch = null ) { return false; } /** * @return bool */ function getUpdatedBy() { return false; } /** * @param string $id UUID * @return bool */ function setUpdatedBy( $id = null ) { return false; } /** * @return bool */ function getDeletedDate() { return false; } /** * @param int $epoch EPOCH * @return bool */ function setDeletedDate( $epoch = null ) { return false; } /** * @return bool */ function getDeletedBy() { return false; } /** * @param string $id UUID * @return bool */ function setDeletedBy( $id = null ) { return false; } /** * @param $log_action * @return bool */ function addLog( $log_action ) { $u_obj = $this->getUserObject(); if ( is_object( $u_obj ) ) { return TTLog::addEntry( $this->getPermissionControl(), $log_action, TTi18n::getText( 'Employee' ) . ': ' . $u_obj->getFullName( false, true ), null, $this->getTable() ); } return false; } } ?>