diff --git a/modules/core/docs/authproc_statisticswithattribute.md b/modules/core/docs/authproc_statisticswithattribute.md index 53753f9dbce44e23a60ae7336ca75909aa55b254..4607c059ea5da12c6324c6130e7396aa10d34a27 100644 --- a/modules/core/docs/authproc_statisticswithattribute.md +++ b/modules/core/docs/authproc_statisticswithattribute.md @@ -12,6 +12,9 @@ Parameters `type` : The type of the statistics entry. +`skipPassive` +: A boolean indicating whether passive requests should be skipped. Defaults to `FALSE`, in which case the type tag is prefixed with 'passive-'. + Example ------- diff --git a/modules/core/lib/Auth/Process/StatisticsWithAttribute.php b/modules/core/lib/Auth/Process/StatisticsWithAttribute.php index eedf3a5903c4de8836559f6c18da7425a9d362b9..9b2cbf332a3ee263c2f61531b7c56dc38ecfec6e 100644 --- a/modules/core/lib/Auth/Process/StatisticsWithAttribute.php +++ b/modules/core/lib/Auth/Process/StatisticsWithAttribute.php @@ -16,6 +16,8 @@ class sspmod_core_Auth_Process_StatisticsWithAttribute extends SimpleSAML_Auth_P private $typeTag = 'saml20-idp-SSO'; + private $skipPassive = false; + /** * Initialize this filter. @@ -41,6 +43,10 @@ class sspmod_core_Auth_Process_StatisticsWithAttribute extends SimpleSAML_Auth_P throw new Exception('Invalid typeTag given to core:StatisticsWithAttribute filter.'); } } + + if (array_key_exists('skipPassive', $config)) { + $this->skipPassive = (bool)$config['skipPassive']; + } } @@ -56,6 +62,15 @@ class sspmod_core_Auth_Process_StatisticsWithAttribute extends SimpleSAML_Auth_P $logAttribute = 'NA'; $source = 'NA'; $dest = 'NA'; + $isPassive = ''; + + if(array_key_exists('isPassive', $state) && $state['isPassive'] === true) { + if ($this->skipPassive === true) { + // We have a passive request. Skip logging statistics + return; + } + $isPassive = 'passive-'; + } if (array_key_exists($this->attribute, $state['Attributes'])) $logAttribute = $state['Attributes'][$this->attribute][0]; if (array_key_exists('Source', $state)) { @@ -76,10 +91,10 @@ class sspmod_core_Auth_Process_StatisticsWithAttribute extends SimpleSAML_Auth_P if (!array_key_exists('PreviousSSOTimestamp', $state)) { // The user hasn't authenticated with this SP earlier in this session - SimpleSAML\Logger::stats($this->typeTag . '-first ' . $dest . ' ' . $source . ' ' . $logAttribute); + SimpleSAML\Logger::stats($isPassive . $this->typeTag . '-first ' . $dest . ' ' . $source . ' ' . $logAttribute); } - SimpleSAML\Logger::stats($this->typeTag . ' ' . $dest . ' ' . $source . ' ' . $logAttribute); + SimpleSAML\Logger::stats($isPassive . $this->typeTag . ' ' . $dest . ' ' . $source . ' ' . $logAttribute); } }