1Web::ID(3)            User Contributed Perl Documentation           Web::ID(3)
2
3
4

NAME

6       Web::ID - implementation of WebID (a.k.a. FOAF+SSL)
7

SYNOPSIS

9        my $webid = Web::ID->new(certificate => $pem_encoded_x509);
10        if ($webid->valid)
11        {
12          say "Authenticated as: ", $webid->uri;
13        }
14

DESCRIPTION

16       WebID is a simple authentication protocol based on TLS (Transaction
17       Layer Security, better known as Secure Socket Layer, SSL) and the
18       Semantic Web. This module provides a Perl implementation for
19       authenticating clients using WebID.
20
21       For more information see the Web::ID::FAQ document.
22
23       Bundled with this module are Plack::Middleware::Auth::WebID, a plugin
24       for Plack to perform WebID authentication on HTTPS connections; and
25       Web::ID::Certificate::Generator, a module that allows you to generate
26       WebID-enabled certificates that can be installed into web browsers.
27
28   Constructor
29       "new"
30           Standard Moose-style constructor.
31
32   Attributes
33       "certificate"
34           A Web::ID::Certificate object representing and x509 certificate,
35           though a PEM-encoded string will be coerced.
36
37           This is usually the only attribute you want to pass to the
38           constructor.  Allow the others to be built automatically.
39
40       "first_valid_san"
41           Probably fairly uninteresting. This is the first subjectAltName
42           value found in the certificate that could be successfully
43           authenticated using Web::ID. An Web::ID::SAN object.
44
45       "uri"
46           The URI associated with the first valid SAN. A URI object.
47
48           This is a URI you can use to identify the person, organisation or
49           robotic poodle holding the certificate.
50
51       "profile"
52           Data about the certificate holder. An RDF::Trine::Model object.
53           Their FOAF file (probably).
54
55       "valid"
56           Boolean.
57
58   Methods
59       "node"
60           Returns the same as "uri", but as an RDF::Trine::Node object.
61
62       get(@predicates)
63           Queries the "profile" for triples of the form:
64
65             $self->node $predicate $x .
66
67           And returns literal and URI values for $x, as strings.
68
69           $predicate should be an RDF::Trine::Node, or a string. If a string,
70           it will be expanded using RDF::Trine::NamespaceMap, so you can do
71           stuff like:
72
73             my $name   = $webid->get('foaf:name', 'rdfs:label');
74             my @mboxes = $webid->get('foaf:mbox');
75

BUGS

77       Please report any bugs to
78       <http://rt.cpan.org/Dist/Display.html?Queue=Web-ID>.
79

SEE ALSO

81       Web::ID::FAQ.
82
83       Web::ID::Certificate, Plack::Middleware::Auth::WebID.
84
85       RDF::ACL provides an access control system that complements WebID.
86
87       CGI::Auth::FOAF_SSL is the spiritual ancestor of this module though
88       they share very little code, and have quite different APIs.
89
90       General WebID information: <http://webid.info/>,
91       <http://www.w3.org/wiki/WebID>,
92       <http://www.w3.org/2005/Incubator/webid/spec/>,
93       <http://lists.foaf-project.org/mailman/listinfo/foaf-protocols>.
94
95       Mailing list for general Perl RDF/SemWeb discussion and support:
96       <http://www.perlrdf.org/>.
97

AUTHOR

99       Toby Inkster <tobyink@cpan.org>.
100

THANKS

102       Thanks to Kjetil Kjernsmo (cpan:KJETILK) for persuading me to port my
103       old CGI-specific implementaton of this to Plack.
104
105       Thanks Kjetil Kjernsmo (again), Florian Ragwitz (cpan:FLORA), and Jonas
106       Smedegaard for help with testing and advice on dependencies.
107
108       Thanks to Henry Story, Melvin Carvalho, Simon Reinhardt, Bruno
109       Harbulot, Ian Jacobi and many others for developing WebID from a poorly
110       thought out idea to a clever, yet simple and practical authentication
111       protocol.
112
113       Thanks to Gregory Williams (cpan:GWILLIAMS), Tatsuhiko Miyagawa
114       (cpan:MIYAGAWA) and the Moose Cabal for providing really good platforms
115       (RDF::Trine, Plack and Moose respectively) to build this on.
116
118       This software is copyright (c) 2012 by Toby Inkster.
119
120       This is free software; you can redistribute it and/or modify it under
121       the same terms as the Perl 5 programming language system itself.
122

DISCLAIMER OF WARRANTIES

124       THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
125       WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
126       MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
127
128
129
130perl v5.36.0                      2023-01-20                        Web::ID(3)
Impressum