Files
pathfinder/app/Model/Universe/StructureModel.php
Mark Friedrich a5f29ee2eb - NEW "Thera connections" UI module, closed #829
- Upgraded "[_pathfinder_esi_](https://github.com/exodus4d/pathfinder_esi)" Web API client`v1.3.2` → `v2.0.0`
- Fixed a js bug where current active(selected) system becomes deselected after system was dragged on map
- Fixed a js bug where new auto mapped systems (e.g. after jump) were positioned outside current map scroll viewport
- Fixed a js bug where map sync failed after map tabs switch
- Fixed blurry map when map zoom was changed
- Fixed multiple minor JS bugs where map render/update failed
2020-03-02 16:42:36 +01:00

126 lines
3.4 KiB
PHP

<?php
/**
* Created by PhpStorm.
* User: Exodus 4D
* Date: 14.10.2017
* Time: 15:56
*/
namespace Exodus4D\Pathfinder\Model\Universe;
use DB\SQL;
use DB\SQL\Schema;
class StructureModel extends AbstractUniverseModel {
/**
* @var string
*/
protected $table = 'structure';
/**
* @var array
*/
protected $fieldConf = [
'name' => [
'type' => Schema::DT_VARCHAR128,
'nullable' => false,
'default' => ''
],
'systemId' => [
'type' => Schema::DT_INT,
'index' => true,
'belongs-to-one' => 'Exodus4D\Pathfinder\Model\Universe\SystemModel',
'constraint' => [
[
'table' => 'system',
'on-delete' => 'CASCADE'
]
],
'validate' => 'notDry'
],
'typeId' => [
'type' => Schema::DT_INT,
'index' => true,
'belongs-to-one' => 'Exodus4D\Pathfinder\Model\Universe\TypeModel',
'constraint' => [
[
'table' => 'type',
'on-delete' => 'CASCADE'
]
],
'validate' => 'notDry'
],
'x' => [
'type' => Schema::DT_FLOAT,
'nullable' => false,
'default' => 0
],
'y' => [
'type' => Schema::DT_FLOAT,
'nullable' => false,
'default' => 0
],
'z' => [
'type' => Schema::DT_FLOAT,
'nullable' => false,
'default' => 0
]
];
/**
* get data from object
* -> more fields can be added in here if needed
* @return \stdClass
*/
public function getData(): \stdClass {
$data = (object) [];
if($this->valid()){
$data->id = $this->_id;
$data->name = $this->name;
$data->type = $this->typeId->getData();
}
return $data;
}
/**
* load data from API into $this and save $this
* @param int $id
* @param string $accessToken
* @param array $additionalOptions
*/
protected function loadData(int $id, string $accessToken = '', array $additionalOptions = []){
$data = self::getF3()->ccpClient()->send('getUniverseStructure', $id, $accessToken);
if(!empty($data) && !isset($data['error'])){
/**
* @var $type TypeModel
*/
$type = $this->rel('typeId');
$type->loadById($data['typeId'], $accessToken, $additionalOptions);
$data['typeId'] = $type;
$this->copyfrom($data, ['id', 'name', 'systemId', 'typeId', 'position']);
$this->save();
}
}
/**
* overwrites parent
* @param null|SQL $db
* @param null $table
* @param null $fields
* @return bool
* @throws \Exception
*/
public static function setup($db = null, $table = null, $fields = null){
if($status = parent::setup($db, $table, $fields)){
//change `id` column to BigInt
$schema = new Schema($db);
$typeQuery = $schema->findQuery($schema->dataTypes[Schema::DT_BIGINT]);
$db->exec("ALTER TABLE " . $db->quotekey('structure') .
" MODIFY COLUMN " . $db->quotekey('id') . " " . $typeQuery . " NOT NULL");
}
return $status;
}
}