2017 © Pedro Peláez
 

library uri-template

PHP URI Template (RFC 6570) supports both expansion & extraction

image

rize/uri-template

PHP URI Template (RFC 6570) supports both expansion & extraction

  • Wednesday, June 14, 2017
  • by rezigned
  • Repository
  • 10 Watchers
  • 164 Stars
  • 1,935,735 Installations
  • PHP
  • 17 Dependents
  • 0 Suggesters
  • 5 Forks
  • 1 Open issues
  • 14 Versions
  • 22 % Grown

The README.md

PHP URI Template

This is a URI Template implementation in PHP based on RFC 6570 URI Template. In addition to URI expansion, it also supports URI extraction (used by Google Cloud Core and Google Cloud Client Library)., (*1)

CI Total Downloads Latest Stable Version PHP Version Require, (*2)

[!NOTE], (*3)

Due to the deprecation of implictly nullable parameter types in PHP 8.4, we must introduce breaking change by adding explicit nullable types (?T) which requires PHP 7.1+., (*4)

As a result, version 0.4.0 and later will no longer support PHP versions below 8.1., (*5)

Usage

Expansion

A very simple usage (string expansion)., (*6)

<?php

use Rize\UriTemplate;

$uri = new UriTemplate();
$uri->expand('/{username}/profile', ['username' => 'john']);

>> '/john/profile'

Rize\UriTemplate supports all Expression Types and Levels specified by RFC6570., (*7)

<?php

use Rize\UriTemplate;

$uri = new UriTemplate();
$uri->expand('/search/{term:1}/{term}/{?q*,limit}', [
    'term'  => 'john',
    'q'     => ['a', 'b'],
    'limit' => 10,
])

>> '/search/j/john/?q=a&q=b&limit=10'

/ Path segment expansion

<?php

use Rize\UriTemplate;

$uri = new UriTemplate();
$uri->expand('http://{host}{/segments*}/{file}{.extensions*}', [
    'host'       => 'www.host.com',
    'segments'   => ['path', 'to', 'a'],
    'file'       => 'file',
    'extensions' => ['x', 'y'],
]);

>> 'http://www.host.com/path/to/a/file.x.y'

Rize\UriTemplate accepts base-uri as a 1st argument and default params as a 2nd argument. This is very useful when you're working with API endpoint., (*8)

Take a look at real world example., (*9)

<?php

use Rize\UriTemplate;

$uri = new UriTemplate('https://api.twitter.com/{version}', ['version' => 1.1]);
$uri->expand('/statuses/show/{id}.json', ['id' => '210462857140252672']);

>> https://api.twitter.com/1.1/statuses/show/210462857140252672.json

Extraction

It also supports URI Extraction (extract all variables from URI). Let's take a look at the example., (*10)

<?php

use Rize\UriTemplate;

$uri = new UriTemplate('https://api.twitter.com/{version}', ['version' => 1.1]);

$params = $uri->extract('/search/{term:1}/{term}/{?q*,limit}', '/search/j/john/?q=a&q=b&limit=10');

>> print_r($params);
(
    [term:1] => j
    [term] => john
    [q] => Array
        (
            [0] => a
            [1] => b
        )

    [limit] => 10
)

Note that in the example above, result returned by extract method has an extra keys named term:1 for prefix modifier. This key was added just for our convenience to access prefix data., (*11)

strict mode

<?php

use Rize\UriTemplate;

$uri = new UriTemplate();
$uri->extract($template, $uri, $strict = false)

Normally extract method will try to extract vars from a uri even if it's partially matched. For example, (*12)

<?php

use Rize\UriTemplate;

$uri = new UriTemplate();
$params = $uri->extract('/{?a,b}', '/?a=1')

>> print_r($params);
(
    [a] => 1
    [b] => null
)

With strict mode, it will allow you to extract uri only when variables in template are fully matched with given uri., (*13)

Which is useful when you want to determine whether the given uri is matched against your template or not (in case you want to use it as routing service)., (*14)

<?php

use Rize\UriTemplate;

$uri = new UriTemplate();

// Note that variable `b` is absent in uri
$params = $uri->extract('/{?a,b}', '/?a=1', true);

>>> null

// Now we give `b` some value
$params = $uri->extract('/{?a,b}', '/?a=1&b=2', true);

>>> print_r($params)
(
  [a] => 1
  [b] => 2
)

Array modifier %

By default, RFC 6570 only has 2 types of operators : and *. This % array operator was added to the library because current spec can't handle array style query e.g. list[]=a or key[user]=john., (*15)

Example usage for % modifier, (*16)

<?php

$uri->expand('{?list%,keys%}', [
    'list' => [
        'a', 'b',
    ),
    'keys' => [
        'a' => 1,
        'b' => 2,
    ),
]);

// '?list[]=a&list[]=b&keys[a]=1&keys[b]=2'
>> '?list%5B%5D=a&list%5B%5D=b&keys%5Ba%5D=1&keys%5Bb%5D=2'

// [] get encoded to %5B%5D i.e. '?list[]=a&list[]=b&keys[a]=1&keys[b]=2'
$params = $uri->extract('{?list%,keys%}', '?list%5B%5D=a&list%5B%5D=b&keys%5Ba%5D=1&keys%5Bb%5D=2', )

>> print_r($params);
(
    [list] => Array
        (
            [0] => a
            [1] => b
        )

    [keys] => Array
        (
            [a] => 1
            [b] => 2
        )
)

Installation

Using composer, (*17)

{
    "require": {
        "rize/uri-template": "~0.3"
    }
}

Changelogs

  • 0.2.0 Add a new modifier % which allows user to use list[]=a&list[]=b query pattern.
  • 0.2.1 Add nested array support for % modifier
  • 0.2.5 Add strict mode support for extract method
  • 0.3.0 Improve code quality + RFC3986 support for extract method by @Maks3w
  • 0.3.1 Improve extract method to parse two or more adjacent variables separated by dot by @corleonis
  • 0.4.0 Fixes the deprecation of implicitly nullable parameter types introduced in PHP 8.4. This version requires PHP 8.1 or later.

Contributors

Code Contributors

This project exists thanks to all the people who contribute. [Contribute]. , (*18)

Financial Contributors

Become a financial contributor and help us sustain our community. [Contribute], (*19)

Individuals

, (*20)

Organizations

Support this project with your organization. Your logo will show up here with a link to your website. [Contribute], (*21)

, (*22)

The Versions

14/06 2017

dev-master

9999999-dev

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

14/06 2017

0.3.2

0.3.2.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

21/02 2017

0.3.1

0.3.1.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

17/04 2015

0.3.0

0.3.0.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

11/06 2014

0.2.6

0.2.6.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

09/06 2014

0.2.5

0.2.5.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

12/05 2014

0.2.3

0.2.3.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

12/05 2014

0.2.2

0.2.2.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

12/05 2014

0.2.1

0.2.1.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

09/05 2014

0.2.0

0.2.0.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

08/05 2014

0.1.3

0.1.3.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

07/05 2014

0.1.2

0.1.2.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

05/05 2014

0.1.1

0.1.1.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570

31/03 2014

0.1.0

0.1.0.0

PHP URI Template (RFC 6570) supports both expansion & extraction

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

The Development Requires

template uri rfc 6570