Get all track questions
GET /api/v1/track-question-templates
params
'page' => 'integer|min:1'
'per_page' => 'required_with:page|integer|min:5|max:100'
filter
'name' => ['=@', '==']
'label' => ['=@', '==']
'class_name' => ['==']
order
* id
* name
* label
expand
* tracks
scopes
%s/summits/read/all
Add track question
POST /api/v1/track-question-templates
payload
'name' => 'sometimes|alpha_dash|max:255'
'label' => 'sometimes|string'
'is_mandatory' => 'sometimes|boolean'
'is_read_only' => 'sometimes|boolean'
'tracks' => 'sometimes|int_array'
for
TrackCheckBoxQuestionTemplate and TrackTextBoxQuestionTemplate
'initial_value' => 'string|sometimes'
for
TrackDropDownQuestionTemplate
'is_multiselect' => 'sometimes|boolean'
'is_country_selector' => 'sometimes|boolean'
scopes
%s/summits/write
%s/track-question-templates/write
PUT /api/v1/track-question-templates/{track_question_template_id}
payload same as POST
scopes
%s/summits/write
%s/track-question-templates/write
delete track question
DELETE /api/v1/track-question-templates/{track_question_template_id}
scopes
%s/summits/write
%s/track-question-templates/write
get track question metadata
GET /api/v1/track-question-templates/metadata
scopes
%s/summits/read/all
add track question value
POST /api/v1/track-question-templates/{track_question_template_id}/values
payload
'value' => 'required|string|max:255'
'label' => 'required|string'
scopes
%s/summits/write
%s/track-question-templates/write
update track question value
/api/v1/track-question-templates/{track_question_template_id}/values/{track_question_template_value_id}
payload
'value' => 'sometimes|string|max:255'
'label' => 'sometimes|string'
'order' => 'sometimes|integer|min:1'
delete track question value
DELETE /api/v1/track-question-templates/{track_question_template_id}/values/{track_question_template_value_id}
scopes
%s/summits/write
%s/track-question-templates/write
get track question template value
GET /api/v1/track-question-templates/{track_question_template_id}/values/{track_question_template_value_id}
scopes
'%s/summits/read/all'
Change-Id: I663bccf3987cb0b7e337e0fe5b92f3723fac5cd6
361 lines
15 KiB
PHP
361 lines
15 KiB
PHP
<?php
|
|
/**
|
|
* Copyright 2015 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 Illuminate\Database\Seeder;
|
|
use Illuminate\Support\Facades\Config;;
|
|
use App\Models\ResourceServer\ApiScope;
|
|
use LaravelDoctrine\ORM\Facades\EntityManager;
|
|
use Illuminate\Support\Facades\DB;
|
|
use App\Security\SummitScopes;
|
|
use App\Security\OrganizationScopes;
|
|
/**
|
|
* Class ApiScopesSeeder
|
|
*/
|
|
final class ApiScopesSeeder extends Seeder
|
|
{
|
|
|
|
public function run()
|
|
{
|
|
DB::table('endpoint_api_scopes')->delete();
|
|
DB::table('api_scopes')->delete();
|
|
|
|
$this->seedSummitScopes();
|
|
$this->seedMembersScopes();
|
|
$this->seedTeamsScopes();
|
|
$this->seedTagsScopes();
|
|
$this->seedCompaniesScopes();
|
|
$this->seedGroupsScopes();
|
|
$this->seedOrganizationScopes();
|
|
}
|
|
|
|
private function seedSummitScopes()
|
|
{
|
|
|
|
$current_realm = Config::get('app.url');
|
|
$api = EntityManager::getRepository(\App\Models\ResourceServer\Api::class)->findOneBy(['name' => 'summits']);
|
|
|
|
$scopes = [
|
|
[
|
|
'name' => sprintf(SummitScopes::ReadSummitData, $current_realm),
|
|
'short_description' => 'Get Summit Data',
|
|
'description' => 'Grants read only access for Summits Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::ReadAllSummitData, $current_realm),
|
|
'short_description' => 'Get All Summits Data',
|
|
'description' => 'Grants read only access for All Summits Data',
|
|
],
|
|
[
|
|
'name' => sprintf('%s/me/read', $current_realm),
|
|
'short_description' => 'Get own summit member data',
|
|
'description' => 'Grants read only access for our own summit member data',
|
|
],
|
|
[
|
|
'name' => sprintf('%s/me/summits/events/favorites/add', $current_realm),
|
|
'short_description' => 'Allows to add Summit events as favorite',
|
|
'description' => 'Allows to add Summit events as favorite',
|
|
],
|
|
[
|
|
'name' => sprintf('%s/me/summits/events/favorites/delete', $current_realm),
|
|
'short_description' => 'Allows to remove Summit events as favorite',
|
|
'description' => 'Allows to remove Summit events as favorite',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteSummitData, $current_realm),
|
|
'short_description' => 'Write Summit Data',
|
|
'description' => 'Grants write access for Summits Data',
|
|
],
|
|
array(
|
|
'name' => sprintf(SummitScopes::WriteEventData, $current_realm),
|
|
'short_description' => 'Write Summit Events',
|
|
'description' => 'Grants write access for Summits Events',
|
|
),
|
|
array(
|
|
'name' => sprintf(SummitScopes::WritePresentationData, $current_realm),
|
|
'short_description' => 'Write Summit Presentations',
|
|
'description' => 'Grants write access for Summits Presentations',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/summits/delete-event', $current_realm),
|
|
'short_description' => 'Delete Summit Events',
|
|
'description' => 'Grants delete access for Summits Events',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/summits/publish-event', $current_realm),
|
|
'short_description' => 'Publish/UnPublish Summit Events',
|
|
'description' => 'Grants Publish/UnPublish access for Summits Events',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/summits/read-external-orders', $current_realm),
|
|
'short_description' => 'Allow to read External Orders',
|
|
'description' => 'Allow to read External Orders',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/summits/confirm-external-orders', $current_realm),
|
|
'short_description' => 'Allow to confirm External Orders',
|
|
'description' => 'Allow to confirm External Orders',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/summits/write-videos', $current_realm),
|
|
'short_description' => 'Allow to write presentation videos',
|
|
'description' => 'Allow to write presentation videos',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/summits/read-notifications', $current_realm),
|
|
'short_description' => 'Allow to read summit notifications',
|
|
'description' => 'Allow to read summit notifications',
|
|
),
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteSpeakersData, $current_realm),
|
|
'short_description' => 'Write Speakers Data',
|
|
'description' => 'Grants write access for Speakers Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteMySpeakersData, $current_realm),
|
|
'short_description' => 'Write My Speakers Profile Data',
|
|
'description' => 'Grants write access for My Speaker Profile Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteAttendeesData, $current_realm),
|
|
'short_description' => 'Write Attendees Data',
|
|
'description' => 'Grants write access for Attendees Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WritePromoCodeData, $current_realm),
|
|
'short_description' => 'Write Promo Codes Data',
|
|
'description' => 'Grants write access for Promo Codes Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteLocationsData, $current_realm),
|
|
'short_description' => 'Write Summit Locations Data',
|
|
'description' => 'Grants write access for Summit Locations Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteLocationBannersData, $current_realm),
|
|
'short_description' => 'Write Summit Location Banners Data',
|
|
'description' => 'Grants write access for Summit Location Banners Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteTrackTagGroupsData, $current_realm),
|
|
'short_description' => 'Write Summit Track Tag Groups Data',
|
|
'description' => 'Grants write access for Summit Track Tag Groups Data',
|
|
],
|
|
[
|
|
'name' => sprintf(SummitScopes::WriteTrackQuestionTemplateData, $current_realm),
|
|
'short_description' => 'Write Summit Track Question Template Data',
|
|
'description' => 'Grants write access for Summit Track Question Template Data',
|
|
],
|
|
];
|
|
|
|
foreach ($scopes as $scope_info) {
|
|
$scope = new ApiScope();
|
|
$scope->setName($scope_info['name']);
|
|
$scope->setShortDescription($scope_info['short_description']);
|
|
$scope->setDescription($scope_info['description']);
|
|
$scope->setActive(true);
|
|
$scope->setDefault(false);
|
|
$scope->setApi($api);
|
|
EntityManager::persist($scope);
|
|
}
|
|
|
|
EntityManager::flush();
|
|
|
|
}
|
|
|
|
private function seedMembersScopes(){
|
|
$current_realm = Config::get('app.url');
|
|
$api = EntityManager::getRepository(\App\Models\ResourceServer\Api::class)->findOneBy(['name' => 'members']);
|
|
|
|
$scopes = [
|
|
array(
|
|
'name' => sprintf('%s/members/read', $current_realm),
|
|
'short_description' => 'Get Members Data',
|
|
'description' => 'Grants read only access for Members Data',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/members/read/me', $current_realm),
|
|
'short_description' => 'Get My Member Data',
|
|
'description' => 'Grants read only access for My Member',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/members/invitations/read', $current_realm),
|
|
'short_description' => 'Allows read only access to invitations',
|
|
'description' => 'Allows read only access to invitations',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/members/invitations/write', $current_realm),
|
|
'short_description' => 'Allows write only access to invitations',
|
|
'description' => 'Allows write only access to invitations',
|
|
),
|
|
array(
|
|
'name' => sprintf(SummitScopes::WriteMemberData, $current_realm),
|
|
'short_description' => 'Allows write only access to members',
|
|
'description' => 'Allows write only access to memberss',
|
|
),
|
|
];
|
|
|
|
foreach ($scopes as $scope_info) {
|
|
$scope = new ApiScope();
|
|
$scope->setName($scope_info['name']);
|
|
$scope->setShortDescription($scope_info['short_description']);
|
|
$scope->setDescription($scope_info['description']);
|
|
$scope->setActive(true);
|
|
$scope->setDefault(false);
|
|
$scope->setApi($api);
|
|
EntityManager::persist($scope);
|
|
}
|
|
|
|
EntityManager::flush();
|
|
}
|
|
|
|
private function seedTagsScopes(){
|
|
$current_realm = Config::get('app.url');
|
|
$api = EntityManager::getRepository(\App\Models\ResourceServer\Api::class)->findOneBy(['name' => 'organizations']);
|
|
|
|
$scopes = [
|
|
[
|
|
'name' => sprintf('%s/tags/read', $current_realm),
|
|
'short_description' => 'Get Tags Data',
|
|
'description' => 'Grants read only access for Tags Data',
|
|
],
|
|
];
|
|
|
|
foreach ($scopes as $scope_info) {
|
|
$scope = new ApiScope();
|
|
$scope->setName($scope_info['name']);
|
|
$scope->setShortDescription($scope_info['short_description']);
|
|
$scope->setDescription($scope_info['description']);
|
|
$scope->setActive(true);
|
|
$scope->setDefault(false);
|
|
$scope->setApi($api);
|
|
EntityManager::persist($scope);
|
|
}
|
|
|
|
EntityManager::flush();
|
|
}
|
|
|
|
private function seedOrganizationScopes(){
|
|
$current_realm = Config::get('app.url');
|
|
$api = EntityManager::getRepository(\App\Models\ResourceServer\Api::class)->findOneBy(['name' => 'companies']);
|
|
|
|
$scopes = [
|
|
[
|
|
'name' => sprintf(OrganizationScopes::ReadOrganizationData, $current_realm),
|
|
'short_description' => 'Get Organizations Data',
|
|
'description' => 'Grants read only access for Organization Data',
|
|
],
|
|
[
|
|
'name' => sprintf(OrganizationScopes::WriteOrganizationData, $current_realm),
|
|
'short_description' => 'Write Companies Data',
|
|
'description' => 'Grants write access for Organization Data',
|
|
],
|
|
];
|
|
|
|
foreach ($scopes as $scope_info) {
|
|
$scope = new ApiScope();
|
|
$scope->setName($scope_info['name']);
|
|
$scope->setShortDescription($scope_info['short_description']);
|
|
$scope->setDescription($scope_info['description']);
|
|
$scope->setActive(true);
|
|
$scope->setDefault(false);
|
|
$scope->setApi($api);
|
|
EntityManager::persist($scope);
|
|
}
|
|
|
|
EntityManager::flush();
|
|
}
|
|
|
|
private function seedCompaniesScopes(){
|
|
$current_realm = Config::get('app.url');
|
|
$api = EntityManager::getRepository(\App\Models\ResourceServer\Api::class)->findOneBy(['name' => 'companies']);
|
|
|
|
$scopes = [
|
|
array(
|
|
'name' => sprintf('%s/companies/read', $current_realm),
|
|
'short_description' => 'Get Companies Data',
|
|
'description' => 'Grants read only access for Companies Data',
|
|
),
|
|
];
|
|
|
|
foreach ($scopes as $scope_info) {
|
|
$scope = new ApiScope();
|
|
$scope->setName($scope_info['name']);
|
|
$scope->setShortDescription($scope_info['short_description']);
|
|
$scope->setDescription($scope_info['description']);
|
|
$scope->setActive(true);
|
|
$scope->setDefault(false);
|
|
$scope->setApi($api);
|
|
EntityManager::persist($scope);
|
|
}
|
|
|
|
EntityManager::flush();
|
|
}
|
|
|
|
private function seedGroupsScopes(){
|
|
$current_realm = Config::get('app.url');
|
|
$api = EntityManager::getRepository(\App\Models\ResourceServer\Api::class)->findOneBy(['name' => 'groups']);
|
|
|
|
$scopes = [
|
|
array(
|
|
'name' => sprintf('%s/groups/read', $current_realm),
|
|
'short_description' => 'Get Groups Data',
|
|
'description' => 'Grants read only access for Groups Data',
|
|
),
|
|
];
|
|
|
|
foreach ($scopes as $scope_info) {
|
|
$scope = new ApiScope();
|
|
$scope->setName($scope_info['name']);
|
|
$scope->setShortDescription($scope_info['short_description']);
|
|
$scope->setDescription($scope_info['description']);
|
|
$scope->setActive(true);
|
|
$scope->setDefault(false);
|
|
$scope->setApi($api);
|
|
EntityManager::persist($scope);
|
|
}
|
|
|
|
EntityManager::flush();
|
|
}
|
|
|
|
private function seedTeamsScopes(){
|
|
$current_realm = Config::get('app.url');
|
|
$api = EntityManager::getRepository(\App\Models\ResourceServer\Api::class)->findOneBy(['name' => 'teams']);
|
|
|
|
$scopes = [
|
|
array(
|
|
'name' => sprintf('%s/teams/read', $current_realm),
|
|
'short_description' => 'Get Teams Data',
|
|
'description' => 'Grants read only access for Teams Data',
|
|
),
|
|
array(
|
|
'name' => sprintf('%s/teams/write', $current_realm),
|
|
'short_description' => 'Write Teams Data',
|
|
'description' => 'Grants write access for Teams Data',
|
|
),
|
|
];
|
|
|
|
foreach ($scopes as $scope_info) {
|
|
$scope = new ApiScope();
|
|
$scope->setName($scope_info['name']);
|
|
$scope->setShortDescription($scope_info['short_description']);
|
|
$scope->setDescription($scope_info['description']);
|
|
$scope->setActive(true);
|
|
$scope->setDefault(false);
|
|
$scope->setApi($api);
|
|
EntityManager::persist($scope);
|
|
}
|
|
|
|
EntityManager::flush();
|
|
}
|
|
|
|
} |