dbp / relay-base-organization-connector-campusonline-bundle
A template bundle for the Relay API gateway
Maintainers
Details
github.com/digital-blueprint/relay-base-organization-connector-campusonline-bundle
Installs: 2 789
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 1
Type:symfony-bundle
Requires
- php: >=8.1
- ext-json: *
- api-platform/core: ^2.7.11 || ^3.2
- dbp/campusonline-api: ^0.3.13
- dbp/relay-base-organization-bundle: ^0.2.11
- dbp/relay-core-bundle: ^0.1.153
- psr/log: ^1.1.4 || ^2.0.0 || ^3.0.0
- symfony/config: ^5.4 || ^6.4
- symfony/dependency-injection: ^5.4 || ^6.4
- symfony/event-dispatcher: ^5.4 || ^6.4
- symfony/event-dispatcher-contracts: ^2.5 || ^3.4
- symfony/framework-bundle: ^5.4 || ^6.4
- symfony/http-foundation: ^5.4 || ^6.4
- symfony/http-kernel: ^5.4 || ^6.4
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.50
- phpstan/phpstan: ^1.10.59
- phpstan/phpstan-phpunit: ^1.3.16
- phpunit/phpunit: ^9.6.17
- symfony/browser-kit: ^5.4 || ^6.4
- symfony/http-client: ^5.4 || ^6.4
- symfony/monolog-bundle: ^3.10
- symfony/phpunit-bridge: ^7.0
- vimeo/psalm: ^5.22.2
README
Integration into the Relay API Server
- Add the bundle package as a dependency:
composer require dbp/relay-base-organization-connector-campusonline-bundle
- Add the bundle to your
config/bundles.php
:
... Dbp\Relay\BasePersonBundle\DbpRelayBaseOrganizationBundle::class => ['all' => true], Dbp\Relay\BasePersonBundle\DbpRelayBaseOrganizationConnectorCampusonlineBundle::class => ['all' => true], ...
- Run
composer install
to clear caches
Configuration
The bundle has some configuration values that you can specify in your app, either by hard-coding it, or by referencing an environment variable.
For this create config/packages/dbp_relay_base_organization_connector_ldap.yaml
in the app with the following
content:
dbp_relay_base_organization_connector_campusonline: campus_online: api_token: '%env(CAMPUS_ONLINE_API_TOKEN)%' api_url: '%env(CAMPUS_ONLINE_API_URL)%' org_root_id: '%env(ORGANIZATION_ROOT_ID)%'
For more info on bundle configuration see https://symfony.com/doc/current/bundles/configuration.html
Events
OrganizationPostEvent
This event allows you to add additional attributes ("local data") to the \Dbp\Relay\BaseOrganizationBundle\Entity\Organization
base-entity that you want to be included in responses to Organization
entity requests.
Event subscribers receive a \Dbp\Relay\RelayBaseOrganizationConnectorCampusonlineBundle\Event\OrganizationPostEvent
instance containing the Organization
base-entity and the organization data provided by Campusonline.
For example, create an event subscriber src/EventSubscriber/OrganizationEventSubscriber.php
:
<?php namespace App\EventSubscriber; use Dbp\Relay\BaseOrganizationConnectorCampusonlineBundle\Event\OrganizationPostEvent; use Symfony\Component\EventDispatcher\EventSubscriberInterface; class OrganizationEventSubscriber implements EventSubscriberInterface { public static function getSubscribedEvents(): array { return [ OrganizationPostEvent::NAME => 'onPost', ]; } public function onPost(OrganizationPostEvent $event) { $organization = $event->getOrganization(); $organizationData = $event->getOrganizationUnitData(); $organization->trySetLocalDataValue('code', $organizationData->getCode()); } }
And add it to your src/Resources/config/services.yaml
:
App\EventSubscriber\OrganizationEventSubscriber: autowire: true autoconfigure: true