openstackid-resources/app/Repositories/Summit/DoctrineSummitRepository.php
smarcet dc6cfc296a Track chairs endpoints
** 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>
2021-02-19 13:54:28 -03:00

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();
}
}