You are here

class JsonapiExtrasServiceProvider in JSON:API Extras 8.3

Same name and namespace in other branches
  1. 8 src/JsonapiExtrasServiceProvider.php \Drupal\jsonapi_extras\JsonapiExtrasServiceProvider
  2. 8.2 src/JsonapiExtrasServiceProvider.php \Drupal\jsonapi_extras\JsonapiExtrasServiceProvider

Replace the resource type repository for our own configurable version.

Hierarchy

Expanded class hierarchy of JsonapiExtrasServiceProvider

File

src/JsonapiExtrasServiceProvider.php, line 13

Namespace

Drupal\jsonapi_extras
View source
class JsonapiExtrasServiceProvider extends ServiceProviderBase {

  /**
   * {@inheritdoc}
   */
  public function alter(ContainerBuilder $container) {
    $settings = BootstrapConfigStorageFactory::get()
      ->read('jsonapi_extras.settings');
    if ($settings !== FALSE) {
      $container
        ->setParameter('jsonapi.base_path', '/' . $settings['path_prefix']);
    }

    // Enable normalizers in the "src-impostor-normalizers" directory to be
    // within the \Drupal\jsonapi\Normalizer namespace in order to circumvent
    // the encapsulation enforced by
    // \Drupal\jsonapi\Serializer\Serializer::__construct().
    $container_namespaces = $container
      ->getParameter('container.namespaces');
    $container_modules = $container
      ->getParameter('container.modules');
    $jsonapi_impostor_path = dirname($container_modules['jsonapi_extras']['pathname']) . '/src-impostor-normalizers';
    $container_namespaces['Drupal\\jsonapi\\Normalizer\\ImpostorFrom\\jsonapi_extras'][] = $jsonapi_impostor_path;

    // Manually include the impostor definitions to avoid class not found error
    // during compilation, which gets triggered though cache-clear.
    $container
      ->getDefinition('serializer.normalizer.field_item.jsonapi_extras')
      ->setFile($jsonapi_impostor_path . '/FieldItemNormalizerImpostor.php');
    $container
      ->getDefinition('serializer.normalizer.resource_identifier.jsonapi_extras')
      ->setFile($jsonapi_impostor_path . '/ResourceIdentifierNormalizerImpostor.php');
    $container
      ->getDefinition('serializer.normalizer.resource_object.jsonapi_extras')
      ->setFile($jsonapi_impostor_path . '/ResourceObjectNormalizerImpostor.php');
    $container
      ->getDefinition('serializer.normalizer.content_entity.jsonapi_extras')
      ->setFile($jsonapi_impostor_path . '/ContentEntityDenormalizerImpostor.php');
    $container
      ->getDefinition('serializer.normalizer.config_entity.jsonapi_extras')
      ->setFile($jsonapi_impostor_path . '/ConfigEntityDenormalizerImpostor.php');
    $container
      ->setParameter('container.namespaces', $container_namespaces);
  }

  /**
   * {@inheritdoc}
   */
  public function register(ContainerBuilder $container) {
    $modules = $container
      ->getParameter('container.modules');
    if (isset($modules['schemata_json_schema'])) {

      // Register field definition schema override.
      $container
        ->register('serializer.normalizer.field_definition.schema_json.jsonapi_extras', 'Drupal\\jsonapi_extras\\Normalizer\\SchemaFieldDefinitionNormalizer')
        ->addTag('normalizer', [
        'priority' => 32,
      ])
        ->addArgument(new Reference('jsonapi.resource_type.repository'));

      // Register top-level schema override.
      $container
        ->register('serializer.normalizer.schemata_schema_normalizer.schema_json.jsonapi_extras', 'Drupal\\jsonapi_extras\\Normalizer\\SchemataSchemaNormalizer')
        ->addTag('normalizer', [
        'priority' => 100,
      ])
        ->addArgument(new Reference('jsonapi.resource_type.repository'));
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
JsonapiExtrasServiceProvider::alter public function Modifies existing service definitions. Overrides ServiceProviderBase::alter
JsonapiExtrasServiceProvider::register public function Registers services to the container. Overrides ServiceProviderBase::register