2017 © Pedro Peláez
 

library accept

Provides content-negotiation using Accept* headers for BEAR.Sunday

image

bear/accept

Provides content-negotiation using Accept* headers for BEAR.Sunday

  • Thursday, August 10, 2017
  • by koriym
  • Repository
  • 2 Watchers
  • 1 Stars
  • 288 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 77 % Grown

The README.md

BEAR.Accept

Provides content-negotiation using Accept* headers for BEAR.Sunday, (*1)

Composer install

$ composer require bear/accept

Module install


use Ray\Di\AbstractModule; use Ray\Di\Scope; class AppModule extends AbstractModule { /** * {@inheritdoc} */ protected function configure() { $available = [ 'Accept' => [ 'application/hal+json' => 'prod-hal-app', 'application/json' => 'prod-app', 'text/csv' => 'prod-csv-app', 'cli' => 'prod-html-app' ], 'Accept-Language' => [ 'en-US' => 'en', 'ja-JP' => 'ja' ] ]; // $available support 'Accept' and 'Accept-Language' key only $this->install(new AcceptModule($available)); } }

Accept specifies all of the available media in the format [$mediatype => $context]. cli is the context in case of console access. The renderer of the context of the media type matched by content negotiation is used for rendering the resource., (*2)

Accept-Language specifies all available languages in the format [$lang => $contextKey]., (*3)

For example, if application/hal+json and ja-JPmatches, the $context is prod-hal-jp-app. (We set JpModule in App\Module folder and bind it for Japanese.), (*4)

Usage

Apply to the specified resource

Annotate the resource to do content negotiation with @Produces., (*5)

use use BEAR\Accept\Annotation\Produces;

/**
 * @Produces({"application/json", "text/csv"})
 */
public function onGet()

application/json and text/csv media type is available for this resource. The Vary header is added automatically., (*6)

Apply to all resources

To perform content negotiation on all resources, prepare a special bootstrap file. This is especially useful when negotiating languages., (*7)

cn.php, (*8)

require dirname(__DIR__) . '/vendor/autoload.php';

$available = [
    'Accept' => [
        'text/html' => 'prod-html-app',
        'application/hal+json' => 'prod-hal-app',
        'application/json' => 'prod-app',
        'cli' => 'cli-html-app'
    ],
    'Accept-Language' => [
        'ja' => 'ja',
        'en-US' => 'us'
    ]
];
$accept = new \BEAR\Accept\Accept($available);
[$context, $vary] = $accept($_SERVER);
//

Add a vary header in Bootstrap to enable caching when using content negotiation., (*9)

+    /* @global \BEAR\Resource\Vary $vary */
+    if (isset($vary)) {
+        $page->headers['Vary'] = $vary;
+    }
     $page->transfer($app->responder, $_SERVER);

Prepare the module of the DI setting necessary for each language., (*10)

use BEAR\Sunday\Module\Constant\NamedModule;

class JaModule extends AbstractModule
{
    /**
     * {@inheritdoc}
     */
    protected function configure()
    {
        $text = ['greeting' => 'こんにちは'];
        $this->install(new NamedModule($text));
    }
}

The Versions

10/08 2017

1.x-dev

1.9999999.9999999.9999999-dev

Provides content-negotiation using Accept* headers for BEAR.Sunday

  Sources   Download

MIT

The Requires

 

The Development Requires

accept content negotiation

10/08 2017

0.1.0

0.1.0.0

Provides content-negotiation using Accept* headers for BEAR.Sunday

  Sources   Download

MIT

The Requires

 

The Development Requires

accept content negotiation