//* Licensed Materials - Property of * //* IBM * //* Miracle A/S * //* Alexandra Instituttet A/S * //* * //* eu.abc4trust.pabce.1.34 * //* * //* (C) Copyright IBM Corp. 2014. All Rights Reserved. * //* (C) Copyright Miracle A/S, Denmark. 2014. All Rights Reserved. * //* (C) Copyright Alexandra Instituttet A/S, Denmark. 2014. All * //* Rights Reserved. * //* US Government Users Restricted Rights - Use, duplication or * //* disclosure restricted by GSA ADP Schedule Contract with IBM Corp. * //* * //* This file is 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 eu.abc4trust.abce.internal.user.policyCredentialMatcher; import eu.abc4trust.abce.internal.user.credentialManager.CredentialManagerException; import eu.abc4trust.cryptoEngine.CryptoEngineException; import eu.abc4trust.keyManager.KeyManagerException; import eu.abc4trust.returnTypes.UiIssuanceArguments; import eu.abc4trust.returnTypes.UiIssuanceReturn; import eu.abc4trust.returnTypes.UiPresentationArguments; import eu.abc4trust.returnTypes.UiPresentationReturn; import eu.abc4trust.xml.IssuanceMessage; import eu.abc4trust.xml.PresentationPolicyAlternatives; import eu.abc4trust.xml.PresentationToken; public interface PolicyCredentialMatcher { /** * This method performs steps 0-3 of PolicyCredentialMatcher.createToken(p) and returns true if * and only if the list of possible presentation tokens is non-empty. Note that this does not * include any revocation checks, i.e., the response of this method is more an indication whether * a presentation policy can, in general, be fullfilled or not. * * @param p * @return * @throws CredentialManagerException * @throws KeyManagerException * @throws CryptoEngineException */ public boolean canBeSatisfied(String username, PresentationPolicyAlternatives p) throws CredentialManagerException, KeyManagerException, CryptoEngineException; public IssuanceMessage createIssuanceToken(String username, UiIssuanceReturn uir) throws CryptoEngineException; public UiIssuanceArguments createIssuanceToken(String username, IssuanceMessage im) throws CredentialManagerException, KeyManagerException, CryptoEngineException; public PresentationToken createPresentationToken(String username, UiPresentationReturn upr) throws CryptoEngineException; public UiPresentationArguments createPresentationToken(String username, PresentationPolicyAlternatives p) throws CredentialManagerException, KeyManagerException, CryptoEngineException; }