Files
pathfinder/app/main/model/corporationmodel.php
Exodus4D a8edf39697 - new "logging" system for map/system/signature/connection changes, closed #271
- new map change log to Slack channel
- new "rally point" logging to Slack channel
- new "rally point" poke options (e.g. custom message), closed #295
- new log options for WebSocket installations
- added ship "mass" logging (backend only), #313
- added map logging to Slack, #326
- added "ESI error rate" limit detection
- added "Monolog" as new logging library (Composer dependency)
- added "Swiftmailer" as new eMail library (Composer dependency)
- added Support for Redis session hander (performance boost)
- improved character select panels (visible "online" status)
- improved "activity logging" (more DB columns added to check)
- improved eMail logging (HTML template support)
- improved "delete map" now become "inactive" for some days before delete
- improved character logout handling
- improved /setup page for DB bootstrap (new button for DB create if not exists)
- fixed broken ship tracking (ship name re-added)
- fixed broken ship tracking for multiple chars on different browser tabs
- fixed broken cursor coordinates, closed #518
- fixed null pointer "charactermodel.php->isActive():925" closed #529
- fixed broken "scroll offset", closed #533 closed #534
- Updated "validation" library JS v0.10.1 -> v0.11.9
- Updated ORM Mapper _Cortex_ v1.5.0-dev -> v1.5.0
- and many more....
2017-10-22 17:58:34 +02:00

223 lines
5.4 KiB
PHP

<?php
/**
* Created by PhpStorm.
* User: exodus4d
* Date: 17.05.15
* Time: 20:43
*/
namespace Model;
use DB\SQL\Schema;
use lib\Config;
class CorporationModel extends BasicModel {
protected $table = 'corporation';
/**
* all available corp roles EVE has
* -> a corp member has granted roles 0 up to all roles
*/
const CCP_ROLES = [
'director',
'personnel_manager',
'accountant',
'security_officer',
'factory_manager',
'station_manager',
'auditor',
'hangar_take_1',
'hangar_take_2',
'hangar_take_3',
'hangar_take_4',
'hangar_take_5',
'hangar_take_6',
'hangar_take_7',
'hangar_query_1',
'hangar_query_2',
'hangar_query_3',
'hangar_query_4',
'hangar_query_5',
'hangar_query_6',
'hangar_query_7',
'account_take_1',
'account_take_2',
'account_take_3',
'account_take_4',
'account_take_5',
'account_take_6',
'account_take_7',
'diplomat',
'config_equipment',
'container_take_1',
'container_take_2',
'container_take_3',
'container_take_4',
'container_take_5',
'container_take_6',
'container_take_7',
'rent_office',
'rent_factory_facility',
'rent_research_facility',
'junior_accountant',
'config_starbase_equipment',
'trader',
'communications_officer',
'contract_manager',
'starbase_defense_operator',
'starbase_fuel_technician',
'fitting_manager',
'terrestrial_combat_officer',
'terrestrial_logistics_officer'
];
/**
* corp roles that give admin access for a corp
*/
const ADMIN_ROLES = [
'director',
'personnel_manager',
'security_officer'
];
protected $fieldConf = [
'active' => [
'type' => Schema::DT_BOOL,
'nullable' => false,
'default' => 1,
'index' => true
],
'name' => [
'type' => Schema::DT_VARCHAR128,
'nullable' => false,
'default' => ''
],
'shared' => [
'type' => Schema::DT_BOOL,
'nullable' => false,
'default' => 0
],
'isNPC' => [
'type' => Schema::DT_BOOL,
'nullable' => false,
'default' => 0
],
'corporationCharacters' => [
'has-many' => ['Model\CharacterModel', 'corporationId']
],
'mapCorporations' => [
'has-many' => ['Model\CorporationMapModel', 'corporationId']
]
];
/**
* get all cooperation data
* @return \stdClass
*/
public function getData(){
$cooperationData = (object) [];
$cooperationData->id = $this->id;
$cooperationData->name = $this->name;
$cooperationData->shared = $this->shared;
return $cooperationData;
}
/**
* get all maps for this corporation
* @return MapModel[]
*/
public function getMaps(){
$maps = [];
$this->filter('mapCorporations',
['active = ?', 1],
['order' => 'created']
);
if($this->mapCorporations){
$mapCount = 0;
foreach($this->mapCorporations as $mapCorporation){
if(
$mapCorporation->mapId->isActive() &&
$mapCount < Config::getMapsDefaultConfig('corporation')['max_count']
){
$maps[] = $mapCorporation->mapId;
$mapCount++;
}
}
}
return $maps;
}
/**
* get all characters in this corporation
* @param array $characterIds
* @param array $options
* @return CharacterModel[]
*/
public function getCharacters($characterIds = [], $options = []){
$characters = [];
$filter = ['active = ?', 1];
if( !empty($characterIds) ){
$filter[0] .= ' AND id IN (?)';
$filter[] = $characterIds;
}
$this->filter('corporationCharacters', $filter);
if($options['hasLog']){
// just characters with active log data
$this->has('corporationCharacters.characterLog', ['active = ?', 1]);
}
if($this->corporationCharacters){
foreach($this->corporationCharacters as $character){
$characters[] = $character;
}
}
return $characters;
}
/**
* get roles for each character in this corp
* -> CCP API call
* @param string $accessToken
* @return array
*/
public function getCharactersRoles($accessToken){
$characterRolesData = [];
if(
!empty($accessToken) &&
!$this->isNPC
){
$characterRolesData = self::getF3()->ccpClient->getCorporationRoles($this->_id, $accessToken);
}
return $characterRolesData;
}
/**
* get all corporations
* @param array $options
* @return \DB\CortexCollection
*/
public static function getAll($options = []){
$query = [
'active = :active',
':active' => 1
];
if( !$options['addNPC'] ){
$query[0] .= ' AND isNPC = :isNPC';
$query[':isNPC'] = 1;
}
return (new self())->find($query);
}
}