for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
/*
* This file is part of the LightSAML-Core package.
*
* (c) Milos Tomic <[email protected]>
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace LightSaml\Resolver\Credential;
use LightSaml\Credential\CredentialInterface;
use LightSaml\Credential\Criteria\AlgorithmCriteria;
use LightSaml\Criteria\CriteriaSet;
class AlgorithmFilterResolver extends AbstractQueryableResolver
{
/**
* @param CredentialInterface[] $arrCredentials
* @return CredentialInterface[]
public function resolve(CriteriaSet $criteriaSet, array $arrCredentials = [])
if (false == $criteriaSet->has(AlgorithmCriteria::class)) {
===
When comparing two booleans, it is generally considered safer to use the strict comparison operator.
return $arrCredentials;
}
$result = [];
foreach ($criteriaSet->get(AlgorithmCriteria::class) as $criteria) {
/* @var AlgorithmCriteria $criteria */
foreach ($arrCredentials as $credential) {
if (($credential->getPrivateKey() && $credential->getPrivateKey()->getAlgorith() == $criteria->getAlgorithm()) ||
($credential->getPublicKey() && $credential->getPublicKey()->getAlgorith() == $criteria->getAlgorithm())
) {
$result[] = $credential;
return $result;
When comparing two booleans, it is generally considered safer to use the strict comparison operator.