abstract class ResourceBase in JSON:API Resources 8
Defines basic functionality for a JSON:API Resource.
Hierarchy
- class \Drupal\jsonapi_resources\Resource\ResourceBase
Expanded class hierarchy of ResourceBase
5 files declare their use of ResourceBase
- CurrentUserInfo.php in tests/modules/ jsonapi_resources_test/ src/ Resource/ CurrentUserInfo.php 
- JsonapiResourceClassResolver.php in src/Unstable/ DependencyInjection/ JsonapiResourceClassResolver.php 
- JsonapiResourceController.php in src/Unstable/ Controller/ JsonapiResourceController.php 
- ResourceEnhancer.php in src/Unstable/ Routing/ Enhancer/ ResourceEnhancer.php 
- ResourceRoutes.php in src/Unstable/ Routing/ ResourceRoutes.php 
File
- src/Resource/ ResourceBase.php, line 19 
Namespace
Drupal\jsonapi_resources\ResourceView source
abstract class ResourceBase {
  /**
   * The resource type repository.
   *
   * @var \Drupal\jsonapi\ResourceType\ResourceTypeRepositoryInterface
   */
  protected $resourceTypeRepository;
  /**
   * The resource response factory.
   *
   * @var \Drupal\jsonapi_resources\Unstable\ResourceResponseFactory
   */
  private $resourceResponseFactory;
  /**
   * The document extractor.
   *
   * @var \Drupal\jsonapi_resources\Unstable\DocumentExtractor
   */
  private $documentExtractor;
  /**
   * Sets the resource type repository.
   *
   * @param \Drupal\jsonapi\ResourceType\ResourceTypeRepositoryInterface $resource_type_repository
   *   A resource type repository.
   */
  public function setResourceTypeRepository(ResourceTypeRepositoryInterface $resource_type_repository) : void {
    $this->resourceTypeRepository = $resource_type_repository;
  }
  /**
   * Sets the resource response factory.
   *
   * @param \Drupal\jsonapi_resources\Unstable\ResourceResponseFactory $resource_response_factory
   *   A JSON:API resource response factory.
   */
  public function setResourceResponseFactory(ResourceResponseFactory $resource_response_factory) : void {
    $this->resourceResponseFactory = $resource_response_factory;
  }
  /**
   * Sets the document extractor.
   *
   * @param \Drupal\jsonapi_resources\Unstable\DocumentExtractor $document_extractor
   *   The document extractor.
   */
  public function setDocumentExtractor(DocumentExtractor $document_extractor) : void {
    $this->documentExtractor = $document_extractor;
  }
  /**
   * Get the document from the request.
   *
   * @param \Symfony\Component\HttpFoundation\Request $request
   *   The request.
   *
   * @return \Drupal\jsonapi\JsonApiResource\JsonApiDocumentTopLevel
   *   The document.
   */
  protected function getDocumentFromRequest(Request $request) : JsonApiDocumentTopLevel {
    return $this->documentExtractor
      ->getDocument($request);
  }
  /**
   * Builds a response with the appropriate wrapped document.
   *
   * @param \Drupal\jsonapi\JsonApiResource\ResourceObjectData $data
   *   The data to wrap.
   * @param \Symfony\Component\HttpFoundation\Request $request
   *   The request object.
   * @param int $response_code
   *   The response code.
   * @param array $headers
   *   An array of response headers.
   * @param \Drupal\jsonapi\JsonApiResource\LinkCollection $links
   *   The URLs to which to link. A 'self' link is added automatically.
   * @param array $meta
   *   (optional) The top-level metadata.
   *
   * @return \Drupal\jsonapi\ResourceResponse
   *   The response.
   *
   * @throws \Drupal\Component\Plugin\Exception\InvalidPluginDefinitionException
   * @throws \Drupal\Component\Plugin\Exception\PluginNotFoundException
   */
  protected function createJsonapiResponse(ResourceObjectData $data, Request $request, $response_code = 200, array $headers = [], LinkCollection $links = NULL, array $meta = []) : ResourceResponse {
    return $this->resourceResponseFactory
      ->create($data, $request, $response_code, $headers, $links, $meta);
  }
  /**
   * {@inheritdoc}
   */
  public function getRouteResourceTypes(Route $route, string $route_name) : array {
    return array_map(function ($resource_type_name) use ($route_name) {
      $resource_type = $this->resourceTypeRepository
        ->getByTypeName($resource_type_name);
      if (is_null($resource_type)) {
        // @todo: try to move this exception into Drupal\jsonapi_resources\Routing\ResourceRoutes::ensureResourceImplementationValid().
        throw new RouteDefinitionException("The {$route_name} route definition's _jsonapi_resource_types route default declares the resource type {$resource_type_name} but a resource type by that name does not exist.");
      }
      return $resource_type;
    }, $route
      ->getDefault('_jsonapi_resource_types') ?: []);
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| ResourceBase:: | private | property | The document extractor. | |
| ResourceBase:: | private | property | The resource response factory. | |
| ResourceBase:: | protected | property | The resource type repository. | |
| ResourceBase:: | protected | function | Builds a response with the appropriate wrapped document. | |
| ResourceBase:: | protected | function | Get the document from the request. | |
| ResourceBase:: | public | function | 2 | |
| ResourceBase:: | public | function | Sets the document extractor. | |
| ResourceBase:: | public | function | Sets the resource response factory. | |
| ResourceBase:: | public | function | Sets the resource type repository. | 
