
** Get all presentations from selection Plan GET /api/v1/summits/{id}/selection-plans/{selection_plan_id}/presentations filtering 'title' => ['=@', '=='], 'abstract' => ['=@', '=='], 'social_summary' => ['=@', '=='], 'tags' => ['=@', '=='], 'level' => ['=@', '=='], 'summit_type_id' => ['=='], 'event_type_id' => ['=='], 'track_id' => ['=='], 'speaker_id' => ['=='], 'speaker' => ['=@', '=='], 'speaker_email' => ['=@', '=='], 'selection_status' => ['=='], 'id' => ['=='], 'selection_plan_id' => ['=='], 'status' => ['=='], 'is_chair_visible' => ['=='], 'is_voting_visible' => ['=='], ** for track chairs app use 'filter' => 'status==Received,is_chair_visible==1', ordering track Scopes REALM_BASE_URL/summits/read AUTHZ super-admins administrators track-chairs track-chairs-admins ** Get individual Selection List GET /api/v1/summits/{id}/tracks/{track_id}/selection-lists/individual/owner/{owner_id} Scopes REALM_BASE_URL/summits/read AUTHZ super-admins administrators track-chairs track-chairs-admins ** Add to my individual Selection List POST /api/v1/summits/{id}/tracks/{track_id}/selection-lists/individual/presentation-selections/{collection}/presentations/{presentation_id} where {collection} should be one of following: * selected * maybe * pass Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Remove From my individual selection list DELETE /api/v1/summits/{id}/tracks/{track_id}/selection-lists/individual/presentation-selections/{collection}/presentations/{presentation_id} where {collection} should be one of following: * selected * maybe * pass Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Get Team Selection List GET /api/v1/summits/{id}/tracks/{track_id}/selection-lists/team Scopes REALM_BASE_URL/summits/read AUTHZ super-admins administrators track-chairs track-chairs-admins ** Create team selection list POST /api/v1/summits/{id}/tracks/{track_id}/selection-lists/team Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Reorder list PUT /api/v1/summits/{id}/tracks/{track_id}/selection-lists/{list_id}/reorder payload hash => 'required|string' collection => 'required|string|in:selected,maybe' presentations => 'required|int_array' ( presentations ids) Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Get track chairs per Summit GET /api/v1/summits/{id}/track-chairs fitering 'member_first_name' => ['=@', '=='], 'member_last_name' => ['=@', '=='], 'member_full_name' => ['=@', '=='], 'member_email' => ['=@', '=='], 'member_id' => ['=='], 'track_id' => ['=='], 'summit_id' => ['=='] Scopes REALM_BASE_URL/summits/read AUTHZ super-admins administrators track-chairs track-chairs-admins ** Mark Presentation as viewed PUT /api/v1/summits/{id}/selection-plans/{selection_plan_id}/presentations/{presentation_id}/view Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Add Presentation Comment POST /api/v1/summits/{id}/selection-plans/{selection_plan_id}/presentations/{presentation_id}/comments Payload 'body' => 'required|string', 'is_public' => 'required|boolean', Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Get all Presention Category Change Request GET /api/v1/summits/{id}/selection-plans/{selection_plan_id}/presentations/all/category-change-requests filtering 'selection_plan_id' => ['=='], 'summit_id' => ['=='], 'new_category_id' => ['=='], 'old_category_id' => ['=='], 'new_category_title' => ['=@', '=='], 'old_category_title' => ['=@', '=='], 'requester_fullname' => ['=@', '=='], 'requester_email' => ['=@', '=='], 'aprover_fullname' => ['=@', '=='], 'aprover_email' => ['=@', '=='] ordering 'id', 'approval_date', 'status' Scopes REALM_BASE_URL/summits/read REALM_BASE_URL/summits/read/all AUTHZ super-admins administrators track-chairs track-chairs-admins ** Add Presentation Category change Request POST /api/v1/summits/{id}/selection-plans/{selection_plan_id}/presentations/{presentation_id}/category-change-requests payload 'new_category_id' => 'required|integer', Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Resolve Presentation Category change Request PUT /api/v1/summits/{id}/selection-plans/{selection_plan_id}/presentations/{presentation_id}/category-change-requests/{category_change_request_id} payload 'approved' => 'required|bool', 'reason' => 'sometimes|string', Scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs track-chairs-admins ** Add track chair POST /api/v1/summits/{id}/track-chairs Payload 'member_id' => 'required|int', 'categories' => 'required|int_array', scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs-admins ** Update track chair PUT /api/v1/summits/{id}/track-chairs/{track_chair_id} Payload 'categories' => 'required|int_array', scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs-admins ** Delete track chairs DELETE /api/v1/summits/{id}/track-chairs/{track_chair_id} scopes REALM_BASE_URL/summits/write AUTHZ super-admins administrators track-chairs-admins ** Get Track Chair by Id GET /api/v1/summits/{id}/track-chairs/{track_chair_id} scopes REALM_BASE_URL/summits/read AUTHZ super-admins administrators track-chairs-admins Change-Id: Iab0d77a6337a0db27c649dcafb1d90f09923df8a Signed-off-by: smarcet <smarcet@gmail.com>
300 lines
9.1 KiB
PHP
300 lines
9.1 KiB
PHP
<?php namespace App\Repositories\Summit;
|
|
/**
|
|
* Copyright 2016 OpenStack Foundation
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
**/
|
|
|
|
use Doctrine\ORM\QueryBuilder;
|
|
use Illuminate\Support\Facades\Log;
|
|
use models\summit\ISummitRepository;
|
|
use models\summit\Summit;
|
|
use App\Repositories\SilverStripeDoctrineRepository;
|
|
use utils\DoctrineHavingFilterMapping;
|
|
|
|
/**
|
|
* Class DoctrineSummitRepository
|
|
* @package App\Repositories\Summit
|
|
*/
|
|
final class DoctrineSummitRepository
|
|
extends SilverStripeDoctrineRepository
|
|
implements ISummitRepository
|
|
{
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
protected function getFilterMappings()
|
|
{
|
|
return [
|
|
'name' => 'e.name',
|
|
'start_date' => 'e.begin_date:datetime_epoch',
|
|
'end_date' => 'e.end_date:datetime_epoch',
|
|
'submission_begin_date' => 'sp.submission_begin_date:datetime_epoch',
|
|
'submission_end_date' => 'sp.submission_end_date:datetime_epoch',
|
|
'voting_begin_date' => 'sp.voting_begin_date:datetime_epoch',
|
|
'voting_end_date' => 'sp.voting_end_date:datetime_epoch',
|
|
'selection_begin_date' => 'sp.selection_begin_date:datetime_epoch',
|
|
'selection_end_date' => 'sp.selection_end_date:datetime_epoch',
|
|
'selection_plan_enabled' => 'sp.is_enabled:json_boolean',
|
|
'registration_begin_date' => 'e.registration_begin_date:datetime_epoch',
|
|
'registration_end_date' => 'e.registration_end_date:datetime_epoch',
|
|
'available_on_api' => 'e.available_on_api:json_int',
|
|
'summit_id' => 'e.id:json_int',
|
|
'ticket_types_count' => new DoctrineHavingFilterMapping("", "tt.summit", "count(tt.id) :operator :value"),
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
protected function getOrderMappings()
|
|
{
|
|
return [
|
|
'id' => 'e.id',
|
|
'name' => 'e.name',
|
|
'start_date' => 'e.begin_date',
|
|
'registration_begin_date' => 'e.registration_begin_date',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @param QueryBuilder $query
|
|
* @return QueryBuilder
|
|
*/
|
|
protected function applyExtraFilters(QueryBuilder $query)
|
|
{
|
|
return $query;
|
|
}
|
|
|
|
/**
|
|
* @param QueryBuilder $query
|
|
* @return QueryBuilder
|
|
*/
|
|
protected function applyExtraJoins(QueryBuilder $query)
|
|
{
|
|
$query = $query->leftJoin("e.ticket_types", "tt");
|
|
$query = $query->leftJoin("e.selection_plans", "sp");
|
|
return $query;
|
|
}
|
|
|
|
/**
|
|
* @return Summit
|
|
*/
|
|
public function getCurrent()
|
|
{
|
|
$res = $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), "s")
|
|
->where('s.active = 1')
|
|
->orderBy('s.begin_date', 'DESC')
|
|
->getQuery()
|
|
->getResult();
|
|
if (count($res) == 0) return null;
|
|
return $res[0];
|
|
}
|
|
|
|
/**
|
|
* @return Summit[]
|
|
*/
|
|
public function getCurrentAndFutureSummits()
|
|
{
|
|
$now_utc = new \DateTime('now', new \DateTimeZone('UTC'));
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), "s")
|
|
// current
|
|
->where('s.begin_date <= :now and s.end_date >= :now')
|
|
// or future
|
|
->orWhere('s.begin_date >= :now')
|
|
->orderBy('s.begin_date', 'DESC')
|
|
->setParameter('now', $now_utc)
|
|
->getQuery()
|
|
->getResult();
|
|
}
|
|
|
|
/**
|
|
* @return Summit[]
|
|
*/
|
|
public function getAvailables()
|
|
{
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), "s")
|
|
->where('s.available_on_api = 1')
|
|
->orderBy('s.begin_date', 'ASC')
|
|
->getQuery()
|
|
->getResult();
|
|
}
|
|
|
|
/**
|
|
* @return Summit[]
|
|
*/
|
|
public function getAllOrderedByBeginDate()
|
|
{
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), "s")
|
|
->orderBy('s.begin_date', 'ASC')
|
|
->getQuery()
|
|
->getResult();
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
protected function getBaseEntity()
|
|
{
|
|
return Summit::class;
|
|
}
|
|
|
|
/**
|
|
* @param string $name
|
|
* @return Summit
|
|
*/
|
|
public function getByName($name)
|
|
{
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), "s")
|
|
->where('s.name = :name')
|
|
->setParameter('name', $name)
|
|
->getQuery()
|
|
->getOneOrNullResult();
|
|
}
|
|
|
|
/**
|
|
* @param string $slug
|
|
* @return Summit|null
|
|
*/
|
|
public function getBySlug(string $slug): ?Summit
|
|
{
|
|
try {
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), "s")
|
|
->where('s.slug = :slug')
|
|
->setParameter('slug', strtolower($slug))
|
|
->getQuery()
|
|
->getOneOrNullResult();
|
|
} catch (\Exception $ex) {
|
|
Log::warning($ex);
|
|
return null;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @return Summit
|
|
*/
|
|
public function getActive()
|
|
{
|
|
$res = $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), "s")
|
|
->where('s.active = 1')
|
|
->orderBy('s.begin_date', 'DESC')
|
|
->getQuery()
|
|
->getResult();
|
|
if (count($res) == 0) return null;
|
|
return $res[0];
|
|
}
|
|
|
|
/**
|
|
* @return Summit
|
|
*/
|
|
public function getCurrentAndAvailable()
|
|
{
|
|
$res = $this->getEntityManager()->createQueryBuilder()
|
|
->select("s")
|
|
->from($this->getBaseEntity(), 's')
|
|
->where('s.active = 1')
|
|
->andWhere('s.available_on_api = 1')
|
|
->orderBy('s.begin_date', 'DESC')
|
|
->getQuery()
|
|
->getResult();
|
|
if (count($res) == 0) return null;
|
|
return $res[0];
|
|
}
|
|
|
|
/**
|
|
* @return Summit[]
|
|
*/
|
|
public function getWithExternalFeed(): array
|
|
{
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("e")
|
|
->from($this->getBaseEntity(), "e")
|
|
->where("e.api_feed_type is not null")
|
|
->andWhere("e.api_feed_type <> ''")
|
|
->andWhere("e.api_feed_url is not null")
|
|
->andWhere("e.api_feed_url <> ''")
|
|
->andWhere("e.api_feed_key is not null")
|
|
->andWhere("e.api_feed_key <>''")
|
|
->andWhere("e.end_date >= :now")
|
|
->orderBy('e.id', 'DESC')
|
|
->setParameter("now", new \DateTime('now', new \DateTimeZone('UTC')))
|
|
->getQuery()
|
|
->getResult();
|
|
}
|
|
|
|
/**
|
|
* @return Summit[]
|
|
*/
|
|
public function getAllWithExternalRegistrationFeed(): array
|
|
{
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("e")
|
|
->from($this->getBaseEntity(), "e")
|
|
->where("e.api_feed_type is not null")
|
|
->andWhere("e.external_registration_feed_type <> ''")
|
|
->andWhere("e.external_registration_feed_type is not null")
|
|
->andWhere("e.external_registration_feed_api_key <> ''")
|
|
->andWhere("e.external_registration_feed_api_key is not null")
|
|
->andWhere("e.external_summit_id <> ''")
|
|
->andWhere("e.external_summit_id is not null")
|
|
->andWhere("e.end_date >= :now")
|
|
->orderBy('e.id', 'DESC')
|
|
->setParameter("now", new \DateTime('now', new \DateTimeZone('UTC')))
|
|
->getQuery()
|
|
->getResult();
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getNotEnded(): array
|
|
{
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("e")
|
|
->from($this->getBaseEntity(), "e")
|
|
->where("e.end_date >= :now")
|
|
->orderBy('e.id', 'DESC')
|
|
->setParameter("now", new \DateTime('now', new \DateTimeZone('UTC')))
|
|
->getQuery()
|
|
->getResult();
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
* @throws \Exception
|
|
*/
|
|
public function getOnGoing(): array
|
|
{
|
|
return $this->getEntityManager()->createQueryBuilder()
|
|
->select("e")
|
|
->from($this->getBaseEntity(), "e")
|
|
->where("e.begin_date <= :now")
|
|
->andWhere("e.end_date >= :now")
|
|
->orderBy('e.id', 'DESC')
|
|
->setParameter("now", new \DateTime('now', new \DateTimeZone('UTC')))
|
|
->getQuery()
|
|
->getResult();
|
|
}
|
|
} |