Skip to content
forked from pear/XML_XRD

PHP library to parse and generate "Extensible Resource Descriptor (XRD) Version 1.0" files

Notifications You must be signed in to change notification settings

someonewithpc/XRD

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

73 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

XRD

PHP library to parse and generate Extensible Resource Descriptor (XRD) Version 1.0 files. It supports loading and saving XML (XRD) and JSON (JRD) markup.

XRD and JRD files are used for .well-known/host-meta files as standardized in RFC 6415: Web Host Metadata.

Webfinger, based on JRD, can be used to discover information about users by just their e-mail address, e.g. their OpenID provider URL.

The XRD format supercedes the XRDS format defined in XRI 2.0, which is used in the Yadis communications protocol.

This is a modern PHP version of https://github.com/pear/XML_XRD

<?php
use XRD\Document;
use XRD\XRDException;

$xrd = new Document;
try {
    $xrd->loadFile('/path/to/my.xrd', 'xml');
} catch (XRDException $e) {
    die('Loading XRD file failed: '  . $e->getMessage());
}
<?php
$myxrd = <<<XRD
<?xml version="1.0"?>
<XRD>
 ...
XRD;

use XRD\Document;
$xrd = new Document;
try {
    $xrd->loadString($myxrd, 'xml');
} catch (XRDException $e) {
    die('Loading XRD string failed: '  . $e->getMessage());
}

Check if the XRD file really describes the resource/URL that we requested the XRD for:

<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
if (!$xrd->describes('http://example.org/')) {
    die('XRD document is not the correct one for http://example.org/');
}

The <subject> and all <alias> tags are checked.

<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
foreach ($xrd as $link) {
    echo $link->rel . ': ' . $link->href . "\n";
}

Returns the first link that has the given relation:

<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
$idpLink = $xrd->get('lrdd');
echo $idpLink->rel . ': ' . $idpLink->href . "\n";

If no link with the given type is found, the first link with the correct relation and an empty type will be returned:

<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
$link = $xrd->get('lrdd', 'application/xrd+xml');
echo $link->rel . ': ' . $link->href . "\n";

The relation and the type both need to match exactly:

<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
$link = $xrd->get('lrdd', 'application/xrd+xml', false);
echo $link->rel . ': ' . $link->href . "\n";
<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
foreach ($xrd->getAll('lrdd') as $link) {
    echo $link->rel . ': ' . $link->href . "\n";
}
<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
if (isset($xrd['http://spec.example.net/type/person'])) {
    echo $xrd['http://spec.example.net/type/person'] . "\n";
}
<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
foreach ($xrd->getProperties() as $property) {
    echo $property->type . ': ' . $property->value . "\n";
}
<?php
use XRD\Document;
$xrd = new Document;
$xrd->loadFile('http://example.org/.well-known/host-meta');
foreach ($xrd->getProperties('http://spec.example.net/type/person') as $property) {
    echo $property->type . ': ' . $property->value . "\n";
}
<?php
$link = $xrd->get('http://specs.openid.net/auth/2.0/provider');

$title = $link->getTitle('de');
$url   = $link->href;
$urlTemplate = $link->template;
$mimetype    = $link->type;

Works just like properties in the XRD document:

<?php
$link = $xrd->get('http://specs.openid.net/auth/2.0/provider');
$prop = $link['foo'];

As described by RFC 6415:

<?php
use XRD\Document;
use XRD\Element\Link;

$xrd = new Document;
$x->subject = 'example.org';
$x->aliases[] = 'example.com';
$x->links[] = new Link(
    'lrdd', 'http://example.org/gen-lrdd.php?a={uri}',
    'application/xrd+xml', true
);
echo $x->to('xml');
?>

If you want a JSON file for JRD:

echo $x->to('json');
<?php
use XRD\Document;
use XRD\Element\Link;

$xrd = new Document();
$x->subject = '[email protected]';

//add link to the user's OpenID
$x->links[] = new Link(
    'http://specs.openid.net/auth/2.0/provider',
    'http://id.example.org/user'
);
//add link to user's home page
$x->links[] = new Link(
    'http://xmlns.com/foaf/0.1/homepage',
    'http://example.org/~user/'
);

echo $x->to('jrd');
?>

When loading a file, exceptions of type XML_XRD_Exception may be thrown. All other parts of the code do not throw exceptions but fail gracefully by returning null, e.g. when a property does not exist.

Using loadFile() may result in PHP warnings like:

Warning: simplexml_load_file(https://example.org/) failed to open stream: Connection refused

This cannot be prevented properly, so you either have to silence it with @ or fetch the file manually and use loadString().

  • XML signature verification
  • (very optional) XRDS (multiple XRD)?

About

PHP library to parse and generate "Extensible Resource Descriptor (XRD) Version 1.0" files

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 100.0%