//* Licensed Materials - Property of * //* IBM * //* Alexandra Instituttet A/S * //* * //* eu.abc4trust.pabce.1.34 * //* * //* (C) Copyright IBM Corp. 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.smartcardManager; import java.math.BigInteger; import java.net.URI; import java.util.HashMap; import java.util.Map; import java.util.TreeMap; import com.ibm.zurich.idmx.interfaces.device.DeviceProofCommitment; public class DeviceProofCommitmentImpl implements DeviceProofCommitment{ private final Map<URI, Map<URI, BigInteger>> credCom; private final Map<URI, BigInteger> pkCom; private final Map<URI, Map<URI, BigInteger>> sepCom; private final TreeMap<URI, byte[]> zkNonceCommitments; private final DeviceProofSpecificationImpl spec; @Override public BigInteger getCommitmentForCredential(URI deviceUid, URI credentialUri) { return credCom.get(deviceUid).get(credentialUri); } @Override public BigInteger getCommitmentForScopeExclusivePseudonym(URI deviceUid, URI scope) { return sepCom.get(deviceUid).get(scope); } @Override public BigInteger getCommitmentForPublicKey(URI deviceUid) { return pkCom.get(deviceUid); } DeviceProofCommitmentImpl(DeviceProofSpecificationImpl spec) { credCom = new HashMap<URI, Map<URI,BigInteger>>(); pkCom = new HashMap<URI, BigInteger>(); sepCom = new HashMap<URI, Map<URI,BigInteger>>(); zkNonceCommitments = new TreeMap<URI, byte[]>(); this.spec = spec; } public void setCommitmentForCredential(URI smartcardUri, URI credUri, BigInteger value) { if(! credCom.containsKey(smartcardUri)) { credCom.put(smartcardUri, new HashMap<URI, BigInteger>()); } credCom.get(smartcardUri).put(credUri, value); } public void setCommitmentForPublicKey(URI smartcardUri, BigInteger value) { pkCom.put(smartcardUri, value); } public void setCommitmentForScopeExclusivePseudonym(URI smartcardUri, URI scope, BigInteger value) { if(! sepCom.containsKey(smartcardUri)) { sepCom.put(smartcardUri, new HashMap<URI, BigInteger>()); } sepCom.get(smartcardUri).put(scope, value); } public DeviceProofSpecificationImpl getProofSpec() { return spec; } }