227 lines
5.9 KiB
C
227 lines
5.9 KiB
C
/* jni_wolfssl_cert_manager.c
|
|
*
|
|
* Copyright (C) 2006-2025 wolfSSL Inc.
|
|
*
|
|
* This file is part of wolfSSL.
|
|
*
|
|
* wolfSSL 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 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* wolfSSL 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, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
|
|
#ifdef WOLFSSL_USER_SETTINGS
|
|
#include <wolfssl/wolfcrypt/settings.h>
|
|
#elif !defined(__ANDROID__)
|
|
#include <wolfssl/options.h>
|
|
#endif
|
|
|
|
#include <wolfssl/ssl.h>
|
|
#include <wolfssl/error-ssl.h>
|
|
#include <com_wolfssl_wolfcrypt_WolfSSLCertManager.h>
|
|
#include <wolfcrypt_jni_error.h>
|
|
|
|
/* #define WOLFCRYPT_JNI_DEBUG_ON */
|
|
#include <wolfcrypt_jni_debug.h>
|
|
|
|
JNIEXPORT jlong JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerNew
|
|
(JNIEnv* env, jclass jcl)
|
|
{
|
|
(void)env;
|
|
(void)jcl;
|
|
|
|
return (jlong)(uintptr_t)wolfSSL_CertManagerNew();
|
|
}
|
|
|
|
JNIEXPORT void JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerFree
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr)
|
|
{
|
|
(void)env;
|
|
(void)jcl;
|
|
|
|
wolfSSL_CertManagerFree((WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr);
|
|
}
|
|
|
|
JNIEXPORT jint JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerLoadCA
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr, jstring f, jstring d)
|
|
{
|
|
#ifndef NO_FILESYSTEM
|
|
int ret;
|
|
const char* certFile = NULL;
|
|
const char* certPath = NULL;
|
|
WOLFSSL_CERT_MANAGER* cm = (WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr;
|
|
(void)jcl;
|
|
|
|
if (env == NULL || cm == NULL) {
|
|
return (jint)BAD_FUNC_ARG;
|
|
}
|
|
|
|
certFile = (*env)->GetStringUTFChars(env, f, 0);
|
|
certPath = (*env)->GetStringUTFChars(env, d, 0);
|
|
|
|
ret = wolfSSL_CertManagerLoadCA(cm, certFile, certPath);
|
|
|
|
(*env)->ReleaseStringUTFChars(env, f, certFile);
|
|
(*env)->ReleaseStringUTFChars(env, d, certPath);
|
|
|
|
return (jint)ret;
|
|
#else
|
|
(void)env;
|
|
(void)jcl;
|
|
(void)cmPtr;
|
|
(void)f;
|
|
(void)d;
|
|
return NOT_COMPILED_IN;
|
|
#endif
|
|
}
|
|
|
|
JNIEXPORT jint JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerLoadCABuffer
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr, jbyteArray in, jlong sz, jint format)
|
|
{
|
|
int ret = 0;
|
|
word32 buffSz = 0;
|
|
byte* buff = NULL;
|
|
WOLFSSL_CERT_MANAGER* cm = (WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr;
|
|
(void)jcl;
|
|
|
|
if (env == NULL || in == NULL || (sz < 0)) {
|
|
return BAD_FUNC_ARG;
|
|
}
|
|
|
|
buff = (byte*)(*env)->GetByteArrayElements(env, in, NULL);
|
|
buffSz = (*env)->GetArrayLength(env, in);
|
|
|
|
ret = wolfSSL_CertManagerLoadCABuffer(cm, buff, buffSz, format);
|
|
|
|
(*env)->ReleaseByteArrayElements(env, in, (jbyte*)buff, JNI_ABORT);
|
|
|
|
return (jint)ret;
|
|
}
|
|
|
|
JNIEXPORT jint JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerUnloadCAs
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr)
|
|
{
|
|
int ret = 0;
|
|
WOLFSSL_CERT_MANAGER* cm = (WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr;
|
|
(void)jcl;
|
|
|
|
if (env == NULL) {
|
|
return BAD_FUNC_ARG;
|
|
}
|
|
|
|
ret = wolfSSL_CertManagerUnloadCAs(cm);
|
|
|
|
return (jint)ret;
|
|
}
|
|
|
|
JNIEXPORT jint JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerVerifyBuffer
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr, jbyteArray in, jlong sz, jint format)
|
|
{
|
|
int ret = 0;
|
|
word32 buffSz = 0;
|
|
byte* buff = NULL;
|
|
WOLFSSL_CERT_MANAGER* cm = (WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr;
|
|
(void)jcl;
|
|
|
|
if (env == NULL || in == NULL || (sz < 0)) {
|
|
return BAD_FUNC_ARG;
|
|
}
|
|
|
|
buff = (byte*)(*env)->GetByteArrayElements(env, in, NULL);
|
|
buffSz = (*env)->GetArrayLength(env, in);
|
|
|
|
ret = wolfSSL_CertManagerVerifyBuffer(cm, buff, buffSz, format);
|
|
|
|
(*env)->ReleaseByteArrayElements(env, in, (jbyte*)buff, JNI_ABORT);
|
|
|
|
return (jint)ret;
|
|
}
|
|
|
|
JNIEXPORT jint JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerEnableCRL
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr, jint options)
|
|
{
|
|
#ifdef HAVE_CRL
|
|
WOLFSSL_CERT_MANAGER* cm = (WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr;
|
|
(void)jcl;
|
|
|
|
if (env == NULL || cm == NULL) {
|
|
return BAD_FUNC_ARG;
|
|
}
|
|
|
|
return wolfSSL_CertManagerEnableCRL(cm, (int)options);
|
|
|
|
#else
|
|
(void)env;
|
|
(void)jcl;
|
|
(void)cmPtr;
|
|
(void)options;
|
|
return NOT_COMPILED_IN;
|
|
#endif
|
|
}
|
|
|
|
JNIEXPORT jint JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerDisableCRL
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr)
|
|
{
|
|
#ifdef HAVE_CRL
|
|
WOLFSSL_CERT_MANAGER* cm = (WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr;
|
|
(void)jcl;
|
|
|
|
if (env == NULL || cm == NULL) {
|
|
return BAD_FUNC_ARG;
|
|
}
|
|
|
|
return wolfSSL_CertManagerDisableCRL(cm);
|
|
|
|
#else
|
|
(void)env;
|
|
(void)jcl;
|
|
(void)cmPtr;
|
|
return NOT_COMPILED_IN;
|
|
#endif
|
|
}
|
|
|
|
JNIEXPORT jint JNICALL Java_com_wolfssl_wolfcrypt_WolfSSLCertManager_CertManagerLoadCRLBuffer
|
|
(JNIEnv* env, jclass jcl, jlong cmPtr, jbyteArray in, jlong sz, jint type)
|
|
{
|
|
#ifdef HAVE_CRL
|
|
int ret = 0;
|
|
word32 buffSz = 0;
|
|
byte* buff = NULL;
|
|
WOLFSSL_CERT_MANAGER* cm = (WOLFSSL_CERT_MANAGER*)(uintptr_t)cmPtr;
|
|
(void)jcl;
|
|
|
|
if (env == NULL || in == NULL || (sz < 0)) {
|
|
return BAD_FUNC_ARG;
|
|
}
|
|
|
|
buff = (byte*)(*env)->GetByteArrayElements(env, in, NULL);
|
|
buffSz = (*env)->GetArrayLength(env, in);
|
|
|
|
ret = wolfSSL_CertManagerLoadCRLBuffer(cm, buff, buffSz, type);
|
|
|
|
(*env)->ReleaseByteArrayElements(env, in, (jbyte*)buff, JNI_ABORT);
|
|
|
|
return (jint)ret;
|
|
#else
|
|
(void)env;
|
|
(void)jcl;
|
|
(void)cmPtr;
|
|
(void)in;
|
|
(void)sz;
|
|
(void)type;
|
|
return NOT_COMPILED_IN;
|
|
#endif
|
|
}
|
|
|