Skip to content

Commit

Permalink
Merge pull request #163 from Kern046/master
Browse files Browse the repository at this point in the history
Release v2.1.2
  • Loading branch information
acknowledge authored Aug 9, 2017
2 parents 46525ab + 276633e commit 5a3a779
Show file tree
Hide file tree
Showing 17 changed files with 251 additions and 92 deletions.
34 changes: 34 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,37 @@
## [2.1.2] - 2017-08-09
### Added
- Storage of the sectors ownership data in Redis

### Fixed
- Commanders defection when their base is taken
- Display of the incoming attacks in the admiralty
- Sectors ownership data in faction tactical registry
- Ending of recycling missions
- Conversion of the recycling places when there is no resources left

## [2.1.1] - 2017-07-23
### Added
- Spy and combat active report highlighting in the list
- Daily scheduling for notifications cleaning and inactive accounts management
- Daily scheduling for rankings
- Set an INI parameter for max execution time
- Redis session handling

### Fixed
- External invitations for registration
- School experience for commanders
- Access to admin interface
- Empty investments
- Conversation with no recipients error message
- Storage building informations
- Flashbags for queue's ending notification
- Ship recycling
- Parrainage reward
- Commercial shipping travel time
- Capital leaving
- Defenders losses after a successful defense
- Workers access to the session data

## [2.1.0] - 2017-06-01
### Added
- Container class for services and parameters
Expand Down
1 change: 1 addition & 0 deletions config/services.yml
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,7 @@ services:
arguments:
- "%redis_host"
- "%redis_port"
- "%redis_password"
- "%redis_timeout"

exception_listener:
Expand Down
7 changes: 7 additions & 0 deletions system/Classes/Daemon/Server.php
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,13 @@ public function treatCommand($data)
$data['data']['date']
);
break;
case 'cancel':
$this->realTimeActionScheduler->cancelFromProcess(
$data['data']['object_class'],
$data['data']['object_id'],
$data['data']['date']
);
break;
}
}

Expand Down
1 change: 1 addition & 0 deletions system/Classes/Library/Utils.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ class Utils {
public static function isAdmin($bindkey) {
$bindkeys = array(
'player1', 'player2', 'gil', 'noe', 'jacky',
'YNbrdEaJpDw8mLZ2u6jYqgt6a',
'jq2Bjf0uKzzE0aMErO6rpBxcg',
'E6GatZvhO1W9seBHU7mgQe49c',
'FaDcTV3lWokXHZO8tXH4divWZ',
Expand Down
2 changes: 0 additions & 2 deletions system/Classes/Process/ProcessGateway.php
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ class ProcessGateway
*/
public function writeTo(Process $process, $data)
{
\Asylamba\Classes\Daemon\Server::debug('Writing to Process : ' . json_encode($data));
fwrite($process->getOutput(), json_encode($data) . "\n");
}

Expand All @@ -23,7 +22,6 @@ public function writeTo(Process $process, $data)
*/
public function writeToMaster($data)
{
\Asylamba\Classes\Daemon\Server::debug('Writing to master: ' . json_encode($data));
fwrite(STDOUT, json_encode($data) . "\n");
}

Expand Down
4 changes: 3 additions & 1 deletion system/Classes/Redis/RedisManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,14 @@ class RedisManager
/**
* @param string $host
* @param int $port
* @param string $password
* @param float $timeout
*/
public function __construct($host, $port, $timeout)
public function __construct($host, $port, $password, $timeout)
{
$this->connection = new \Redis();
$this->connection->connect($host, $port, $timeout);
$this->connection->auth($password);
}

public function __destruct()
Expand Down
24 changes: 24 additions & 0 deletions system/Classes/Scheduler/RealTimeActionScheduler.php
Original file line number Diff line number Diff line change
Expand Up @@ -138,12 +138,36 @@ public function reschedule($object, $date, $oldDate) {
*/
public function cancel($object, $date)
{
if (P_TYPE === 'worker') {
return $this->processGateway->writeToMaster([
'command' => 'cancel',
'data' => [
'object_class' => get_class($object),
'object_id' => $object->id,
'date' => $date
]
]);
}
unset($this->queue[$date][get_class($object) . '-' . $object->id]);

if (empty($this->queue[$date])) {
unset($this->queue[$date]);
}
}

/**
* @param string $class
* @param int $id
* @param string $date
*/
public function cancelFromProcess($class, $id, $date)
{
unset($this->queue[$date][$class . '-' . $id]);

if (empty($this->queue[$date])) {
unset($this->queue[$date]);
}
}

/**
* @return array
Expand Down
2 changes: 2 additions & 0 deletions system/Classes/Task/TechnicalTask.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

class TechnicalTask extends Task
{
const DEFAULT_ESTIMATED_TIME = 10.00;

/**
* {@inheritdoc}
*/
Expand Down
2 changes: 2 additions & 0 deletions system/Classes/Worker/Application.php
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,8 @@ public function init()
$this->container->get('process_manager')->launchProcesses();
$this->container->get('realtime_action_scheduler')->init();
$this->container->get('cyclic_action_scheduler')->init();
$this->container->get('gaia.sector_manager')->initOwnershipData();

$server = $this->container->get('server');
$server->createHttpServer();
$server->listen();
Expand Down
11 changes: 6 additions & 5 deletions system/Modules/Athena/Manager/OrbitalBaseManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -420,7 +420,7 @@ public function changeOwnerById($id, $base, $newOwner, $baseCommanders) {
if (in_array($commander->statement, [Commander::INSCHOOL, Commander::ONSALE, Commander::RESERVE])) {
$commander->rPlayer = $newOwner;
} else if ($commander->statement == Commander::MOVING) {
$commander->statement = Commander::RETIRED;
$this->commanderManager->endTravel($commander, Commander::RETIRED);
$this->realtimeActionScheduler->cancel($commander, $commander->getArrivalDate());
} else {
$commander->statement = Commander::DEAD;
Expand Down Expand Up @@ -716,8 +716,7 @@ public function uRecycling($missionId) {
# if there is no more resource
if ($targetPlace->resources <= 0) {
# the place become an empty place
$targetPlace->resources = 0;
$targetPlace->typeOfPlace = Place::EMPTYZONE;
$this->placeManager->turnAsEmptyPlace($targetPlace);

# stop the mission
$mission->statement = RecyclingMission::ST_DELETED;
Expand Down Expand Up @@ -860,8 +859,10 @@ public function uRecycling($missionId) {

# update u
$mission->uRecycling = Utils::addSecondsToDate($mission->uRecycling, $mission->cycleTime);
// Schedule the next mission
$this->realtimeActionScheduler->schedule('athena.orbital_base_manager', 'uRecycling', $mission, $mission->uRecycling);
// Schedule the next mission if there is still resources
if ($mission->getStatement() !== RecyclingMission::ST_DELETED) {
$this->realtimeActionScheduler->schedule('athena.orbital_base_manager', 'uRecycling', $mission, $mission->uRecycling);
}
} else {
# the place become an empty place
$targetPlace->resources = 0;
Expand Down
41 changes: 3 additions & 38 deletions system/Modules/Gaia/EventListener/SectorListener.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,42 +16,29 @@ class SectorListener
protected $sectorManager;
/** @var SystemManager **/
protected $systemManager;
/** @var OrbitalBaseManager **/
protected $orbitalBaseManager;
/** @var PlayerManager **/
protected $playerManager;
/** @var EntityManager **/
protected $entityManager;
/** @var array **/
protected $scores;
/** @var int **/
protected $minimalScore;

/**
* @param SectorManager $sectorManager
* @param SystemManager $systemManager
* @param OrbitalBaseManager $orbitalBaseManager
* @param PlayerManager $playerManager
* @param EntityManager $entityManager
* @param RedisManager $redisManager
* @param array $scores
* @param int $minimalScore
*/
public function __construct(
SectorManager $sectorManager,
SystemManager $systemManager,
OrbitalBaseManager $orbitalBaseManager,
PlayerManager $playerManager,
EntityManager $entityManager,
$scores,
$minimalScore
)
{
$this->sectorManager = $sectorManager;
$this->systemManager = $systemManager;
$this->orbitalBaseManager = $orbitalBaseManager;
$this->playerManager = $playerManager;
$this->entityManager = $entityManager;
$this->scores = $scores;
$this->minimalScore = $minimalScore;
}

Expand All @@ -61,31 +48,9 @@ public function __construct(
public function onPlaceOwnerChange(PlaceOwnerChangeEvent $event)
{
$system = $this->systemManager->get($event->getPlace()->rSystem);
$systems = $this->systemManager->getSectorSystems($system->rSector);
$sector = $this->sectorManager->get($system->rSector);
$bases = $this->orbitalBaseManager->getSectorBases($system->rSector);
$scores = [];

foreach ($bases as $base)
{
$player = $this->playerManager->get($base->rPlayer);

$scores[$player->rColor] =
(!empty($scores[$player->rColor]))
? $scores[$player->rColor] + $this->scores[$base->typeOfBase]
: $this->scores[$base->typeOfBase]
;
}
// For each system, the owning faction gains two points
foreach ($systems as $system) {
if ($system->rColor === 0) {
continue;
}
$scores[$system->rColor] = (!empty($scores[$system->rColor])) ? $scores[$system->rColor] + 2 : 2;
}
$scores[0] = 0;
arsort($scores);
reset($scores);
$scores = $this->sectorManager->calculateOwnership($sector);

$newColor = key($scores);
$hasEnoughPoints = false;
foreach ($scores as $factionId => $score) {
Expand Down
9 changes: 9 additions & 0 deletions system/Modules/Gaia/Manager/PlaceManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,15 @@ public function updatePlayerPlaces() {
$this->entityManager->commit();
$this->entityManager->clear(Place::class);
}

/**
* @param Place $place
* @return bool
*/
public function turnAsEmptyPlace(Place $place)
{
return $this->entityManager->getRepository(Place::class)->turnAsEmptyPlace($place->getId());
}

public function turnAsSpawnPlace($placeId, $playerId)
{
Expand Down
Loading

0 comments on commit 5a3a779

Please sign in to comment.