fei/filer-package

Filer client package integration for Objective PHP applications

v2.0.1 2018-12-13 00:36 UTC

README

This package provide Filer Client integration for Objective PHP applications.

Installation

Filer Package needs PHP 7.0 or up to run correctly.

You will have to integrate it to your Objective PHP project with composer require fei/filer-package.

Integration

As shown below, the Filer Package must be plugged in the application initialization method. The Filer Package create a Filer Client service that will be consumed by the application's middlewares.

<?php

use ObjectivePHP\Application\AbstractApplication;
use Fei\Service\Filer\Package\FilerPackage;

class Application extends AbstractApplication
{
    public function init()
    {
        // Define some application steps
        $this->addSteps('bootstrap', 'init', 'auth', 'route', 'rendering');
        
        // Initializations...

        // Plugging the Filer Package in the bootstrap step
        $this->getStep('bootstrap')
        ->plug(FilerPackage::class);

        // Another initializations...
    }
}

The name of the service will be filer.client. If you want to rename it, you can plug the package like this:

			// Plugging the Filer Package in the bootstrap step
			$this->getStep('bootstrap')
			->plug(new FilerPackage('my_service'));

Application configuration

`` Create a file in your configuration directory and put your Filer configuration as below:

<?php
use Fei\Service\Filer\Package\Config\FilerEndpoint;
use Fei\Service\Filer\Package\Config\FilerTransportOptions;
use Fei\Service\Filer\Package\Config\FilerAsyncTransport;
return [
    new FilerEndpoint('http://filer.dev'),
    new FilerTransportOptions([]),
    new FilerAsyncTransport('127.0.0.1')
];

In the previous example you need to set these configurations:

  • FilerEndpoint : represent the URL where the API can be contacted in order to send and retrieve the files
  • `FilerTransportOptions : represents the options for the transport of the request if you want to set specific options
  • `FilerAsyncTransport : if this config is set, the client will try to use the async transport instead of the BasicTransport

Please check out filer-client documentation for more information about how to use this client.