eu.europa.esig.dss.EncryptionAlgorithm Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dss-model Show documentation
Show all versions of dss-model Show documentation
DSS Model contains the data model representation for DSS
/**
* DSS - Digital Signature Services
* Copyright (C) 2015 European Commission, provided under the CEF programme
*
* This file is part of the "DSS - Digital Signature Services" project.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
package eu.europa.esig.dss;
import java.util.HashMap;
import java.util.Map;
/**
* Supported signature encryption algorithms.
*
*/
public enum EncryptionAlgorithm {
RSA("RSA", "1.2.840.113549.1.1.1", "RSA/ECB/PKCS1Padding"),
DSA("DSA", "1.2.840.10040.4.1", "DSA"),
ECDSA("ECDSA", "1.2.840.10045.2.1", "ECDSA"),
HMAC("HMAC", "", "");
private String name;
private String oid;
private String padding;
private static class Registry {
private static final Map OID_ALGORITHMS = registerOIDAlgorithms();
private static Map registerOIDAlgorithms() {
Map map = new HashMap();
for (EncryptionAlgorithm encryptionAlgorithm : values()) {
map.put(encryptionAlgorithm.oid, encryptionAlgorithm);
}
return map;
}
}
/**
* Returns the encryption algorithm associated to the given OID.
*
* @param oid
* @return
*/
public static EncryptionAlgorithm forOID(String oid) {
EncryptionAlgorithm algorithm = Registry.OID_ALGORITHMS.get(oid);
if (algorithm == null) {
throw new RuntimeException("Unsupported algorithm: " + oid);
}
return algorithm;
}
/**
* Returns the encryption algorithm associated to the given JCE name.
*
* @param name
* @return
*/
public static EncryptionAlgorithm forName(final String name) {
// To be checked if ECC exists also .
if ("EC".equals(name) || "ECC".equals(name)) {
return ECDSA;
}
try {
return valueOf(name);
} catch (Exception e) {
}
throw new DSSException("Unsupported algorithm: " + name);
}
/**
* Returns the encryption algorithm associated to the given JCE name.
*
* @param name
* @param defaultValue
* @return
*/
public static EncryptionAlgorithm forName(final String name, final EncryptionAlgorithm defaultValue) {
// To be checked if ECC exists also .
if ("EC".equals(name) || "ECC".equals(name)) {
return ECDSA;
}
try {
final EncryptionAlgorithm encryptionAlgorithm = valueOf(name);
return encryptionAlgorithm;
} catch (Exception e) {
return defaultValue;
}
}
private EncryptionAlgorithm(String name, String oid, String padding) {
this.name = name;
this.oid = oid;
this.padding = padding;
}
/**
* @return the name
*/
public String getName() {
return name;
}
/**
* @return the OID
*/
public String getOid() {
return oid;
}
/**
* @return the padding
*/
public String getPadding() {
return padding;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy