Justin Richer
10 years ago
3 changed files with 124 additions and 28 deletions
@ -0,0 +1,45 @@
|
||||
/******************************************************************************* |
||||
* Copyright 2015 The MITRE Corporation |
||||
* and the MIT Kerberos and Internet Trust Consortium |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*******************************************************************************/ |
||||
|
||||
package org.mitre.uma.service; |
||||
|
||||
import java.util.Collection; |
||||
|
||||
import org.mitre.uma.model.Claim; |
||||
|
||||
/** |
||||
* |
||||
* Processes claims presented during an UMA transaction. |
||||
* |
||||
* @author jricher |
||||
* |
||||
*/ |
||||
public interface ClaimsProcessingService { |
||||
|
||||
/** |
||||
* |
||||
* Determine whether or not the claims that have been supplied are |
||||
* sufficient to fulfill the requirements given by the claims that |
||||
* are required. |
||||
* |
||||
* @param claimsRequired the required claims to check against |
||||
* @param claimsSupplied the supplied claims to test |
||||
* @return the unmatched claims (if any), an empty set if the claims are satisfied, never null |
||||
*/ |
||||
public Collection<Claim> claimsAreSatisfied(Collection<Claim> claimsRequired, Collection<Claim> claimsSupplied); |
||||
|
||||
} |
@ -0,0 +1,65 @@
|
||||
/******************************************************************************* |
||||
* Copyright 2015 The MITRE Corporation |
||||
* and the MIT Kerberos and Internet Trust Consortium |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*******************************************************************************/ |
||||
|
||||
package org.mitre.uma.service; |
||||
|
||||
import java.util.Collection; |
||||
import java.util.HashSet; |
||||
|
||||
import org.mitre.uma.model.Claim; |
||||
import org.springframework.stereotype.Service; |
||||
|
||||
/** |
||||
* Tests if all the claims in the required set have a matching |
||||
* value in the supplied set. |
||||
* |
||||
* @author jricher |
||||
* |
||||
*/ |
||||
@Service("matchAllClaimsProcessor") |
||||
public class MatchAllClaimsProcessor implements ClaimsProcessingService { |
||||
|
||||
@Override |
||||
public Collection<Claim> claimsAreSatisfied(Collection<Claim> claimsRequired, Collection<Claim> claimsSupplied) { |
||||
|
||||
Collection<Claim> claimsUnmatched = new HashSet<>(claimsRequired); |
||||
|
||||
// see if each of the required claims has a counterpart in the supplied claims set
|
||||
for (Claim required : claimsRequired) { |
||||
for (Claim supplied : claimsSupplied) { |
||||
|
||||
if (required.getIssuer().containsAll(supplied.getIssuer())) { |
||||
// it's from the right issuer
|
||||
|
||||
if (required.getName().equals(supplied.getName()) && |
||||
required.getValue().equals(supplied.getValue())) { |
||||
|
||||
// the claim matched, pull it from the set
|
||||
claimsUnmatched.remove(required); |
||||
|
||||
} |
||||
|
||||
} |
||||
} |
||||
} |
||||
|
||||
// if there's anything left then the claims aren't satisfied, return the leftovers
|
||||
return claimsUnmatched; |
||||
|
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue