/***** BEGIN LICENSE BLOCK *****
* Version: EPL 1.0/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Eclipse 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/epl-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 <ola@ologix.com>
*
* 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 EPL, 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 EPL, the GPL or the LGPL.
***** END LICENSE BLOCK *****/
package org.jruby.ext.openssl;
import java.util.Map;
import org.jruby.Ruby;
import org.jruby.RubyFixnum;
import org.jruby.RubyModule;
import org.jruby.ext.openssl.x509store.X509Error;
import org.jruby.ext.openssl.x509store.X509Utils;
/**
* @author <a href="mailto:ola.bini@ki.se">Ola Bini</a>
*/
public class X509 {
public static void createX509(final Ruby runtime, final RubyModule _OpenSSL) {
final RubyModule _X509 = _OpenSSL.defineModuleUnder("X509");
X509Name.createX509Name(runtime, _X509);
X509Cert.createX509Cert(runtime, _X509);
X509Extension.createX509Extension(runtime, _X509);
X509CRL.createX509CRL(runtime, _X509);
X509Revoked.createX509Revoked(runtime, _X509);
X509Store.createX509Store(runtime, _X509);
X509Request.createRequest(runtime, _X509);
X509Attribute.createAttribute(runtime, _X509);
final RubyFixnum _1 = runtime.newFixnum(1);
final RubyFixnum _2 = runtime.newFixnum(2);
final RubyFixnum _3 = runtime.newFixnum(3);
final RubyFixnum _4 = runtime.newFixnum(4);
final RubyFixnum _5 = runtime.newFixnum(5);
final RubyFixnum _6 = runtime.newFixnum(6);
final RubyFixnum _7 = runtime.newFixnum(7);
final RubyFixnum _8 = runtime.newFixnum(8);
_X509.setConstant("V_OK",runtime.newFixnum(0));
_X509.setConstant("V_ERR_UNABLE_TO_GET_ISSUER_CERT",_2);
_X509.setConstant("V_ERR_UNABLE_TO_GET_CRL",_3);
_X509.setConstant("V_ERR_UNABLE_TO_DECRYPT_CERT_SIGNATURE",_4);
_X509.setConstant("V_ERR_UNABLE_TO_DECRYPT_CRL_SIGNATURE",_5);
_X509.setConstant("V_ERR_UNABLE_TO_DECODE_ISSUER_PUBLIC_KEY",_6);
_X509.setConstant("V_ERR_CERT_SIGNATURE_FAILURE",_7);
_X509.setConstant("V_ERR_CRL_SIGNATURE_FAILURE",_8);
_X509.setConstant("V_ERR_CERT_NOT_YET_VALID",runtime.newFixnum(9));
_X509.setConstant("V_ERR_CERT_HAS_EXPIRED",runtime.newFixnum(10));
_X509.setConstant("V_ERR_CRL_NOT_YET_VALID",runtime.newFixnum(11));
_X509.setConstant("V_ERR_CRL_HAS_EXPIRED",runtime.newFixnum(12));
_X509.setConstant("V_ERR_ERROR_IN_CERT_NOT_BEFORE_FIELD",runtime.newFixnum(13));
_X509.setConstant("V_ERR_ERROR_IN_CERT_NOT_AFTER_FIELD",runtime.newFixnum(14));
_X509.setConstant("V_ERR_ERROR_IN_CRL_LAST_UPDATE_FIELD",runtime.newFixnum(15));
_X509.setConstant("V_ERR_ERROR_IN_CRL_NEXT_UPDATE_FIELD",runtime.newFixnum(16));
_X509.setConstant("V_ERR_OUT_OF_MEM",runtime.newFixnum(17));
_X509.setConstant("V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT",runtime.newFixnum(18));
_X509.setConstant("V_ERR_SELF_SIGNED_CERT_IN_CHAIN",runtime.newFixnum(19));
_X509.setConstant("V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY",runtime.newFixnum(20));
_X509.setConstant("V_ERR_UNABLE_TO_VERIFY_LEAF_SIGNATURE",runtime.newFixnum(21));
_X509.setConstant("V_ERR_CERT_CHAIN_TOO_LONG",runtime.newFixnum(22));
_X509.setConstant("V_ERR_CERT_REVOKED",runtime.newFixnum(23));
_X509.setConstant("V_ERR_INVALID_CA",runtime.newFixnum(24));
_X509.setConstant("V_ERR_PATH_LENGTH_EXCEEDED",runtime.newFixnum(25));
_X509.setConstant("V_ERR_INVALID_PURPOSE",runtime.newFixnum(26));
_X509.setConstant("V_ERR_CERT_UNTRUSTED",runtime.newFixnum(27));
_X509.setConstant("V_ERR_CERT_REJECTED",runtime.newFixnum(28));
_X509.setConstant("V_ERR_SUBJECT_ISSUER_MISMATCH",runtime.newFixnum(29));
_X509.setConstant("V_ERR_AKID_SKID_MISMATCH",runtime.newFixnum(30));
_X509.setConstant("V_ERR_AKID_ISSUER_SERIAL_MISMATCH",runtime.newFixnum(31));
_X509.setConstant("V_ERR_KEYUSAGE_NO_CERTSIGN",runtime.newFixnum(32));
_X509.setConstant("V_ERR_APPLICATION_VERIFICATION",runtime.newFixnum(50));
_X509.setConstant("V_FLAG_CRL_CHECK",_4);
_X509.setConstant("V_FLAG_CRL_CHECK_ALL",_8);
_X509.setConstant("PURPOSE_SSL_CLIENT",_1);
_X509.setConstant("PURPOSE_SSL_SERVER",_2);
_X509.setConstant("PURPOSE_NS_SSL_SERVER",_3);
_X509.setConstant("PURPOSE_SMIME_SIGN",_4);
_X509.setConstant("PURPOSE_SMIME_ENCRYPT",_5);
_X509.setConstant("PURPOSE_CRL_SIGN",_6);
_X509.setConstant("PURPOSE_ANY",_7);
_X509.setConstant("PURPOSE_OCSP_HELPER",_8);
_X509.setConstant("TRUST_COMPAT",_1);
_X509.setConstant("TRUST_SSL_CLIENT",_2);
_X509.setConstant("TRUST_SSL_SERVER",_3);
_X509.setConstant("TRUST_EMAIL",_4);
_X509.setConstant("TRUST_OBJECT_SIGN",_5);
_X509.setConstant("TRUST_OCSP_SIGN",_6);
_X509.setConstant("TRUST_OCSP_REQUEST",_7);
// These should eventually point to correct things.
_X509.setConstant("DEFAULT_CERT_AREA", runtime.newString(X509Utils.X509_CERT_AREA));
_X509.setConstant("DEFAULT_CERT_DIR", runtime.newString(X509Utils.X509_CERT_DIR));
_X509.setConstant("DEFAULT_CERT_FILE", runtime.newString(X509Utils.X509_CERT_FILE));
_X509.setConstant("DEFAULT_CERT_DIR_ENV", runtime.newString(X509Utils.X509_CERT_DIR_EVP));
_X509.setConstant("DEFAULT_CERT_FILE_ENV", runtime.newString(X509Utils.X509_CERT_FILE_EVP));
_X509.setConstant("DEFAULT_PRIVATE_DIR", runtime.newString(X509Utils.X509_PRIVATE_DIR));
}
static RubyModule _X509(final Ruby runtime) {
return (RubyModule) runtime.getModule("OpenSSL").getConstant("X509");
}
static Map<Integer, String> getErrors() {
return X509Error.getErrors();
}
}// X509