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

org.jruby.ext.openssl.x509store.Trust Maven / Gradle / Ivy

/***** BEGIN LICENSE BLOCK *****
 * Version: CPL 1.0/GPL 2.0/LGPL 2.1
 *
 * The contents of this file are subject to the Common Public
 * License Version 1.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.eclipse.org/legal/cpl-v10.html
 *
 * Software distributed under the License is distributed on an "AS
 * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
 * implied. See the License for the specific language governing
 * rights and limitations under the License.
 *
 * Copyright (C) 2006 Ola Bini 
 * 
 * Alternatively, the contents of this file may be used under the terms of
 * either of the GNU General Public License Version 2 or later (the "GPL"),
 * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 * in which case the provisions of the GPL or the LGPL are applicable instead
 * of those above. If you wish to allow use of your version of this file only
 * under the terms of either the GPL or the LGPL, and not to allow others to
 * use your version of this file under the terms of the CPL, indicate your
 * decision by deleting the provisions above and replace them with the notice
 * and other provisions required by the GPL or the LGPL. If you do not delete
 * the provisions above, a recipient may use your version of this file under
 * the terms of any one of the CPL, the GPL or the LGPL.
 ***** END LICENSE BLOCK *****/
package org.jruby.ext.openssl.x509store;

import java.util.ArrayList;
import java.util.List;

/**
 * c: X509_TRUST
 *
 * @author Ola Bini
 */
public class Trust {
    public static interface Checker extends Function3 {}
    public int trust;
    public int flags;
    public Checker checkTrust;
    public String name;
    public String arg1;
    public Object arg2;

    public Trust() {}

    public Trust(int t, int f, Checker ct, String n, String a1, Object a2) {
        this.trust = t;
        this.flags = f; this.checkTrust = ct;
        this.name = n; this.arg1 = a1;
        this.arg2 = a2;
    }

    /**
     * c: X509_TRUST_set_default
     */
    public static Checker setDefault(Checker trust) {
        Checker old_trust = defaultTrust;
        defaultTrust = trust;
        return old_trust;
    }

    private final static List trtable = new ArrayList();

    /**
     * c: X509_check_trust
     */
    public static int checkTrust(X509AuxCertificate x, int id, int flags) throws Exception {
        if(id == -1) {
            return 1;
        }
        int idx = getByID(id);
        if(idx == -1) {
            return defaultTrust.call(new Integer(id),x,new Integer(flags));
        }
        Trust pt = getFirst(idx);
        return pt.checkTrust.call(pt,x,new Integer(flags));
    }

    /**
     * c: X509_TRUST_get_count
     */
    public static int getCount() {
        return trtable.size() + trstandard.length;
    }

    /**
     * c: X509_TRUST_get0
     */
    public static Trust getFirst(int idx) {
        if(idx < 0) {
            return null;
        }
        if(idx < trstandard.length) {
            return trstandard[idx];
        }
        return trtable.get(idx - trstandard.length);
    }

    /**
     * c: X509_TRUST_get_by_id
     */
    public static int getByID(int id) {
        if(id >= X509Utils.X509_TRUST_MIN && id <= X509Utils.X509_TRUST_MAX) {
            return id - X509Utils.X509_TRUST_MIN;
        }
        int i = 0;
        for(Trust t : trtable) {
            if(t.trust == id) {
                return i + trstandard.length;
            }
        }
        return -1;
    }

    /**
     * c: X509_TRUST_set
     */
    public static int set(int[] t, int trust) {
        if(getByID(trust) == -1) {
            X509Error.addError(X509Utils.X509_R_INVALID_TRUST);
            return 0;
        }
        t[0] = trust;
        return 1;
    }

    /**
     * c: X509_TRUST_add
     */
    public static int add(int id, int flags, Checker ck, String name, String arg1, Object arg2) {
        int idx;
        Trust trtmp;
        flags &= ~X509Utils.X509_TRUST_DYNAMIC;
        flags |= X509Utils.X509_TRUST_DYNAMIC_NAME;
        idx = getByID(id);
        if(idx == -1) {
            trtmp = new Trust();
            trtmp.flags = X509Utils.X509_TRUST_DYNAMIC;
        } else {
            trtmp = getFirst(idx);
        }
        trtmp.name = name;
        trtmp.flags &= X509Utils.X509_TRUST_DYNAMIC;
        trtmp.flags |= flags;
        trtmp.trust = id;
        trtmp.checkTrust = ck;
        trtmp.arg1 = arg1;
        trtmp.arg2 = arg2;
        if(idx == -1) {
            trtable.add(trtmp);
        }
        return 1;
    }

    /**
     * c: X509_TRUST_cleanup
     */
    public static void cleanup() {
        trtable.clear();
    }
    
    /**
     * c: X509_TRUST_get_flags
     */
    public int getFlags() {
	return flags;
    }

    /**
     * c: X509_TRUST_get0_name
     */
    public String getName() {
	return name;
    }

    /**
     * c: X509_TRUST_get_trust
     */
    public int getTrust() {
	return trust;
    }

    /**
     * c: trust_compat
     */
    public final static Checker trustCompatibe = new Checker() {
            public int call(Object _trust, Object _x, Object _flags) throws Exception {
                //X509_TRUST trust = (X509_TRUST)_trust;
                X509AuxCertificate x = (X509AuxCertificate)_x;
                //int flags = ((Integer)_flags).intValue();

                Purpose.checkPurpose(x,-1,0);
                if(x.getIssuerX500Principal().equals(x.getSubjectX500Principal())) { // self signed
                    return X509Utils.X509_TRUST_TRUSTED;
                } else {
                    return X509Utils.X509_TRUST_UNTRUSTED;
                }
            }
        };

    /**
     * c: trust_1oidany
     */
    public final static Checker trust1OIDAny = new Checker() {
            public int call(Object _trust, Object _x, Object _flags) throws Exception {
                Trust trust = (Trust)_trust;
                X509AuxCertificate x = (X509AuxCertificate)_x;
                int flags = ((Integer)_flags).intValue();

                X509Aux ax = x.getAux();
                if(ax != null && (ax.trust.size() > 0 || ax.reject.size() > 0)) {
                    return objTrust.call(trust.arg1,x,new Integer(flags));
                }
                return trustCompatibe.call(trust,x,new Integer(flags));
            }
        };

    /**
     * c: trust_1oid
     */
    public final static Checker trust1OID = new Checker() {
            public int call(Object _trust, Object _x, Object _flags) throws Exception {
                Trust trust = (Trust)_trust;
                X509AuxCertificate x = (X509AuxCertificate)_x;
                int flags = ((Integer)_flags).intValue();

                if(x.getAux() != null) {
                    return objTrust.call(trust.arg1,x,new Integer(flags));
                }
                return X509Utils.X509_TRUST_UNTRUSTED;
            }
        };

    /**
     * c: obj_trust
     */
    public final static Checker objTrust = new Checker() {
            public int call(Object _id, Object _x, Object _flags) {
                String id = (String)_id;
                X509AuxCertificate x = (X509AuxCertificate)_x;
                //int flags = ((Integer)_flags).intValue();
                
                X509Aux ax = x.getAux();
                if(null == ax) {
                    return X509Utils.X509_TRUST_UNTRUSTED;
                }
                for(String rej : ax.reject) {
                    if(rej.equals(id)) {
                        return X509Utils.X509_TRUST_REJECTED;
                    }
                }
                for(String t : ax.trust) {
                    if(t.equals(id)) {
                        return X509Utils.X509_TRUST_TRUSTED;
                    }
                }
                return X509Utils.X509_TRUST_UNTRUSTED;
            }
        };

    /**
     * c: default_trust
     */
    public static Checker defaultTrust = objTrust;

    public final static Trust[] trstandard = new Trust[] {
        new Trust(X509Utils.X509_TRUST_COMPAT, 0, trustCompatibe, "compatible", null, null),
        new Trust(X509Utils.X509_TRUST_SSL_CLIENT, 0, trust1OIDAny, "SSL Client", "1.3.6.1.5.5.7.3.2", null),
        new Trust(X509Utils.X509_TRUST_SSL_SERVER, 0, trust1OIDAny, "SSL Server", "1.3.6.1.5.5.7.3.1", null),
        new Trust(X509Utils.X509_TRUST_EMAIL, 0, trust1OIDAny, "S/MIME email", "1.3.6.1.5.5.7.3.4", null),
        new Trust(X509Utils.X509_TRUST_OBJECT_SIGN, 0, trust1OIDAny, "Object Signer", "1.3.6.1.5.5.7.3.3", null),
        new Trust(X509Utils.X509_TRUST_OCSP_SIGN, 0, trust1OID, "OCSP responder", "1.3.6.1.5.5.7.3.9", null),
        new Trust(X509Utils.X509_TRUST_OCSP_REQUEST, 0, trust1OID, "OCSP request", "1.3.6.1.5.5.7.48.1", null)
    
    };
}// X509_TRUST




© 2015 - 2025 Weber Informatics LLC | Privacy Policy