blob: 62d5550d19d1b43486c561777efeddf172f5cd46 [file] [log] [blame]
// Copyright 2017 Google Inc.
//
// 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 com.google.crypto.tink.signature;
import com.google.crypto.tink.Catalogue;
import com.google.crypto.tink.KeyManager;
import com.google.crypto.tink.PrimitiveWrapper;
import com.google.crypto.tink.PublicKeySign;
import java.security.GeneralSecurityException;
/** A catalogue of {@link PublicKeySign} key managers. */
class PublicKeySignCatalogue implements Catalogue<PublicKeySign> {
public PublicKeySignCatalogue() {}
/**
* @return a KeyManager for the given {@code typeUrl}, {@code primitiveName} and version at least
* {@code minVersion} (if it exists in the catalogue).
*/
@Override
public KeyManager<PublicKeySign> getKeyManager(
String typeUrl, String primitiveName, int minVersion) throws GeneralSecurityException {
KeyManager<PublicKeySign> keyManager;
switch (primitiveName.toLowerCase()) {
case "publickeysign":
keyManager = publicKeySignKeyManager(typeUrl);
break;
default:
throw new GeneralSecurityException(
String.format("No support for primitive '%s'.", primitiveName));
}
if (keyManager.getVersion() < minVersion) {
throw new GeneralSecurityException(
String.format(
"No key manager for key type '%s' with version at least %d.", typeUrl, minVersion));
}
return keyManager;
}
private KeyManager<PublicKeySign> publicKeySignKeyManager(String typeUrl)
throws GeneralSecurityException {
switch (typeUrl) {
case EcdsaSignKeyManager.TYPE_URL:
return new EcdsaSignKeyManager();
case Ed25519PrivateKeyManager.TYPE_URL:
return new Ed25519PrivateKeyManager();
case RsaSsaPkcs1SignKeyManager.TYPE_URL:
return new RsaSsaPkcs1SignKeyManager();
case RsaSsaPssSignKeyManager.TYPE_URL:
return new RsaSsaPssSignKeyManager();
default:
throw new GeneralSecurityException(
String.format("No support for primitive 'PublicKeySign' with key type '%s'.", typeUrl));
}
}
@Override
public PrimitiveWrapper<PublicKeySign> getPrimitiveWrapper() {
return new PublicKeySignWrapper();
}
}