Required:
- Python 3.6 or greater with
- PyYAML
- cryptography installed.
xmllint
, which in Ubuntu comes from thelibxml2-utils
package
This script is a simplified version of /bin/aacli.sh
to show what attributes would be returned if the given -n
principal (user) authenticated for the given -r
requester (service provider).
Example:
utils/attributes.py -n jsmith -r https://sp.example.edu
The notable differences from the Shibboleth-supplied script are its defaults:
- Uses the IdP’s hostname instead of
localhost
– can be overridden inconfig.yml
- Output defaults to
saml2
format (including NameID, based on the SP’s metadata) — other-f
format options aresaml1
,json
, and custom formateasy
(see below). - If
test-sp
is configured inconfig.yml
, specify requestertest
as a shortcut to testing attribute release to that SP and show its output ineasy
format.
If you specify -f easy
, the output is only attribute names and values — no XML or JSON wrapping — sorted alphabetically by name. Multivalued attributes are presented as lists within square brackets (['value1', 'value2']
).
If you’re verifying attributes for a DynamicHTTPMetadataProvider
or FileBackedHTTPMetadataProvider
, you may need a local copy of its metadata.
TODO: Currently easy
parses the JSON output; switch it to saml2
so it can show the NameID also.
Before running this script, make a copy of config-default.yml
named config.yml
and edit any settings that need to be changed for your installation.
This script runs three checks against the configuration files:
First, if you have xmllint
installed, the script will validate all .xml
files in conf/
and metadata/
. Failure in any file raises an exception and halts the script.
It then extracts three sets of files from conf/services.xml
: metadata resolvers, attribute filters, and attribute resolvers. In all cases it excludes those with /system/
in their path.
Second, it compares the contents of the metadata providers file(s) with the contents of the metadata/
directory to make sure all required files exist, and identify any extraneous metadata files.
-
Metadata files are examined to make sure they have not exceeded their
validUntil
attribute (if they have one) and that any SSL certificates in the file have not expired. -
Metadata files that exist as the result of a
FileBackedHTTPMetadataProvider
are checked if present but not required. -
Use the
metadata_require
andmetadata_ignore
keys inconfig.yml
to modify the rules of which files are checked.
Third, it compares the attributes called for in the attribute filters with those that are resolvable using the attribute resolvers to make sure all needed attributes are accounted for, and identify any that are resolvable but used.
Future plans include validating the id
attributes in conf/metadata-providers.xml
(they should match the metadata filenames themselves), comparing EntityIDs from metadata with conf/attribute-filter.xml
, and a verbose output that includes more diagnostics and warnings.
This script scans one or more idp-process.log
files to see details about which service providers have received attributes about which users from the IdP.
In both cases, the default file to analyze is the current (live) log file, as it would be named on the idpv4 servers: /var/log/tomcat9/access.log
and /opt/shibboleth-idp/logs/idp-process.log
. Use -f
to specify a different filename.
Multiple filenames are allowed (separate by spaces), wildcards are allowed, and filenames that end in .gz
can be processed without unzipping them.
Example
To get every SP that has used this IdP for authentication over the entire logs/
directory:
./logscan.py sp -f /opt/shibboleth-idp/logs/idp-process*
-n [username ...]
filters the logs for one or more usernames, and shows the SPs each of those users connected to, and how many times.
-r [entity_id ...]
filters the logs for one or more SP entity ids, and shows the users who connected to each of those SPs, and how many times.
-n [username] -r [entity_id]
filters the logs for both usernames and SP entity ids, and provides a detail view with date and IP address for each instance.
The subcommand loop
, which scanned webserver logs for the looping behavior we saw in late 2020, was removed in commit #bf21dda, which left subcommand sp
as the only operation. It was simplified to remove the IdP version option in commit #0a61bde, and then removed as a subcommand in commit #6beab69. A final round of code cleanup in commit #b8250c8 renamed the script from logcheck.py
and removed a few more remnants of the old code.