getGenericDataValue( 'policy_group_id' ); } /** * @param string $value UUID * @return bool */ function setPolicyGroup( $value ) { $value = TTUUID::castUUID( $value ); return $this->setGenericDataValue( 'policy_group_id', $value ); } /** * @return bool|null */ function getUserObject() { if ( is_object( $this->user_obj ) ) { return $this->user_obj; } else { $ulf = TTnew( 'UserListFactory' ); /** @var UserListFactory $ulf */ $ulf->getById( $this->getUser() ); if ( $ulf->getRecordCount() == 1 ) { $this->user_obj = $ulf->getCurrent(); return $this->user_obj; } return false; } } /** * @param string $id UUID * @return bool */ function isUniqueUser( $id ) { $pglf = TTnew( 'PolicyGroupListFactory' ); /** @var PolicyGroupListFactory $pglf */ $ph = [ 'id' => TTUUID::castUUID( $id ), ]; $query = 'select a.id from ' . $this->getTable() . ' as a, ' . $pglf->getTable() . ' as b where a.policy_group_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 $this->getGenericDataValue( 'user_id' ); } /** * @param string $value UUID * @return bool */ function setUser( $value ) { $value = TTUUID::castUUID( $value ); return $this->setGenericDataValue( 'user_id', $value ); } /** * @return bool */ function Validate() { // // BELOW: Validation code moved from set*() functions. // // Policy Group if ( $this->getPolicyGroup() == TTUUID::getZeroID() ) { $pglf = TTnew( 'PolicyGroupListFactory' ); /** @var PolicyGroupListFactory $pglf */ $this->Validator->isResultSetWithRows( 'policy_group', $pglf->getByID( $this->getPolicyGroup() ), TTi18n::gettext( 'Policy Group is invalid' ) ); } // Employee if ( $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 Policy Group' ) ); } } // // ABOVE: Validation code moved from set*() functions. // return true; } //This table doesn't have any of these columns, so overload the functions. /** * @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->getPolicyGroup(), $log_action, TTi18n::getText( 'Employee' ) . ': ' . $u_obj->getFullName( false, true ), null, $this->getTable() ); } return false; } } ?>