Skip to content

B!Q Common service layer for SOA communication

License

Notifications You must be signed in to change notification settings

Carvago/service-layer

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

BootIq - Service Layer

BOOT!Q Logo

pipeline status coverage report

Service Layer vendor, for SOA communication (REST/SOAP).

Installation

For installation of Boot!Q Service Layer, use composer:

composer require bootiq/service-layer

Adapters

BootIq\ServiceLayer\Adapter\GuzzleAdapter

Default adapter is GuzzleAdapter, primary for REST communication.

Configuration

  • dependencies
    • client - GuzzleHttp\ClientInterface - client for calling requests.
    • responseFactory - BootIq\ServiceLayer\Response\ResponseFactoryInterface - response factory for creating specific response.
    • urn - URN of API (for example: https://api.bootiq.io).
  • timeout - request timeout provided by setTimeout method (default: 10s).
  • cache - if you want cache responses, provide your cache service (PSR-16).
  • logger - if you want log what is going on in adapter, provide your logger service (PSR-3).

Own adapter

To create your own adapter, you have to implement BootIq\ServiceLayer\Adapter\AdapterInterface.

Enum

Library provides enums:

Exception

We provide base exception for working with our service layer (BootIq\ServiceLayer\Exception\ServiceLayerException).

Requests

Every request which can be called by adapter must implement BootIq\ServiceLayer\Request\RequestInterface.

In BootIq\ServiceLayer\Request namespace are abstract classes for various http methods, for more simple integration with our service layer.

For example:

<?php

namespace BootIq\CmsApiVendor\Request\Page;

use BootIq\ServiceLayer\Request\GetMethod;

class GetPageRequest extends GetMethod
{

    /**
     * @var int
     */
    private $pageId;

    /**
     * GetPageRequest constructor.
     * @param int $pageId
     */
    public function __construct(int $pageId)
    {
        $this->pageId = $pageId;
    }

    /**
     * @return string
     */
    public function getEndpoint(): string
    {
        return 'page/' . $this->pageId;
    }
}

Response

Every response returned by adapter must implement BootIq\ServiceLayer\Response\ResponseInterface.

We provide default response object BootIq\ServiceLayer\Response\Response and default response factory BootIq\ServiceLayer\Response\ResponseFactory for faster implementation.

About

B!Q Common service layer for SOA communication

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%