org.kontalk.xmppserver.x509.SubjectPGPPublicKeyInfo.java Source code

Java tutorial

Introduction

Here is the source code for org.kontalk.xmppserver.x509.SubjectPGPPublicKeyInfo.java

Source

/*
 * Kontalk XMPP Tigase extension
 * Copyright (C) 2017 Kontalk Devteam <devteam@kontalk.org>
    
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
    
 * This program 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 General Public License for more details.
    
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

package org.kontalk.xmppserver.x509;

import org.bouncycastle.asn1.*;

import java.io.ByteArrayInputStream;
import java.io.IOException;

/**
 * A custom X.509 extension for a PGP public key.
 * @author Daniele Ricci
 */
public class SubjectPGPPublicKeyInfo extends ASN1Object {

    // based on UUID 24e844a0-6cbc-11e3-8997-0002a5d5c51b
    public static final ASN1ObjectIdentifier OID = new ASN1ObjectIdentifier(
            "2.25.49058212633447845622587297037800555803");

    private DERBitString keyData;

    public SubjectPGPPublicKeyInfo(ASN1Encodable publicKey) throws IOException {
        keyData = new DERBitString(publicKey);
    }

    public SubjectPGPPublicKeyInfo(byte[] publicKey) {
        keyData = new DERBitString(publicKey);
    }

    private SubjectPGPPublicKeyInfo(DERBitString bitstring) {
        keyData = bitstring;
    }

    public DERBitString getPublicKeyData() {
        return keyData;
    }

    @Override
    public ASN1Primitive toASN1Primitive() {
        return keyData;
    }

    public static SubjectPGPPublicKeyInfo getInstance(byte[] bytes) throws IOException {
        ASN1Primitive obj = toDERObject(bytes);
        if (obj instanceof DEROctetString) {
            obj = toDERObject(((DEROctetString) obj).getOctets());
            if (obj instanceof DERBitString) {
                return getInstance((DERBitString) obj);
            }
        }

        return null;
    }

    public static SubjectPGPPublicKeyInfo getInstance(DERBitString bitstring) throws IOException {
        return new SubjectPGPPublicKeyInfo(bitstring);
    }

    private static ASN1Primitive toDERObject(byte[] data) throws IOException {
        ASN1InputStream asnInputStream = null;
        try {
            ByteArrayInputStream inStream = new ByteArrayInputStream(data);
            asnInputStream = new ASN1InputStream(inStream);

            return asnInputStream.readObject();
        } finally {
            try {
                asnInputStream.close();
            } catch (Exception e) {
            }
        }
    }

}