All Downloads are FREE. Search and download functionalities are using the official Maven repository.

be.atbash.ee.security.octopus.nimbus.util.X509CertChainUtils Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017-2022 Rudy De Busscher (https://www.atbash.be)
 *
 * 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 be.atbash.ee.security.octopus.nimbus.util;


import org.bouncycastle.cert.X509CertificateHolder;
import org.bouncycastle.openssl.PEMParser;

import javax.json.JsonArray;
import javax.json.JsonString;
import javax.json.JsonValue;
import java.io.File;
import java.io.IOException;
import java.io.Reader;
import java.io.StringReader;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.security.KeyStore;
import java.security.KeyStoreException;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.text.ParseException;
import java.util.LinkedList;
import java.util.List;
import java.util.UUID;


/**
 * X.509 certificate chain utilities.
 * 

* Based on code by Vladimir Dzhuvinov */ public final class X509CertChainUtils { /** * Converts the specified JSON array of strings to a list of Base64 * encoded objects. * * @param jsonArray The JSON array of string, {@code null} if not * specified. * @return The Base64 list, {@code null} if not specified. * @throws ParseException If parsing failed. */ public static List toBase64List(JsonArray jsonArray) throws ParseException { if (jsonArray == null) { return null; } List chain = new LinkedList<>(); for (int i = 0; i < jsonArray.size(); i++) { JsonValue item = jsonArray.get(i); if (item == null) { throw new ParseException("The X.509 certificate at position " + i + " must not be null", 0); } if (!item.getValueType().equals(JsonValue.ValueType.STRING)) { throw new ParseException("The X.509 certificate at position " + i + " must be encoded as a Base64 string", 0); } chain.add(new Base64Value(((JsonString) item).getString())); } return chain; } /** * Parses a X.509 certificate chain from the specified Base64-encoded * DER-encoded representation. * * @param b64List The Base64-encoded DER-encoded X.509 certificate * chain, {@code null} if not specified. * @return The X.509 certificate chain, {@code null} if not specified. * @throws ParseException If parsing failed. */ public static List parse(List b64List) throws ParseException { if (b64List == null) { return null; } List out = new LinkedList<>(); for (int i = 0; i < b64List.size(); i++) { if (b64List.get(i) == null) { continue; } // skip X509Certificate cert = X509CertUtils.parse(b64List.get(i).decode()); if (cert == null) { throw new ParseException("Invalid X.509 certificate at position " + i, 0); } out.add(cert); } return out; } /** * Parses a X.509 certificate chain from the specified PEM-encoded * representation. PEM-encoded objects that are not X.509 certificates * are ignored. * * @param pemFile The PEM-encoded X.509 certificate chain file. Must * not be {@code null}. * @return The X.509 certificate chain, empty list if no certificates * are found. * @throws IOException On I/O exception. * @throws CertificateException On a certificate exception. */ public static List parse(File pemFile) throws IOException, CertificateException { String pemString = new String(Files.readAllBytes(pemFile.toPath()), StandardCharsets.UTF_8); return parse(pemString); } /** * Parses a X.509 certificate chain from the specified PEM-encoded * representation. PEM-encoded objects that are not X.509 certificates * are ignored. * * @param pemString The PEM-encoded X.509 certificate chain. Must not * be {@code null}. * @return The X.509 certificate chain, empty list if no certificates * are found. * @throws IOException On I/O exception. * @throws CertificateException On a certificate exception. */ public static List parse(String pemString) throws IOException, CertificateException { Reader pemReader = new StringReader(pemString); PEMParser parser = new PEMParser(pemReader); List certChain = new LinkedList<>(); Object pemObject; do { pemObject = parser.readObject(); if (pemObject instanceof X509CertificateHolder) { X509CertificateHolder certHolder = (X509CertificateHolder) pemObject; byte[] derEncodedCert = certHolder.getEncoded(); certChain.add(X509CertUtils.parseWithException(derEncodedCert)); } } while (pemObject != null); return certChain; } /** * Stores a X.509 certificate chain into the specified Java trust (key) * store. The name (alias) for each certificate in the store is a * generated UUID. * * @param trustStore The trust (key) store. Must be initialised and not * {@code null}. * @param certChain The X.509 certificate chain. Must not be * {@code null}. * @throws KeyStoreException On a key store exception. */ public static List store(KeyStore trustStore, List certChain) throws KeyStoreException { List aliases = new LinkedList<>(); for (X509Certificate cert : certChain) { UUID alias = UUID.randomUUID(); trustStore.setCertificateEntry(alias.toString(), cert); aliases.add(alias); } return aliases; } /** * Prevents public instantiation. */ private X509CertChainUtils() { } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy