SYNOPSIS
- dacs_list_jurisdictions [m[blue]dacsoptionsm[][1]]
DESCRIPTION
The dacs_list_jurisdictions web service displays information, relative to the jurisdiction that receives the request, about its federation and other jurisdictions in that federation. Included are the federation's public encryption key and its unique instance identifier.
The FORMAT argument (see m[blue]dacs.services(8)m[][2]) determines the type of output, with the default being HTML, using the style sheet m[blue]dacs_list_jurisdictions.cssm[][3]. The various flavours of XML, a PHP format (see below), JSON, and plain text (TEXT) are supported.
One application of dacs_list_jurisdictions is to assist middleware to generate a menu of jurisdictions for user authentication. If FORMAT is PHP, a list of each jurisdiction that provides an authentication service is emitted (as text/plain, one jurisdiction per line. Each line has the format:
-
jurisdiction[]=jname&host[]=url&jname
The string jname is the DACS jurisdiction name and url is the complete URL prefix for DACS web services at the jurisdiction. For example, invoking this URL:
might return the following response:
-
jurisdiction[]=INFOCARDS&host[]=https://example.com/infocards/cgi-bin/dacs&INFOCARDS jurisdiction[]=DEMO&host[]=https://example.com/demo/cgi-bin/dacs&DEMO jurisdiction[]=TEST&host[]=https://test.example.com/cgi-bin/dacs&TEST
The m[blue]html/examples/login.phpm[][4] template demonstrates this feature. If XML output is selected, a document conforming to m[blue]dacs_list_jurisdictions.dtdm[][5] is returned.
When returned as an XML attribute, a public encryption key is a base-64 encoding of the PEM formatted key.
-
Note
This program is also available as a DACS utility, m[blue]dacslist(1)m[][6]. Because m[blue]dacs_admin(8)m[][7] provides the same functionality and more, dacs_list_jurisdictions may be removed in a future release.
Web Service Arguments
In addition to the m[blue]standard CGI argumentsm[][8], dacs_list_jurisdictions understands the following CGI arguments:
JURISDICTION
- Limit the output to the specified jurisdiction name. As a special case, if the argument does not specify a jurisdiction name, only federation-scoped information will be returned.
PUB_KEY_ONLY
- If this argument is "yes" (case insensitive) only the federation's or a jurisdiction's public key (if known) will be returned. If JURISDICTION is given and is not the empty string, that jurisdiction name is selected; if JURISDICTION is given and is the empty string, the federation is selected; and if the argument is absent, the current jurisdiction is selected. This argument currently requires FORMAT to be TEXT. A PEM [m[blue]RFC 1421m[][9], m[blue]RFC 1422m[][10], m[blue]RFC 1423m[][11], m[blue]RFC 1424m[][12]] formatted key is returned.
-
Note
In the current implementation, a jurisdiction's public key can only be provided by one of the jurisdictions configured on the same host.
FILES
m[blue]dacs_list_jurisdictions.cssm[][3]
DIAGNOSTICS
The program exits 0 if everything was fine, 1 if an error occurred.
AUTHOR
Distributed Systems Software (m[blue]www.dss.cam[][16])
COPYING
Copyright2003-2012 Distributed Systems Software. See the m[blue]LICENSEm[][17] file that accompanies the distribution for licensing information.
NOTES
- 1.
- dacsoptions
- 2.
- dacs.services(8)
- 3.
- dacs_list_jurisdictions.css
- 4.
- html/examples/login.php
- 5.
- dacs_list_jurisdictions.dtd
- 6.
- dacslist(1)
- 7.
- dacs_admin(8)
- 8.
- standard CGI arguments
- 9.
- RFC 1421
- 10.
- RFC 1422
- 11.
- RFC 1423
- 12.
- RFC 1424
- 13.
- dacs(1)
- 14.
- dacskey(1)
- 15.
- dacs.groups(5)
- 16.
- www.dss.ca
- 17.
-
LICENSE