2022-03-01 15:53:24 +01:00
|
|
|
// SPDX-FileCopyrightText: 2022 Paul Schaub <vanitasvitae@fsfe.org>
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
|
|
package pgp.cert_d.cli.commands;
|
|
|
|
|
|
|
|
import org.bouncycastle.openpgp.PGPException;
|
|
|
|
import org.bouncycastle.openpgp.PGPPublicKeyRing;
|
|
|
|
import org.bouncycastle.openpgp.PGPPublicKeyRingCollection;
|
|
|
|
import org.pgpainless.PGPainless;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
2022-08-12 15:43:22 +02:00
|
|
|
import org.pgpainless.certificate_store.MergeCallbacks;
|
2022-03-01 15:53:24 +01:00
|
|
|
import pgp.cert_d.cli.PGPCertDCli;
|
2022-08-12 15:04:54 +02:00
|
|
|
import pgp.certificate_store.certificate.Certificate;
|
|
|
|
import pgp.certificate_store.exception.BadDataException;
|
2022-03-01 15:53:24 +01:00
|
|
|
import picocli.CommandLine;
|
|
|
|
|
|
|
|
import java.io.ByteArrayInputStream;
|
|
|
|
import java.io.IOException;
|
|
|
|
|
2022-07-04 13:05:32 +02:00
|
|
|
@CommandLine.Command(name = "import",
|
2022-08-04 13:46:36 +02:00
|
|
|
resourceBundle = "msg_import")
|
2022-07-04 13:05:32 +02:00
|
|
|
public class Import implements Runnable {
|
2022-03-01 15:53:24 +01:00
|
|
|
|
2022-07-04 13:05:32 +02:00
|
|
|
private static final Logger LOGGER = LoggerFactory.getLogger(Import.class);
|
2022-03-01 15:53:24 +01:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
try {
|
|
|
|
PGPPublicKeyRingCollection certificates = PGPainless.readKeyRing().publicKeyRingCollection(System.in);
|
|
|
|
for (PGPPublicKeyRing cert : certificates) {
|
|
|
|
ByteArrayInputStream certIn = new ByteArrayInputStream(cert.getEncoded());
|
|
|
|
Certificate certificate = PGPCertDCli.getCertificateDirectory()
|
2022-08-09 18:34:42 +02:00
|
|
|
.insert(certIn, MergeCallbacks.mergeCertificates());
|
2022-03-01 15:53:24 +01:00
|
|
|
}
|
|
|
|
} catch (IOException e) {
|
|
|
|
LOGGER.error("IO-Error.", e);
|
|
|
|
System.exit(-1);
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
LOGGER.error("Thread interrupted.", e);
|
|
|
|
System.exit(-1);
|
|
|
|
} catch (BadDataException e) {
|
|
|
|
LOGGER.error("Certificate contains bad data.", e);
|
|
|
|
System.exit(-1);
|
|
|
|
} catch (PGPException e) {
|
|
|
|
LOGGER.error("PGP Exception.", e);
|
|
|
|
System.exit(-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|