mainQuery; $query .= ' ' . $this->whereQuery; $query .= ' ' . $this->havingQuery; $query .= ' ' . $this->orderByQuery; $query .= ' ' . $this->limitQuery; return $query; } /** * get system Data from CCPs [SDE] * search column for IDs can be (solarSystemID, regionID, constellationID) * @param array $columnIDs * @param string $column * @return Model\SystemModel[] * @throws \Exception */ public function getSystemModelByIds($columnIDs = [], $column = 'solarSystemID'){ $systemModels = []; $ccpDB = $this->getDB('CCP'); $this->whereQuery = "WHERE map_sys." . $column . " IN (" . implode(',', $columnIDs) . ")"; $query = $this->_getQuery(); $rows = $ccpDB->exec($query, null, 60 * 60 * 24); // format result $ccpSystemsData = (new Mapper\CcpSystemsMapper($rows))->getData(); foreach($ccpSystemsData as $ccpSystemData){ /** * @var Model\SystemModel $system */ $system = Model\BasicModel::getNew('SystemModel'); $system->setData($ccpSystemData); $systemModels[] = $system; } return $systemModels; } /** * Get all static system Data from CCP DB (long cache timer) * @return array */ public function getSystems(){ $ccpDB = $this->getDB('CCP'); $query = $this->_getQuery(); $rows = $ccpDB->exec($query, null, 60 * 60 * 24); // format result $mapper = new Mapper\CcpSystemsMapper($rows); return $mapper->getData(); } /** * search systems by name * @param \Base $f3 * @param array $params */ public function search(\Base $f3, $params){ $ccpDB = $this->getDB('CCP'); $searchToken = ''; // check for search parameter if( isset($params['arg1']) ){ $searchToken = $params['arg1']; } // some "edge cases" for testing trueSec rounding... //$searchToken = 'H472-N'; // -0.000001 -> 0.0 //$searchToken = 'X1E-OQ'; // -0.099426 -> -0.10 //$searchToken = 'BKK4-H'; // -0.049954 -> -0.05 //$searchToken = 'Uhtafal'; // 0.499612 -> 0.5 (HS) //$searchToken = 'Oshaima'; // 0.453128 -> 0.5 (HS) //$searchToken = 'Ayeroilen'; // 0.446568 -> 0.4 (LS) //$searchToken = 'Enderailen'; // 0.448785 -> 0.4 (LS) //$searchToken = 'Neziel'; // 0.449943 -> 0.4 (LS) //$searchToken = 'Naga'; // 0.033684 -> 0.1 (LS) $this->whereQuery = "WHERE map_sys.solarSystemName LIKE '%" . $searchToken . "%'"; $query = $this->_getQuery(); $rows = $ccpDB->exec($query); // format result $mapper = new Mapper\CcpSystemsMapper($rows); $data = $mapper->getData(); echo json_encode($data); } /** * save a new system to a a map * @param \Base $f3 */ public function save(\Base $f3){ $newSystemData = []; $postData = (array)$f3->get('POST'); if( isset($postData['systemData']) && isset($postData['mapData']) ){ $activeCharacter = $this->getCharacter(); $systemData = (array)$postData['systemData']; $mapData = (array)$postData['mapData']; $systemModel = null; if( isset($systemData['statusId']) ){ if( (int)$systemData['statusId'] <= 0){ unset($systemData['statusId']); }else{ $systemData['statusId'] = (int)$systemData['statusId']; } } if( isset($systemData['id']) ){ // update existing system (e.g. changed system description) ------------------------------------------- /** * @var $system Model\SystemModel */ $system = Model\BasicModel::getNew('SystemModel'); $system->getById($systemData['id']); if( !$system->dry() ){ if( $system->hasAccess($activeCharacter) ){ // system model found $systemModel = $system; } } }elseif( isset($mapData['id']) ){ // save NEW system ------------------------------------------------------------------------------------ /** * @var $map Model\MapModel */ $map = Model\BasicModel::getNew('MapModel'); $map->getById($mapData['id']); if( !$map->dry() && $map->hasAccess($activeCharacter) ){ // make sure system is not already on map // --> (e.g. multiple simultaneously save() calls for the same system) $systemModel = $map->getSystemByCCPId($systemData['systemId']); if( is_null($systemModel) ){ // system not found on map -> get static system data (CCP DB) $systemModel = $map->getNewSystem($systemData['systemId']); $systemModel->createdCharacterId = $activeCharacter; $systemModel->statusId = isset($systemData['statusId']) ? $systemData['statusId'] : 1; }else{ // system already exists (e.g. was inactive) $systemModel->statusId = isset($systemData['statusId']) ? $systemData['statusId'] : $systemModel->statusId; } // map is not changeable for a system! (security) $systemData['mapId'] = $map; } } if( !is_null($systemModel) ){ // "statusId" was set above unset($systemData['statusId']); unset($systemData['mapId']); unset($systemData['createdCharacterId']); unset($systemData['updatedCharacterId']); // set/update system $systemModel->setData($systemData); // activate system (e.g. was inactive)) $systemModel->setActive(true); $systemModel->updatedCharacterId = $activeCharacter; $systemModel->save(); // get data from "fresh" model (e.g. some relational data has changed: "statusId") $newSystemModel = Model\BasicModel::getNew('SystemModel'); $newSystemModel->getById( $systemModel->id, 0); $newSystemModel->clearCacheData(); $newSystemData = $newSystemModel->getData(); } } echo json_encode($newSystemData); } /** * get system log data from CCP API import * system Kills, Jumps,.... * @param \Base $f3 */ public function graphData(\Base $f3){ $graphData = []; $systemIds = $f3->get('POST.systemIds'); // number of log entries in each table per system (24 = 24h) $logEntryCount = 24; // table names with system data $logTables = [ 'jumps' => 'SystemJumpModel', 'shipKills' => 'SystemShipKillModel', 'podKills' => 'SystemPodKillModel', 'factionKills' => 'SystemFactionKillModel' ]; foreach($systemIds as $systemId){ foreach($logTables as $label => $ModelClass){ $systemLogModel = Model\BasicModel::getNew($ModelClass); // 10min cache (could be up to 1h cache time) $systemLogModel->getByForeignKey('systemId', $systemId, [], 60 * 10); if( !$systemLogModel->dry() ){ $counter = 0; for( $i = $logEntryCount; $i >= 1; $i--){ $column = 'value' . $i; // ship and pod kills should be merged into one table if($label == 'podKills'){ $graphData[$systemId]['shipKills'][$counter]['z'] = $systemLogModel->$column; }else{ $dataSet = [ 'x' => ($i - 1) . 'h', 'y' => $systemLogModel->$column ]; $graphData[$systemId][$label][] = $dataSet; } $counter++; } } } } echo json_encode($graphData); } /** * get system data for all systems within a constellation * @param \Base $f3 * @param array $params */ public function constellationData(\Base $f3, $params){ $return = (object) []; $return->error = []; $return->systemData = []; $constellationId = 0; // check for search parameter if( isset($params['arg1']) ){ $constellationId = (int)$params['arg1']; } $cacheKey = 'CACHE_CONSTELLATION_SYSTEMS_' . self::formatHiveKey($constellationId); if($f3->exists($cacheKey)){ $return->systemData = $f3->get($cacheKey); }else{ if($constellationId > 0){ $systemModels = $this->getSystemModelByIds([$constellationId], 'constellationID'); foreach($systemModels as $systemModel){ $return->systemData[] = $systemModel->getData(); } $f3->set($cacheKey, $return->systemData, $f3->get('PATHFINDER.CACHE.CONSTELLATION_SYSTEMS') ); } } echo json_encode($return); } /** * set destination for specific systemIds * @param \Base $f3 */ public function setDestination(\Base $f3){ $postData = (array)$f3->get('POST'); $return = (object) []; $return->error = []; $return->systemData = []; if( !empty($postData['systemData'] )){ $activeCharacter = $this->getCharacter(); $return->clearOtherWaypoints = (bool)$postData['clearOtherWaypoints']; $return->first = (bool)$postData['first']; /** * @var Sso $ssoController */ $ssoController = self::getController('Sso'); foreach($postData['systemData'] as $systemData){ $waypointData = $ssoController->setWaypoint($activeCharacter, $systemData['systemId'], [ 'clearOtherWaypoints' => $return->clearOtherWaypoints, 'first' => $return->first, ]); if($waypointData['systemId']){ $return->systemData[] = $systemData; }elseif( isset($waypointData['error']) ){ $return->error[] = $waypointData['error']; } } } echo json_encode($return); } /** * delete systems and all its connections from map * -> set "active" flag * @param \Base $f3 */ public function delete(\Base $f3){ $systemIds = (array)$f3->get('POST.systemIds'); $activeCharacter = $this->getCharacter(); /** * @var Model\SystemModel $system */ $system = Model\BasicModel::getNew('SystemModel'); foreach($systemIds as $systemId){ $system->getById($systemId); if( $system->hasAccess($activeCharacter) ){ $system->setActive(false); $system->save(); $system->reset(); } } echo json_encode([]); } }