diff --git a/modules/consent/lib/Auth/Process/Consent.php b/modules/consent/lib/Auth/Process/Consent.php index eff89c43808d3c466334d96b8365031fbffb165a..6e87ca038c143a87cd7047bb566253c1566e3f0c 100644 --- a/modules/consent/lib/Auth/Process/Consent.php +++ b/modules/consent/lib/Auth/Process/Consent.php @@ -216,19 +216,24 @@ class sspmod_consent_Auth_Process_Consent extends SimpleSAML_Auth_ProcessingFilt 'Consent: hasConsent() [' . $userId . '|' . $targetedId . '|' . $attributeSet . ']' ); - - if ($this->_store->hasConsent($userId, $targetedId, $attributeSet)) { - // Consent already given - SimpleSAML_Logger::stats('Consent: Consent found'); - return; - } - SimpleSAML_Logger::stats('Consent: Consent notfound'); + try { + if ($this->_store->hasConsent($userId, $targetedId, $attributeSet)) { + // Consent already given + SimpleSAML_Logger::stats('Consent: Consent found'); + return; + } - $state['consent:store'] = $this->_store; - $state['consent:store.userId'] = $userId; - $state['consent:store.destination'] = $targetedId; - $state['consent:store.attributeSet'] = $attributeSet; + SimpleSAML_Logger::stats('Consent: Consent notfound'); + + $state['consent:store'] = $this->_store; + $state['consent:store.userId'] = $userId; + $state['consent:store.destination'] = $targetedId; + $state['consent:store.attributeSet'] = $attributeSet; + } catch (Exception $e) { + SimpleSAML_Logger::error('Consent: Error reading from storage: ' . $e->getMessage()); + SimpleSAML_Logger::stats('Consent: Failed'); + } } else { SimpleSAML_Logger::stats('Consent: No storage'); } diff --git a/modules/consent/www/getconsent.php b/modules/consent/www/getconsent.php index 949630dfe5d60d28e32a46322c620b02689a077f..84acd064f8a3d29f4caf5f0a3f0bf84502878606 100644 --- a/modules/consent/www/getconsent.php +++ b/modules/consent/www/getconsent.php @@ -56,7 +56,11 @@ if (array_key_exists('yes', $_REQUEST)) { 'Consent - saveConsent() : [' . $userId . '|' . $targetedId . '|' . $attributeSet . ']' ); - $store->saveConsent($userId, $targetedId, $attributeSet); + try { + $store->saveConsent($userId, $targetedId, $attributeSet); + } catch (Exception $e) { + SimpleSAML_Logger::error('Consent: Error writing to storage: ' . $e->getMessage()); + } } SimpleSAML_Auth_ProcessingChain::resumeProcessing($state);