hierarchy_control_obj ) ) { return $this->hierarchy_control_obj; } else { $hclf = TTnew( 'HierarchyControlListFactory' ); /** @var HierarchyControlListFactory $hclf */ $this->hierarchy_control_obj = $hclf->getById( $this->getHierarchyControl() )->getCurrent(); return $this->hierarchy_control_obj; } } /** * @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; } } /** * @return bool|mixed */ function getHierarchyControl() { return $this->getGenericDataValue( 'hierarchy_control_id' ); } /** * @param string $value UUID * @return bool */ function setHierarchyControl( $value ) { $value = TTUUID::castUUID( $value ); //This is a sub-class, need to support setting HierachyControlID before its created. return $this->setGenericDataValue( 'hierarchy_control_id', $value ); } /** * @param string $id UUID * @param int $exclude_id * @return bool */ function isUniqueUser( $id, $exclude_id = 0 ) { if ( $exclude_id === 0 ) { $exclude_id = TTUUID::getZeroID(); } $hcf = TTnew( 'HierarchyControlFactory' ); /** @var HierarchyControlFactory $hcf */ $hotf = TTnew( 'HierarchyObjectTypeFactory' ); /** @var HierarchyObjectTypeFactory $hotf */ $ph = [ 'hierarchy_control_id' => $this->getHierarchyControl(), 'id' => $id, 'exclude_id' => TTUUID::castUUID( $exclude_id ), ]; //$query = 'select a.id from '. $this->getTable() .' as a, '. $pglf->getTable() .' as b where a.hierarchy_control_id = b.id AND a.user_id = ? AND b.deleted=0'; $query = ' select * from ' . $hotf->getTable() . ' as a LEFT JOIN ' . $this->getTable() . ' as b ON a.hierarchy_control_id = b.hierarchy_control_id LEFT JOIN ' . $hcf->getTable() . ' as c ON a.hierarchy_control_id = c.id WHERE a.object_type_id in ( select object_type_id from hierarchy_object_type where hierarchy_control_id = ? ) AND b.user_id = ? AND a.hierarchy_control_id != ? AND c.deleted = 0 '; //Debug::Query( $query, $ph, __FILE__, __LINE__, __METHOD__, 10); $user_id = $this->db->GetOne( $query, $ph ); 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. // // Hierarchy Control if ( $this->getHierarchyControl() == '' || $this->getHierarchyControl() == TTUUID::getZeroID() ) { $hclf = TTnew( 'HierarchyControlListFactory' ); /** @var HierarchyControlListFactory $hclf */ $this->Validator->isResultSetWithRows( 'hierarchy_control_id', $hclf->getByID( $this->getHierarchyControl() ), TTi18n::gettext( 'Invalid Hierarchy Control' ) ); } // Selected Employee $ulf = TTnew( 'UserListFactory' ); /** @var UserListFactory $ulf */ $this->Validator->isResultSetWithRows( 'user', $ulf->getByID( $this->getUser() ), TTi18n::gettext( 'Selected Employee is invalid' ) ); /* //Allow superiors to be assigned as subordinates in the same hierarchy to make it easier to administer hierarchies //that have superiors sharing responsibility. //For example Super1 and Super2 look after 10 subordinates as well as each other. This would require 3 hierarchies normally, //but if we allow Super1 and Super2 to be subordinates in the same hierarchy, it can be done with a single hierarchy. //The key with this though is to have Permission->getPermissionChildren() *not* return the current user, even if they are a subordinates, //as that could cause a conflict with view_own and view_child permissions (as a child would imply view_own) AND $this->Validator->isNotResultSetWithRows( 'user', $hllf->getByHierarchyControlIdAndUserId( $this->getHierarchyControl(), $id ), TTi18n::gettext('Selected Employee is assigned as both a superior and subordinate') ) */ if ( $this->Validator->isError( 'user' ) == false ) { $this->Validator->isTrue( 'user', $this->isUniqueUser( $this->getUser() ), TTi18n::gettext( 'Selected Employee is already assigned to another hierarchy' ) ); } // // 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->getHierarchyControl(), $log_action, TTi18n::getText( 'Subordinate' ) . ': ' . $u_obj->getFullName( false, true ), null, $this->getTable() ); } return false; } } ?>