[Freeswitch-svn] [commit] r7756 - freeswitch/trunk/src/mod/languages/mod_spidermonkey_rsa
Freeswitch SVN
mikej at freeswitch.org
Wed Feb 27 12:30:38 EST 2008
Author: mikej
Date: Wed Feb 27 12:30:38 2008
New Revision: 7756
Added:
freeswitch/trunk/src/mod/languages/mod_spidermonkey_rsa/
freeswitch/trunk/src/mod/languages/mod_spidermonkey_rsa/mod_spidermonkey_rsa.c
Log:
MODLANG-50, add spidermonkey module for some rsa functions from Daniel Swarbrick
Added: freeswitch/trunk/src/mod/languages/mod_spidermonkey_rsa/mod_spidermonkey_rsa.c
==============================================================================
--- (empty file)
+++ freeswitch/trunk/src/mod/languages/mod_spidermonkey_rsa/mod_spidermonkey_rsa.c Wed Feb 27 12:30:38 2008
@@ -0,0 +1,182 @@
+/*
+ * FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
+ * Copyright (C) 2005/2006, Anthony Minessale II <anthmct at yahoo.com>
+ *
+ * Version: MPL 1.1
+ *
+ * The contents of this file are subject to the Mozilla Public License Version
+ * 1.1 (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.mozilla.org/MPL/
+ *
+ * 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.
+ *
+ * The Original Code is FreeSWITCH Modular Media Switching Software Library / Soft-Switch Application
+ *
+ * The Initial Developer of the Original Code is
+ * Anthony Minessale II <anthmct at yahoo.com>
+ * Portions created by the Initial Developer are Copyright (C)
+ * the Initial Developer. All Rights Reserved.
+ *
+ * Contributor(s):
+ *
+ * Anthony Minessale II <anthmct at yahoo.com>
+ * Daniel Swarbrick <freeswitch at pressure.net.nz>
+ *
+ *
+ * mod_spidermonkey_rsa.c -- OpenSSL RSA Javascript Module
+ *
+ */
+#include "mod_spidermonkey.h"
+
+/* OpenSSL includes */
+#include <openssl/evp.h>
+#include <openssl/x509.h>
+#include <openssl/x509v3.h>
+#include <openssl/crypto.h>
+#include <openssl/pem.h>
+#include <openssl/err.h>
+#include <openssl/conf.h>
+#include <openssl/rand.h>
+#include <openssl/ssl.h>
+#include <openssl/pkcs12.h>
+#include <openssl/rsa.h>
+
+static const char modname[] = "RSA";
+
+struct rsa_obj {
+ RSA *rsa;
+ JSContext *cx;
+ JSObject *obj;
+ JSFunction *function;
+ JSObject *user_data;
+ jsrefcount saveDepth;
+ jsval ret;
+};
+
+/* RSA Object */
+/*********************************************************************************/
+static JSBool rsa_construct(JSContext * cx, JSObject * obj, uintN argc, jsval * argv, jsval * rval)
+{
+ struct rsa_obj *ro = NULL;
+
+ ro = malloc(sizeof(*ro));
+ switch_assert(ro);
+
+ memset(ro, 0, sizeof(*ro));
+
+ ro->rsa = RSA_new();
+ if (ro->rsa == NULL) {
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "OpenSSL RSA_new() error: %s\n", ERR_error_string(ERR_get_error(), NULL));
+ }
+
+ ro->cx = cx;
+ ro->obj = obj;
+
+ JS_SetPrivate(cx, obj, ro);
+
+ return JS_TRUE;
+}
+
+static void rsa_destroy(JSContext * cx, JSObject * obj)
+{
+ struct rsa_obj *ro = JS_GetPrivate(cx, obj);
+
+ if (ro && ro->rsa) {
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Freeing RSA struct: RSA_free()\n");
+ RSA_free(ro->rsa);
+ }
+
+ switch_safe_free(ro);
+ JS_SetPrivate(cx, obj, NULL);
+}
+
+static JSBool read_rsa_pub_key(JSContext * cx, JSObject * obj, uintN argc, jsval * argv, jsval * rval)
+{
+ struct rsa_obj *ro = JS_GetPrivate(cx, obj);
+ EVP_PKEY * key = NULL;
+ BIO *bio_in;
+ char * inputstr = NULL;
+
+ if (argc < 1 || !ro) {
+ return JS_FALSE;
+ }
+
+ inputstr = JS_GetStringBytes(JS_ValueToString(cx, argv[0]));
+
+ bio_in = BIO_new_mem_buf(inputstr, sizeof(inputstr));
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "PUBKEY: %s\n", inputstr);
+ key = PEM_read_bio_PUBKEY(bio_in, NULL, NULL, NULL);
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "OpenSSL PEM_read_bio_PUBKEY: %s\n", ERR_error_string(ERR_get_error(), NULL));
+ BIO_free(bio_in);
+
+ return JS_FALSE;
+}
+
+static JSFunctionSpec rsa_methods[] = {
+ {"readRSAPublicKey", read_rsa_pub_key, 1},
+ {0}
+};
+
+
+static JSPropertySpec rsa_props[] = {
+ {0}
+};
+
+
+static JSBool rsa_getProperty(JSContext * cx, JSObject * obj, jsval id, jsval * vp)
+{
+ JSBool res = JS_TRUE;
+
+ return res;
+}
+
+JSClass rsa_class = {
+ modname, JSCLASS_HAS_PRIVATE,
+ JS_PropertyStub, JS_PropertyStub, rsa_getProperty, DEFAULT_SET_PROPERTY,
+ JS_EnumerateStub, JS_ResolveStub, JS_ConvertStub, rsa_destroy, NULL, NULL, NULL,
+ rsa_construct
+};
+
+
+switch_status_t rsa_load(JSContext * cx, JSObject * obj)
+{
+ JS_InitClass(cx, obj, NULL, &rsa_class, rsa_construct, 3, rsa_props, rsa_methods, rsa_props, rsa_methods);
+ return SWITCH_STATUS_SUCCESS;
+}
+
+
+const sm_module_interface_t rsa_module_interface = {
+ /*.name = */ modname,
+ /*.spidermonkey_load */ rsa_load,
+ /*.next */ NULL
+};
+
+SWITCH_MOD_DECLARE(switch_status_t) spidermonkey_init(const sm_module_interface_t ** module_interface)
+{
+ SSL_library_init();
+ OpenSSL_add_all_ciphers();
+ OpenSSL_add_all_digests();
+ OpenSSL_add_all_algorithms();
+
+ ERR_load_ERR_strings();
+ ERR_load_crypto_strings();
+ ERR_load_EVP_strings();
+
+ *module_interface = &rsa_module_interface;
+ return SWITCH_STATUS_SUCCESS;
+}
+
+/* For Emacs:
+ * Local Variables:
+ * mode:c
+ * indent-tabs-mode:nil
+ * tab-width:4
+ * c-basic-offset:4
+ * End:
+ * For VIM:
+ * vim:set softtabstop=4 shiftwidth=4 tabstop=4 expandtab:
+ */
More information about the Freeswitch-svn
mailing list