org.xipki.security.pkcs11.P11MacContentSignerBuilder Maven / Gradle / Ivy
/*
*
* Copyright (c) 2013 - 2020 Lijun Liao
*
* 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.xipki.security.pkcs11;
import static org.xipki.util.Args.notNull;
import static org.xipki.util.Args.positive;
import java.security.NoSuchAlgorithmException;
import java.util.ArrayList;
import java.util.List;
import org.bouncycastle.asn1.x509.AlgorithmIdentifier;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.xipki.security.ConcurrentContentSigner;
import org.xipki.security.DfltConcurrentContentSigner;
import org.xipki.security.XiContentSigner;
import org.xipki.security.XiSecurityException;
import org.xipki.util.LogUtil;
import iaik.pkcs.pkcs11.wrapper.PKCS11Constants;
/**
* Builder to create {@link ConcurrentContentSigner} for PKCS#11 token.
*
* @author Lijun Liao
* @since 2.2.0
*/
public class P11MacContentSignerBuilder {
private static final Logger LOG = LoggerFactory.getLogger(P11MacContentSignerBuilder.class);
private final P11CryptService cryptService;
private final P11IdentityId identityId;
public P11MacContentSignerBuilder(P11CryptService cryptService, P11IdentityId identityId) {
this.cryptService = notNull(cryptService, "cryptService");
this.identityId = notNull(identityId, "identityId");
} // constructor
public ConcurrentContentSigner createSigner(AlgorithmIdentifier signatureAlgId, int parallelism)
throws XiSecurityException, P11TokenException {
positive(parallelism, "parallelism");
List signers = new ArrayList<>(parallelism);
for (int i = 0; i < parallelism; i++) {
XiContentSigner signer = new P11ContentSigner.Mac(cryptService, identityId, signatureAlgId);
signers.add(signer);
} // end for
final boolean mac = true;
DfltConcurrentContentSigner concurrentSigner;
try {
concurrentSigner = new DfltConcurrentContentSigner(mac, signers, null);
} catch (NoSuchAlgorithmException ex) {
throw new XiSecurityException(ex.getMessage(), ex);
}
try {
byte[] sha1HashOfKey = cryptService.getIdentity(identityId).digestSecretKey(
PKCS11Constants.CKM_SHA_1);
concurrentSigner.setSha1DigestOfMacKey(sha1HashOfKey);
} catch (P11TokenException | XiSecurityException ex) {
LogUtil.warn(LOG, ex, "could not compute the digest of secret key " + identityId);
}
return concurrentSigner;
} // method createSigner
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy