2020-05-25 19:46:31 +02:00
|
|
|
<?php namespace MapGuesser\Controller;
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
use DateTime;
|
2020-06-09 00:56:00 +02:00
|
|
|
use MapGuesser\Interfaces\Request\IRequest;
|
2020-05-25 19:46:31 +02:00
|
|
|
use MapGuesser\Util\Geo\Position;
|
2020-05-31 20:43:14 +02:00
|
|
|
use MapGuesser\Response\JsonContent;
|
|
|
|
use MapGuesser\Interfaces\Response\IContent;
|
2021-03-19 23:14:01 +01:00
|
|
|
use MapGuesser\Multi\MultiConnector;
|
2021-05-12 15:34:15 +02:00
|
|
|
use MapGuesser\PersistentData\Model\UserInChallenge;
|
2021-03-19 23:14:01 +01:00
|
|
|
use MapGuesser\PersistentData\PersistentDataManager;
|
2021-05-12 21:01:26 +02:00
|
|
|
use MapGuesser\PersistentData\Model\Guess;
|
2021-05-05 19:19:38 +02:00
|
|
|
use MapGuesser\PersistentData\Model\UserPlayedPlace;
|
2021-05-12 15:34:15 +02:00
|
|
|
use MapGuesser\Repository\ChallengeRepository;
|
2021-05-12 21:01:26 +02:00
|
|
|
use MapGuesser\Repository\GuessRepository;
|
|
|
|
use MapGuesser\Repository\MapRepository;
|
2021-03-19 23:14:01 +01:00
|
|
|
use MapGuesser\Repository\MultiRoomRepository;
|
2021-05-12 21:01:26 +02:00
|
|
|
use MapGuesser\Repository\PlaceInChallengeRepository;
|
2020-06-02 01:16:59 +02:00
|
|
|
use MapGuesser\Repository\PlaceRepository;
|
2021-05-12 15:34:15 +02:00
|
|
|
use MapGuesser\Repository\UserInChallengeRepository;
|
2021-05-05 19:19:38 +02:00
|
|
|
use MapGuesser\Repository\UserPlayedPlaceRepository;
|
2021-05-13 13:06:24 +02:00
|
|
|
use MapGuesser\Repository\UserRepository;
|
2020-05-25 19:46:31 +02:00
|
|
|
|
2020-06-05 00:59:23 +02:00
|
|
|
class GameFlowController
|
2020-05-25 19:46:31 +02:00
|
|
|
{
|
|
|
|
const NUMBER_OF_ROUNDS = 5;
|
|
|
|
const MAX_SCORE = 1000;
|
|
|
|
|
2020-06-09 00:56:00 +02:00
|
|
|
private IRequest $request;
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
private PersistentDataManager $pdm;
|
|
|
|
|
|
|
|
private MultiConnector $multiConnector;
|
|
|
|
|
|
|
|
private MultiRoomRepository $multiRoomRepository;
|
|
|
|
|
2020-06-02 01:16:59 +02:00
|
|
|
private PlaceRepository $placeRepository;
|
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
private MapRepository $mapRepository;
|
|
|
|
|
2021-05-13 13:06:24 +02:00
|
|
|
private UserRepository $userRepository;
|
|
|
|
|
2021-05-05 19:19:38 +02:00
|
|
|
private UserPlayedPlaceRepository $userPlayedPlaceRepository;
|
|
|
|
|
2021-05-12 15:34:15 +02:00
|
|
|
private ChallengeRepository $challengeRepository;
|
|
|
|
|
|
|
|
private UserInChallengeRepository $userInChallengeRepository;
|
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
private PlaceInChallengeRepository $placeInChallengeRepository;
|
|
|
|
|
|
|
|
private GuessRepository $guessRepository;
|
|
|
|
|
2020-06-09 00:56:00 +02:00
|
|
|
public function __construct(IRequest $request)
|
2020-06-02 01:16:59 +02:00
|
|
|
{
|
2020-06-09 00:56:00 +02:00
|
|
|
$this->request = $request;
|
2021-03-19 23:14:01 +01:00
|
|
|
$this->pdm = new PersistentDataManager();
|
|
|
|
$this->multiConnector = new MultiConnector();
|
|
|
|
$this->multiRoomRepository = new MultiRoomRepository();
|
2020-06-02 01:16:59 +02:00
|
|
|
$this->placeRepository = new PlaceRepository();
|
2021-05-12 21:01:26 +02:00
|
|
|
$this->mapRepository = new MapRepository();
|
2021-05-13 13:06:24 +02:00
|
|
|
$this->userRepository = new UserRepository();
|
2021-05-05 19:19:38 +02:00
|
|
|
$this->userPlayedPlaceRepository = new UserPlayedPlaceRepository();
|
2021-05-12 15:34:15 +02:00
|
|
|
$this->challengeRepository = new ChallengeRepository();
|
|
|
|
$this->userInChallengeRepository = new UserInChallengeRepository();
|
2021-05-12 21:01:26 +02:00
|
|
|
$this->placeInChallengeRepository = new PlaceInChallengeRepository();
|
|
|
|
$this->guessRepository = new GuessRepository();
|
2020-06-02 01:16:59 +02:00
|
|
|
}
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
public function initialData(): IContent
|
2020-05-30 15:33:28 +02:00
|
|
|
{
|
2020-06-09 00:56:00 +02:00
|
|
|
$mapId = (int) $this->request->query('mapId');
|
|
|
|
$session = $this->request->session();
|
2020-05-25 19:46:31 +02:00
|
|
|
|
2020-06-09 00:56:00 +02:00
|
|
|
if (!($state = $session->get('state')) || $state['mapId'] !== $mapId) {
|
2020-07-05 00:58:03 +02:00
|
|
|
return new JsonContent(['error' => 'no_session_found']);
|
2020-05-25 19:46:31 +02:00
|
|
|
}
|
|
|
|
|
2021-03-15 13:58:44 +01:00
|
|
|
if (!isset($state['currentRound']) || $state['currentRound'] == -1 || $state['currentRound'] >= static::NUMBER_OF_ROUNDS) {
|
2021-05-06 17:12:18 +02:00
|
|
|
$this->startNewGame($state, $mapId);
|
2021-03-19 23:14:01 +01:00
|
|
|
$session->set('state', $state);
|
2021-03-15 13:58:44 +01:00
|
|
|
}
|
2020-06-20 00:03:49 +02:00
|
|
|
|
2021-03-15 13:58:44 +01:00
|
|
|
$response = [];
|
2020-05-25 19:46:31 +02:00
|
|
|
|
2021-03-15 13:58:44 +01:00
|
|
|
$last = $state['rounds'][$state['currentRound']];
|
|
|
|
$response['place'] = [
|
|
|
|
'panoId' => $last['panoId'],
|
|
|
|
'pov' => $last['pov']->toArray()
|
|
|
|
];
|
|
|
|
|
|
|
|
$response['history'] = [];
|
|
|
|
for ($i = 0; $i < $state['currentRound']; ++$i) {
|
|
|
|
$round = $state['rounds'][$i];
|
|
|
|
$response['history'][] = [
|
|
|
|
'position' => $round['position']->toArray(),
|
2021-04-03 13:38:16 +02:00
|
|
|
'result' => [
|
|
|
|
'guessPosition' => $round['guessPosition']->toArray(),
|
|
|
|
'distance' => $round['distance'],
|
|
|
|
'score' => $round['score']
|
|
|
|
]
|
2020-05-25 19:46:31 +02:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2021-03-15 13:58:44 +01:00
|
|
|
return new JsonContent($response);
|
2020-05-31 20:43:14 +02:00
|
|
|
}
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
public function multiInitialData(): IContent
|
|
|
|
{
|
|
|
|
$roomId = $this->request->query('roomId');
|
|
|
|
$session = $this->request->session();
|
|
|
|
|
|
|
|
if (!($multiState = $session->get('multiState')) || $multiState['roomId'] !== $roomId) {
|
|
|
|
return new JsonContent(['error' => 'no_session_found']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$room = $this->multiRoomRepository->getByRoomId($roomId);
|
|
|
|
$state = $room->getStateArray();
|
|
|
|
$members = $room->getMembersArray();
|
|
|
|
|
|
|
|
if ($members['owner'] !== $multiState['token']) {
|
|
|
|
return new JsonContent(['error' => 'not_owner_of_room']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($state['currentRound'] == -1 || $state['currentRound'] >= static::NUMBER_OF_ROUNDS - 1) {
|
|
|
|
$this->startNewGame($state, $state['mapId']);
|
|
|
|
$room->setStateArray($state);
|
|
|
|
$room->setUpdatedDate(new DateTime());
|
|
|
|
$this->pdm->saveToDb($room);
|
|
|
|
}
|
|
|
|
|
|
|
|
$places = [];
|
|
|
|
foreach ($state['rounds'] as $round) {
|
|
|
|
$places[] = [
|
|
|
|
'position' => $round['position']->toArray(),
|
|
|
|
'panoId' => $round['panoId'],
|
|
|
|
'pov' => $round['pov']->toArray()
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->multiConnector->sendMessage('start_game', ['roomId' => $roomId, 'places' => $places]);
|
|
|
|
|
|
|
|
return new JsonContent(['ok' => true]);
|
|
|
|
}
|
|
|
|
|
2021-05-12 15:34:15 +02:00
|
|
|
public function challengeInitialData(): IContent
|
|
|
|
{
|
|
|
|
$session = $this->request->session();
|
|
|
|
$userId = $session->get('userId');
|
|
|
|
$challengeToken_str = $this->request->query('challengeToken');
|
|
|
|
$challenge = $this->challengeRepository->getByTokenStr($challengeToken_str);
|
|
|
|
|
|
|
|
if (!isset($challenge)) {
|
|
|
|
return new JsonContent(['error' => 'game_not_found']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$userInChallenge = $this->userInChallengeRepository->getByUserIdAndChallenge($userId, $challenge);
|
|
|
|
$currentRound = $userInChallenge->getRound();
|
2021-05-12 21:01:26 +02:00
|
|
|
$currentPlace = $this->placeRepository->getByRoundInChallenge($challenge, $currentRound);
|
2021-05-12 15:34:15 +02:00
|
|
|
|
|
|
|
$response = [];
|
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
$response['history'] = [];
|
2021-05-12 15:34:15 +02:00
|
|
|
|
2021-05-13 19:48:25 +02:00
|
|
|
$guessesByUser = iterator_to_array($this->guessRepository->getAllInChallengeByUser($userId, $challenge));
|
2021-05-12 21:01:26 +02:00
|
|
|
$places = iterator_to_array($this->placeRepository->getAllInChallenge($challenge));
|
2021-05-13 19:48:25 +02:00
|
|
|
|
|
|
|
|
|
|
|
for($i = 0; $i < $currentRound; ++$i) {
|
2021-05-12 15:34:15 +02:00
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
$response['history'][] = [
|
|
|
|
'position' => $places[$i]->getPosition()->toArray(),
|
|
|
|
'result' => [
|
2021-05-13 19:48:25 +02:00
|
|
|
'guessPosition' => $guessesByUser[$i]->getPosition()->toArray(),
|
|
|
|
'distance' => $guessesByUser[$i]->getDistance(),
|
|
|
|
'score' => $guessesByUser[$i]->getScore()
|
|
|
|
],
|
|
|
|
'allResults' => []
|
2021-05-12 21:01:26 +02:00
|
|
|
];
|
2021-05-13 19:48:25 +02:00
|
|
|
|
|
|
|
foreach($this->guessRepository->getAllInChallengeByRound($i, $challenge) as $guess) {
|
|
|
|
if($guess->getUserId() != $userId) {
|
|
|
|
$user = $this->userRepository->getByGuess($guess);
|
|
|
|
|
|
|
|
$response['history'][$i]['allResults'][] = [
|
|
|
|
'userName' => $user->getDisplayName(),
|
|
|
|
'guessPosition' => $guess->getPosition()->toArray(),
|
|
|
|
'distance' => $guess->getDistance(),
|
|
|
|
'score' => $guess->getScore()
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
2021-05-12 21:01:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if(!isset($currentPlace)) { // game finished
|
|
|
|
$response['finished'] = true;
|
|
|
|
|
|
|
|
} else { // continue game
|
|
|
|
$response['place'] = [
|
|
|
|
'panoId' => $currentPlace->getPanoIdCached(),
|
|
|
|
'pov' => [$currentPlace->getPov()->toArray()]
|
|
|
|
];
|
|
|
|
}
|
2021-05-12 15:34:15 +02:00
|
|
|
|
|
|
|
return new JsonContent($response);
|
|
|
|
}
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
public function guess(): IContent
|
2020-05-31 20:43:14 +02:00
|
|
|
{
|
2020-06-09 00:56:00 +02:00
|
|
|
$mapId = (int) $this->request->query('mapId');
|
|
|
|
$session = $this->request->session();
|
2020-05-31 20:43:14 +02:00
|
|
|
|
2020-06-09 00:56:00 +02:00
|
|
|
if (!($state = $session->get('state')) || $state['mapId'] !== $mapId) {
|
2020-07-05 00:58:03 +02:00
|
|
|
return new JsonContent(['error' => 'no_session_found']);
|
2020-05-31 20:43:14 +02:00
|
|
|
}
|
|
|
|
|
2021-03-15 13:58:44 +01:00
|
|
|
$last = $state['rounds'][$state['currentRound']];
|
2020-06-09 00:56:00 +02:00
|
|
|
$guessPosition = new Position((float) $this->request->post('lat'), (float) $this->request->post('lng'));
|
2021-05-12 21:01:26 +02:00
|
|
|
$result = $this->evaluateGuess($last['position'], $guessPosition, $state['area']);
|
2020-05-31 20:43:14 +02:00
|
|
|
|
2020-06-09 00:56:00 +02:00
|
|
|
$last['guessPosition'] = $guessPosition;
|
2021-03-19 23:14:01 +01:00
|
|
|
$last['distance'] = $result['distance'];
|
|
|
|
$last['score'] = $result['score'];
|
2020-05-31 20:43:14 +02:00
|
|
|
|
2021-03-15 12:28:06 +01:00
|
|
|
$response = [
|
2021-04-03 13:38:16 +02:00
|
|
|
'position' => $last['position']->toArray(),
|
|
|
|
'result' => $result
|
2021-03-15 12:28:06 +01:00
|
|
|
];
|
2020-05-31 20:43:14 +02:00
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
$state['rounds'][$state['currentRound']] = $last;
|
|
|
|
$state['currentRound'] += 1;
|
2021-03-15 13:58:44 +01:00
|
|
|
if ($state['currentRound'] < static::NUMBER_OF_ROUNDS) {
|
|
|
|
$next = $state['rounds'][$state['currentRound']];
|
2020-06-20 00:03:49 +02:00
|
|
|
|
2021-03-15 13:58:44 +01:00
|
|
|
$response['place'] = [
|
|
|
|
'panoId' => $next['panoId'],
|
|
|
|
'pov' => $next['pov']->toArray()
|
2021-03-15 12:28:06 +01:00
|
|
|
];
|
2020-05-31 20:43:14 +02:00
|
|
|
}
|
|
|
|
|
2020-06-20 00:03:49 +02:00
|
|
|
$session->set('state', $state);
|
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
$this->saveVisit($last['placeId']);
|
2021-05-06 10:05:23 +02:00
|
|
|
|
2021-05-06 10:09:28 +02:00
|
|
|
return new JsonContent($response);
|
2021-05-06 10:05:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// save the selected place for the round in UserPlayedPlace
|
2021-05-12 21:01:26 +02:00
|
|
|
private function saveVisit($placeId): void
|
2021-05-06 10:05:23 +02:00
|
|
|
{
|
|
|
|
$session = $this->request->session();
|
2021-05-05 19:19:38 +02:00
|
|
|
$userId = $session->get('userId');
|
2021-05-06 17:12:18 +02:00
|
|
|
|
2021-05-05 19:19:38 +02:00
|
|
|
if(isset($userId)) {
|
|
|
|
$userPlayedPlace = $this->userPlayedPlaceRepository->getByUserIdAndPlaceId($userId, $placeId);
|
|
|
|
if(!$userPlayedPlace) {
|
|
|
|
$userPlayedPlace = new UserPlayedPlace();
|
|
|
|
$userPlayedPlace->setUserId($userId);
|
|
|
|
$userPlayedPlace->setPlaceId($placeId);
|
|
|
|
} else {
|
|
|
|
$userPlayedPlace->incrementOccurrences();
|
|
|
|
}
|
|
|
|
$userPlayedPlace->setLastTimeDate(new DateTime());
|
|
|
|
$this->pdm->saveToDb($userPlayedPlace);
|
|
|
|
}
|
2020-05-25 19:46:31 +02:00
|
|
|
}
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
public function multiGuess(): IContent
|
|
|
|
{
|
|
|
|
$roomId = $this->request->query('roomId');
|
|
|
|
$session = $this->request->session();
|
|
|
|
|
|
|
|
if (!($multiState = $session->get('multiState')) || $multiState['roomId'] !== $roomId) {
|
|
|
|
return new JsonContent(['error' => 'no_session_found']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$room = $this->multiRoomRepository->getByRoomId($roomId);
|
|
|
|
$state = $room->getStateArray();
|
|
|
|
|
|
|
|
$last = $state['rounds'][$state['currentRound']];
|
|
|
|
$guessPosition = new Position((float) $this->request->post('lat'), (float) $this->request->post('lng'));
|
2021-05-12 21:01:26 +02:00
|
|
|
$result = $this->evaluateGuess($last['position'], $guessPosition, $state['area']);
|
2021-03-19 23:14:01 +01:00
|
|
|
|
2021-04-04 23:18:26 +02:00
|
|
|
$responseFromMulti = $this->multiConnector->sendMessage('guess', [
|
2021-03-19 23:14:01 +01:00
|
|
|
'roomId' => $roomId,
|
|
|
|
'token' => $multiState['token'],
|
2021-04-03 13:38:16 +02:00
|
|
|
'guessPosition' => $guessPosition->toArray(),
|
2021-03-19 23:14:01 +01:00
|
|
|
'distance' => $result['distance'],
|
|
|
|
'score' => $result['score']
|
|
|
|
]);
|
|
|
|
|
2021-04-04 23:18:26 +02:00
|
|
|
if (isset($responseFromMulti['error'])) {
|
|
|
|
return new JsonContent(['error' => $responseFromMulti['error']]);
|
|
|
|
}
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
$response = [
|
2021-04-03 13:38:16 +02:00
|
|
|
'position' => $last['position']->toArray(),
|
|
|
|
'result' => $result,
|
2021-04-04 23:18:26 +02:00
|
|
|
'allResults' => $responseFromMulti['allResults']
|
2021-03-19 23:14:01 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
return new JsonContent($response);
|
|
|
|
}
|
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
public function challengeGuess(): IContent
|
|
|
|
{
|
|
|
|
$session = $this->request->session();
|
|
|
|
$userId = $session->get('userId');
|
|
|
|
$challengeToken_str = $this->request->query('challengeToken');
|
|
|
|
$challenge = $this->challengeRepository->getByTokenStr($challengeToken_str);
|
|
|
|
|
|
|
|
if (!isset($challenge)) {
|
|
|
|
return new JsonContent(['error' => 'game_not_found']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$userInChallenge = $this->userInChallengeRepository->getByUserIdAndChallenge($userId, $challenge);
|
|
|
|
$currentRound = $userInChallenge->getRound();
|
|
|
|
$currentPlace = $this->placeRepository->getByRoundInChallenge($challenge, $currentRound);
|
|
|
|
$map = $this->mapRepository->getByPlace($currentPlace);
|
|
|
|
$placeInChallenge = $this->placeInChallengeRepository->getByPlaceAndChallenge($currentPlace, $challenge);
|
|
|
|
|
2021-05-13 13:06:24 +02:00
|
|
|
// fill in all other results for the round
|
|
|
|
$response['allResults'] = [];
|
|
|
|
foreach($this->guessRepository->getAllInChallengeByRound($currentRound, $challenge) as $guess) {
|
|
|
|
$user = $this->userRepository->getByGuess($guess);
|
|
|
|
$response['allResults'][] = [
|
|
|
|
'userName' => $user->getDisplayName(),
|
|
|
|
'guessPosition' => $guess->getPosition()->toArray(),
|
|
|
|
'distance' => $guess->getDistance(),
|
|
|
|
'score' => $guess->getScore()
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
$guessPosition = new Position((float) $this->request->post('lat'), (float) $this->request->post('lng'));
|
|
|
|
$result = $this->evaluateGuess($currentPlace->getPosition(), $guessPosition, $map->getArea());
|
|
|
|
|
|
|
|
// save guess
|
|
|
|
$guess = new Guess();
|
|
|
|
$guess->setUserId($userId);
|
|
|
|
$guess->setPlaceInChallenge($placeInChallenge);
|
|
|
|
$guess->setPosition($guessPosition);
|
|
|
|
$guess->setDistance($result['distance']);
|
|
|
|
$guess->setScore($result['score']);
|
|
|
|
$this->pdm->saveToDb($guess);
|
|
|
|
|
2021-05-13 13:06:24 +02:00
|
|
|
// $response = [
|
|
|
|
// 'position' => $currentPlace->getPosition()->toArray(),
|
|
|
|
// 'result' => $result
|
|
|
|
// ];
|
|
|
|
$response['position'] = $currentPlace->getPosition()->toArray();
|
|
|
|
$response['result'] = $result;
|
2021-05-12 21:01:26 +02:00
|
|
|
|
|
|
|
// update round
|
|
|
|
$nextRound = $currentRound + 1;
|
|
|
|
|
|
|
|
$userInChallenge->setRound($nextRound);
|
|
|
|
$this->pdm->saveToDb($userInChallenge);
|
|
|
|
|
|
|
|
if ($nextRound < static::NUMBER_OF_ROUNDS) {
|
|
|
|
|
|
|
|
$nextPlace = $this->placeRepository->getByRoundInChallenge($challenge, $nextRound);
|
|
|
|
|
|
|
|
$response['place'] = [
|
|
|
|
'panoId' => $nextPlace->getPanoIdCached(),
|
|
|
|
'pov' => $nextPlace->getPov()->toArray()
|
|
|
|
];
|
2021-05-13 13:06:24 +02:00
|
|
|
|
2021-05-13 19:48:25 +02:00
|
|
|
} else {
|
|
|
|
|
|
|
|
$guessesByUser = iterator_to_array($this->guessRepository->getAllInChallengeByUser($userId, $challenge));
|
|
|
|
$places = iterator_to_array($this->placeRepository->getAllInChallenge($challenge));
|
|
|
|
|
|
|
|
for($i = 0; $i < $nextRound; ++$i) {
|
|
|
|
|
|
|
|
$response['history'][] = [
|
|
|
|
'position' => $places[$i]->getPosition()->toArray(),
|
|
|
|
'result' => [
|
|
|
|
'guessPosition' => $guessesByUser[$i]->getPosition()->toArray(),
|
|
|
|
'distance' => $guessesByUser[$i]->getDistance(),
|
|
|
|
'score' => $guessesByUser[$i]->getScore()
|
|
|
|
],
|
|
|
|
'allResults' => []
|
|
|
|
];
|
|
|
|
|
|
|
|
foreach($this->guessRepository->getAllInChallengeByRound($i, $challenge) as $guess) {
|
|
|
|
// if($guess->getUserId() != $userId) {
|
|
|
|
$user = $this->userRepository->getByGuess($guess);
|
|
|
|
|
|
|
|
$response['history'][$i]['allResults'][] = [
|
|
|
|
'userName' => $user->getDisplayName(),
|
|
|
|
'guessPosition' => $guess->getPosition()->toArray(),
|
|
|
|
'distance' => $guess->getDistance(),
|
|
|
|
'score' => $guess->getScore()
|
|
|
|
];
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
}
|
2021-05-13 13:06:24 +02:00
|
|
|
|
2021-05-13 19:48:25 +02:00
|
|
|
}
|
2021-05-13 13:06:24 +02:00
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
$this->saveVisit($currentPlace->getId());
|
|
|
|
|
|
|
|
return new JsonContent($response);
|
|
|
|
}
|
|
|
|
|
2021-03-19 23:14:01 +01:00
|
|
|
public function multiNextRound(): IContent
|
|
|
|
{
|
|
|
|
$roomId = $this->request->query('roomId');
|
|
|
|
$session = $this->request->session();
|
|
|
|
|
|
|
|
if (!($multiState = $session->get('multiState')) || $multiState['roomId'] !== $roomId) {
|
|
|
|
return new JsonContent(['error' => 'no_session_found']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$room = $this->multiRoomRepository->getByRoomId($roomId);
|
|
|
|
$state = $room->getStateArray();
|
|
|
|
$members = $room->getMembersArray();
|
|
|
|
|
|
|
|
if ($members['owner'] !== $multiState['token']) {
|
|
|
|
return new JsonContent(['error' => 'not_owner_of_room']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$state['currentRound'] += 1;
|
|
|
|
if ($state['currentRound'] < static::NUMBER_OF_ROUNDS) {
|
|
|
|
$this->multiConnector->sendMessage('next_round', ['roomId' => $roomId, 'currentRound' => $state['currentRound']]);
|
|
|
|
}
|
|
|
|
|
|
|
|
$room->setStateArray($state);
|
|
|
|
$room->setUpdatedDate(new DateTime());
|
|
|
|
$this->pdm->saveToDb($room);
|
|
|
|
|
|
|
|
return new JsonContent(['ok' => true]);
|
|
|
|
}
|
|
|
|
|
2021-05-12 21:01:26 +02:00
|
|
|
private function evaluateGuess(Position $realPosition, Position $guessPosition, float $area)
|
2021-03-19 23:14:01 +01:00
|
|
|
{
|
|
|
|
$distance = $this->calculateDistance($realPosition, $guessPosition);
|
|
|
|
$score = $this->calculateScore($distance, $area);
|
|
|
|
|
|
|
|
return ['distance' => $distance, 'score' => $score];
|
|
|
|
}
|
|
|
|
|
2021-05-06 17:12:18 +02:00
|
|
|
private function startNewGame(array &$state, int $mapId): void
|
2020-06-20 00:03:49 +02:00
|
|
|
{
|
2021-05-06 17:12:18 +02:00
|
|
|
$session = $this->request->session();
|
2021-05-06 20:25:48 +02:00
|
|
|
$userId = $session->get('userId');
|
2021-05-06 17:12:18 +02:00
|
|
|
|
2021-05-05 19:19:38 +02:00
|
|
|
$places = $this->placeRepository->getRandomNPlaces($mapId, static::NUMBER_OF_ROUNDS, $userId);
|
2021-03-15 13:58:44 +01:00
|
|
|
|
|
|
|
$state['rounds'] = [];
|
|
|
|
$state['currentRound'] = 0;
|
|
|
|
|
|
|
|
foreach ($places as $place) {
|
|
|
|
$state['rounds'][] = [
|
|
|
|
'placeId' => $place->getId(),
|
|
|
|
'position' => $place->getPosition(),
|
|
|
|
'panoId' => $place->getPanoIdCached(),
|
|
|
|
'pov' => $place->getPov()
|
|
|
|
];
|
|
|
|
}
|
2020-06-20 00:03:49 +02:00
|
|
|
}
|
|
|
|
|
2020-05-25 19:46:31 +02:00
|
|
|
private function calculateDistance(Position $realPosition, Position $guessPosition): float
|
|
|
|
{
|
|
|
|
return $realPosition->calculateDistanceTo($guessPosition);
|
|
|
|
}
|
|
|
|
|
2020-05-28 21:05:55 +02:00
|
|
|
private function calculateScore(float $distance, float $area): int
|
2020-05-25 19:46:31 +02:00
|
|
|
{
|
2020-06-12 21:55:04 +02:00
|
|
|
$goodness = 1.0 - ($distance / (sqrt($area) * 1000));
|
2020-05-25 19:46:31 +02:00
|
|
|
|
2020-05-28 21:05:55 +02:00
|
|
|
return (int) round(pow(static::MAX_SCORE, $goodness));
|
2020-05-25 19:46:31 +02:00
|
|
|
}
|
|
|
|
}
|