/*
 * Copyright (c) 2017 Red Hat, Inc. and/or its affiliates.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */

package io.vertx.core.net;

import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.net.impl.SelfSignedCertificateImpl;

A self-signed certificate helper for testing and development purposes.

While it helps for testing and development, it should never ever be used in production settings.

Author:Julien Ponge
/** * A self-signed certificate helper for testing and development purposes. * <p> * While it helps for testing and development, it should never ever be used in production settings. * * @author <a href="https://julien.ponge.org/">Julien Ponge</a> */
@VertxGen public interface SelfSignedCertificate {
Provides the KeyCertOptions RSA private key file in PEM format corresponding to the privateKeyPath()
Returns:a PemKeyCertOptions based on the generated certificate.
/** * Provides the {@link KeyCertOptions} RSA private key file in PEM format corresponding to the {@link #privateKeyPath()} * * @return a {@link PemKeyCertOptions} based on the generated certificate. */
PemKeyCertOptions keyCertOptions();
Provides the TrustOptions X.509 certificate file in PEM format corresponding to the certificatePath()
Returns:a PemTrustOptions based on the generated certificate.
/** * Provides the {@link TrustOptions} X.509 certificate file in PEM format corresponding to the {@link #certificatePath()} * * @return a {@link PemTrustOptions} based on the generated certificate. */
PemTrustOptions trustOptions();
Filesystem path to the RSA private key file in PEM format
Returns:the absolute path to the private key.
/** * Filesystem path to the RSA private key file in PEM format * * @return the absolute path to the private key. */
String privateKeyPath();
Filesystem path to the X.509 certificate file in PEM format .
Returns:the absolute path to the certificate.
/** * Filesystem path to the X.509 certificate file in PEM format . * * @return the absolute path to the certificate. */
String certificatePath();
Delete the private key and certificate files.
/** * Delete the private key and certificate files. */
void delete();
Create a new SelfSignedCertificate instance.
Returns:a new instance.
/** * Create a new {@code SelfSignedCertificate} instance. * * @return a new instance. */
static SelfSignedCertificate create() { return new SelfSignedCertificateImpl(); }
Create a new SelfSignedCertificate instance with a fully-qualified domain name,
Params:
  • fqdn – a fully qualified domain name.
Returns:a new instance.
/** * Create a new {@code SelfSignedCertificate} instance with a fully-qualified domain name, * * @param fqdn a fully qualified domain name. * @return a new instance. */
static SelfSignedCertificate create(String fqdn) { return new SelfSignedCertificateImpl(fqdn); } }