itk-dev/beskedfordeler-symfony

Beskedfordeler for Symfony

Installs: 1 527

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 3

Forks: 0

Open Issues: 0

Type:symfony-bundle

1.0.1 2023-03-23 08:49 UTC

This package is auto-updated.

Last update: 2024-12-23 12:23:40 UTC


README

See https://digitaliseringskataloget.dk/integration/sf1461 for details on the Beskedfordeler.

Installation

Require the bundle:

composer require itk-dev/beskedfordeler-symfony

Enable the bundle:

// config/bundles.php
return [
    // …
    Itkdev\BeskedfordelerBundle\ItkdevBeskedfordelerBundle::class => ['all' => true],
];

Import routes:

# config/routes/itkdev_beskedfordeler.yaml
itkdev_beskedfordeler:
  resource: '@BeskedfordelerBundle/Resources/config/routes.php'

Make the /beskedfordeler routes publically accessible:

# config/packages/security.yaml
security:
    #
    access_control:
        #
        - { path: ^/beskedfordeler, role: PUBLIC_ACCESS }
        #

Routes:

  • /beskedfordeler/PostStatusBeskedModtag

Event subscriber

An event subscriber must be created to do something useful when getting a message from Beskedfordeler:

<?php
// src/EventSubscriber/BeskedfordelerEventSubscriber.php
namespace App\EventSubscriber;

use Itkdev\BeskedfordelerBundle\Event\PostStatusBeskedModtagEvent;
use Itkdev\BeskedfordelerBundle\Helper\MessageHelper;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;

class BeskedfordelerEventSubscriber implements EventSubscriberInterface
{
    private MessageHelper $messageHelper;

    public function __construct(private MessageHelper $messageHelper)
    {
    }

    public static function getSubscribedEvents() {
        return [
            PostStatusBeskedModtagEvent::class => 'postStatusBeskedModtag',
        ];
    }

    public function postStatusBeskedModtag(PostStatusBeskedModtagEvent $event): void {
        // Do something with the event.
        try {
            $data = $this->messageHelper->getBeskeddata($event->getDocument()->saveXML());
            // …
        } catch (\Throwable $exception) {
            // Log the exception.
        }
    }
}

Development

See docs/DEVELOPMENT.md.