From c00f66923909857fa62375623ab53f12c40d87f5 Mon Sep 17 00:00:00 2001 From: liyongfei Date: Fri, 26 Apr 2024 12:32:11 +0800 Subject: [PATCH 01/42] fix:sm3pbkdf2 test error,update README.md,remove unnecessary files. --- CMakeLists.txt | 53 - README.md | 86 +- gmssljni.c | 3882 ------------------- gmssljni.h | 919 ----- jni/jni.h | 1961 ---------- jni/jni_md.h | 23 - pom.xml | 15 +- src/main/c/CMakeLists.txt | 20 +- src/main/c/gmssljni.c | 63 +- src/main/c/gmssljni.h | 22 + src/main/java/org/gmssl/GmSSLException.java | 3 + src/main/java/org/gmssl/GmSSLJNI.java | 2 +- src/main/java/org/gmssl/NativeLoader.java | 10 +- src/test/java/org/gmssl/Sm3Pbkdf2Test.java | 28 +- 14 files changed, 143 insertions(+), 6944 deletions(-) delete mode 100644 CMakeLists.txt delete mode 100644 gmssljni.c delete mode 100644 gmssljni.h delete mode 100755 jni/jni.h delete mode 100755 jni/jni_md.h diff --git a/CMakeLists.txt b/CMakeLists.txt deleted file mode 100644 index 8fdbf1a..0000000 --- a/CMakeLists.txt +++ /dev/null @@ -1,53 +0,0 @@ -cmake_minimum_required(VERSION 3.11) -project(gmssljni) - -add_library(gmssljni-native SHARED gmssljni.c) -target_include_directories(gmssljni-native PUBLIC ${CMAKE_SOURCE_DIR}/src/include) -target_link_libraries(gmssljni-native -L/usr/local/lib) -target_link_libraries(gmssljni-native gmssl) -set_target_properties(gmssljni-native PROPERTIES OUTPUT_NAME gmssljni) - -find_package(Java REQUIRED) -include(UseJava) -include_directories(jni) -include_directories(/usr/local/include) - -# Set the Maven command to be executed -set(MAVEN_COMMAND "mvn clean package test") -# Execute Maven command -execute_process( - COMMAND ${MAVEN_COMMAND} - WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR} - RESULT_VARIABLE MAVEN_RESULT -) -# Check if the Maven command was successfully executed -if(NOT MAVEN_RESULT EQUAL "0") - message(FATAL_ERROR "Maven execute failed: ${MAVEN_OUTPUT}") -endif() - -# Copy the generated jar package to the build directory -set(jarName "GmSSLJNI-2.1.0-dev.jar") -file(COPY ${CMAKE_CURRENT_SOURCE_DIR}/target/${jarName} - DESTINATION ${CMAKE_CURRENT_BINARY_DIR} -) - -enable_testing() - -set(certfile -"-----BEGIN CERTIFICATE-----\n" -"MIIBszCCAVegAwIBAgIIaeL+wBcKxnswDAYIKoEcz1UBg3UFADAuMQswCQYDVQQG\n" -"EwJDTjEOMAwGA1UECgwFTlJDQUMxDzANBgNVBAMMBlJPT1RDQTAeFw0xMjA3MTQw\n" -"MzExNTlaFw00MjA3MDcwMzExNTlaMC4xCzAJBgNVBAYTAkNOMQ4wDAYDVQQKDAVO\n" -"UkNBQzEPMA0GA1UEAwwGUk9PVENBMFkwEwYHKoZIzj0CAQYIKoEcz1UBgi0DQgAE\n" -"MPCca6pmgcchsTf2UnBeL9rtp4nw+itk1Kzrmbnqo05lUwkwlWK+4OIrtFdAqnRT\n" -"V7Q9v1htkv42TsIutzd126NdMFswHwYDVR0jBBgwFoAUTDKxl9kzG8SmBcHG5Yti\n" -"W/CXdlgwDAYDVR0TBAUwAwEB/zALBgNVHQ8EBAMCAQYwHQYDVR0OBBYEFEwysZfZ\n" -"MxvEpgXBxuWLYlvwl3ZYMAwGCCqBHM9VAYN1BQADSAAwRQIgG1bSLeOXp3oB8H7b\n" -"53W+CKOPl2PknmWEq/lMhtn25HkCIQDaHDgWxWFtnCrBjH16/W3Ezn7/U/Vjo5xI\n" -"pDoiVhsLwg==\n" -"-----END CERTIFICATE-----\n") -file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/ROOTCA.pem ${certfile}) - -add_test(NAME main COMMAND java -cp ${jarName} org.gmssl.GmSSLJNI) - - diff --git a/README.md b/README.md index 75769c0..f041a83 100644 --- a/README.md +++ b/README.md @@ -8,12 +8,6 @@ GmSSL-Java是采用JNI (Java Native Interface)方式实现的,也就是说所 因为GmSSL-Java以JNI方式实现,GmSSL-Java不仅包含Java语言实现的Java类库(Jar包),还包括C语言实现的本地库(libgmssljni动态库),其中libgmssljni这个本地库是Java接口类库和GmSSL库(libgmssl)之间的胶水层,应用部署时还需要保证系统中已经安全了GmSSL库。虽然看起来这种实现方式比纯Java实现的类似更麻烦,而且因为包含C编译的本地代码,这个类库也失去了Java代码一次编译到处运行的跨平台能力,但是这是密码库的主流实现方式。相对于纯Java实现来说,GmSSL-Java可以充分利用成熟和功能丰富的GmSSL库,在性能、标准兼容性上都更有优势,并且可以随着GmSSL主项目的升级获得功能和性能上的升级。 -## 下载 - -* GmSSL-Java主分支源代码 [GmSSL-Java-main.zip](https://github.com/GmSSL/GmSSL-Java/archive/refs/heads/main.zip) (版本号:2.1.0 dev) -* 依赖的GmSSL库主分支源代码 [GmSSL-master.zip](https://github.com/guanzhi/GmSSL/archive/refs/heads/master.zip) (版本号:3.1.1 Dev)] -* GitHub主页:https://github.com/GmSSL/GmSSL-Java - ## 项目构成 GmSSL的项目组成主要包括C语言的本地代码、`src`目录下的Java类库代码、`examples`目录下面的例子代码。其中只有本地代码和`src`下面的Java类库代码会参与默认的编译,生成动态库和Jar包,而`examples`下的例子默认不编译也不进入Jar包。 @@ -47,65 +41,35 @@ GmSSL-Java提供一个包`org.gmssl`,其中包含如下密码算法类 +## 下载 -## 编译和安装 - -GmSSL-Java依赖GmSSL项目,在编译前需要先在系统上编译、安装并测试通过GmSSL库及工具。请在https://github.com/guanzhi/GmSSL 项目上下载最新的GmSSL代码,并完成编译、测试和安装。 - -首先下载最新的GmSSL-Java代码。 - -### CMake编译安装 - -采用CMake编译工具链,需要在系统上安装基础的GCC编译工具链、CMake、Java和Maven环境,在Ubuntu/Debian系统上可以执行如下命令安装依赖的工具。 - -```bash -sudo apt update -sudo apt install build-essential cmake default-jdk -``` - -安装完成后可以通过CMake编译 - -```bash -mkdir build -cd build -cmake .. -make -make test -``` - -编译并测试成功后可以显示 - -```bash -$ make test -Running tests... -Test project /path/to/GmSSL-Java/build - Start 1: main -1/1 Test #1: main ............................. Passed 2.27 sec +### 主页 +* GmSSL-Java主页 [GmSSL-Java](https://github.com/GmSSL/GmSSL-Java) +* 依赖的GmSSL库主页 [GmSSL](https://github.com/guanzhi/GmSSL) -100% tests passed, 0 tests failed out of 1 +### 最新发布 +* GmSSL-Java发布页,支持windows、Linux、MacOS多平台 [GmSSL-Java](https://github.com/GmSSL/GmSSL-Java/releases) +* 依赖的GmSSL发布页,包含windows、Linux、MacOS多平台 [GmSSL](https://github.com/guanzhi/GmSSL/releases) +* 当前最新发布版本 3.1.1 + [GmSSL-Java](https://github.com/GmSSL/GmSSL-Java/archive/refs/heads/main.zip) + [GmSSL](https://github.com/guanzhi/GmSSL/archive/refs/tags/v3.1.1.zip) -Total Test time (real) = 2.27 sec -``` +## 编译和安装 -此时查看`build`目录下可以看到生成的本地动态库`libgmssljni`和GmSSLJNI的Jar包`GmSSLJNI-2.1.0-dev.jar`。 +### 编译安装GmSSL +GmSSL-Java依赖GmSSL项目,在编译前需要先在系统上编译、安装并测试通过GmSSL库及工具。请在https://github.com/guanzhi/GmSSL 项目上下载最新发布的GmSSL代码,并完成编译、测试和安装。 -### Maven编译安装 +### Maven编译安装GmSSL-java -检查JAVA环境变量是否配置正确 +检查JAVA、Maven、gmssl的C库环境变量是否配置正确 ```shell java -version # MacOS系统可用如下命令再次确认以检查配置是否成功,路径是否正确 echo $JAVA_HOME -``` - -确认和修改项目编译时打包参数,参数位置在pom.xml中properties的path相关内容。GmSSL如在默认路径安装情况下只需确认。 -``` -winIncludePath 设置Windows系统下依赖的GmSSL的头信息路径地址 -winLibPath 设置Windows系统下依赖的GmSSL的库信息路径地址 -linuxIncludePath 设置Linux系统下依赖的GmSSL的头信息路径地址 -linuxLibPath 设置Linux系统下依赖的GmSSL的库信息路径地址 -macIncludePath 设置MacOS系统下依赖的GmSSL的头信息路径地址 -macLibPath 设置MacOS系统下依赖的GmSSL的库信息路径地址 +# 检查Maven环境变量,能正常输出 +mvn -v +# 检查gmssl环境变量,能正常输出 +gmssl version ``` MacOS环境下在resources目录config.properties设置了生成库的引用库macReferencedLib,为方便项目运行进行配置,本项目生成库引用关系可通过otool -L命令查看,也可以通过下面命令修正本项目生成库的实际引用关系, @@ -119,7 +83,17 @@ macReferencedLib 设置MacOS系统下依赖的GmSSL相关的引用库信 ```shell mvn clean install ``` -最终会执行单元测试并在target目录下生成GmSSLJNI-2.1.0-dev.jar +最终会执行单元测试并在target目录下生成相应版本jar包。 + +## 使用 +在其他项目中使用GmSSL-java,只需在pom.xml中添加如下依赖: +```xml + + com.gmssl + GmSSLJNI + 3.1.1 + +``` ## 开发手册 diff --git a/gmssljni.c b/gmssljni.c deleted file mode 100644 index fe1cc72..0000000 --- a/gmssljni.c +++ /dev/null @@ -1,3882 +0,0 @@ -/* - * Copyright 2014-2023 The GmSSL Project. All Rights Reserved. - * - * Licensed under the Apache License, Version 2.0 (the License); you may - * not use this file except in compliance with the License. - * - * http://www.apache.org/licenses/LICENSE-2.0 - */ - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include "gmssljni.h" - - -static int check_buf(const jbyte *buf, jint bufsiz, jint offset, jint outlen) -{ - if (offset < 0 || outlen < 0) { - error_print(); - return -1; - } - if (!(buf + offset >= buf) - || !(buf + offset + outlen >= buf + offset) - || !(offset + outlen >= offset)) { - error_print(); - return -1; - } - if (offset + outlen > bufsiz) { - error_print(); - return -1; - } - return 1; -} - - -JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM *vm, void *reserved) -{ - return JNI_VERSION_1_2; -} - -JNIEXPORT void JNICALL JNI_OnUnload(JavaVM *vm, void *reserved) -{ -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: version_num - * Signature: ()I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_version_1num( - JNIEnv *env, jclass this) -{ - return (jint)gmssl_version_num(); -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: version_str - * Signature: ()Ljava/lang/String; - */ -JNIEXPORT jstring JNICALL Java_org_gmssl_GmSSLJNI_version_1str( - JNIEnv *env, jclass this) -{ - return (*env)->NewStringUTF(env, gmssl_version_str()); -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: rand_bytes - * Signature: ([BIJ)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_rand_1bytes( - JNIEnv *env, jclass this, - jbyteArray out, jint offset, jlong length) -{ - jint ret = -1; - jbyte *buf = NULL; - jint mode = JNI_ABORT; - - if (!(buf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - return -1; - } - if (check_buf(buf, (*env)->GetArrayLength(env, out), offset, length) != 1) { - error_print(); - goto end; - } - if (rand_bytes((uint8_t *)buf + offset, length) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, out, buf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm3_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong sm3_ctx; - - if (!(sm3_ctx = (jlong)malloc(sizeof(SM3_CTX)))) { - error_print(); - return 0; - } - memset((SM3_CTX *)sm3_ctx, 0, sizeof(SM3_CTX)); - return sm3_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm3_1ctx_1free( - JNIEnv *env, jclass this, - jlong sm3_ctx) -{ - if (sm3_ctx) { - gmssl_secure_clear((SM3_CTX *)sm3_ctx, sizeof(SM3_CTX)); - free((SM3_CTX *)sm3_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_init - * Signature: (J)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1init( - JNIEnv *env, jclass this, - jlong sm3_ctx) -{ - if (!sm3_ctx) { - error_print(); - return -1; - } - sm3_init((SM3_CTX *)sm3_ctx); - return 1; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1update( - JNIEnv *env, jclass this, - jlong sm3_ctx, jbyteArray data, jint offset, jint length) -{ - jint ret = -1; - jbyte *buf = NULL; - jsize buflen; - - if (!sm3_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, data, NULL))) { - error_print(); - return -1; - } - if (check_buf(buf, (*env)->GetArrayLength(env, data), offset, length) != 1) { - error_print(); - goto end; - } - sm3_update((SM3_CTX *)sm3_ctx, (uint8_t *)buf + offset, (size_t)length); - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, data, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_finish - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1finish( - JNIEnv *env, jclass this, - jlong sm3_ctx, jbyteArray dgst) -{ - jint ret = -1; - jbyte *buf = NULL; - jint mode = JNI_ABORT; - - if (!sm3_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, dgst, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, dgst) < SM3_DIGEST_SIZE) { - error_print(); - goto end; - } - sm3_finish((SM3_CTX *)sm3_ctx, (uint8_t *)buf); - mode = 0; - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, dgst, buf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong sm3_hmac_ctx; - if (!(sm3_hmac_ctx = (jlong)malloc(sizeof(SM3_HMAC_CTX)))) { - error_print(); - return 0; - } - return sm3_hmac_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1ctx_1free( - JNIEnv *env, jclass this, - jlong sm3_hmac_ctx) -{ - if (sm3_hmac_ctx) { - gmssl_secure_clear((SM3_HMAC_CTX *)sm3_hmac_ctx, sizeof(SM3_HMAC_CTX)); - free((SM3_HMAC_CTX *)sm3_hmac_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_init - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1init( - JNIEnv *env, jclass this, - jlong sm3_hmac_ctx, jbyteArray key) -{ - jint ret = -1; - jbyte *buf = NULL; - jlong buflen; - - if (!sm3_hmac_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - buflen = (*env)->GetArrayLength(env, key); - if (buflen < 1 || buflen > 64) { - error_print(); - goto end; - } - sm3_hmac_init((SM3_HMAC_CTX *)sm3_hmac_ctx, (uint8_t *)buf, (size_t)buflen); - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1update( - JNIEnv *env, jclass this, - jlong sm3_hmac_ctx, jbyteArray data, jint offset, jint length) -{ - jint ret = -1; - jbyte *buf = NULL; - jsize buflen; - - if (!sm3_hmac_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, data, NULL))) { - error_print(); - return -1; - } - if (check_buf(buf, (*env)->GetArrayLength(env, data), offset, length) != 1) { - error_print(); - goto end; - } - sm3_hmac_update((SM3_HMAC_CTX *)sm3_hmac_ctx, (uint8_t *)buf + offset, (size_t)length); - ret = 1; -end: - if (buf) (*env)->ReleaseByteArrayElements(env, data, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_finish - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1finish( - JNIEnv *env, jclass this, - jlong sm3_hmac_ctx, jbyteArray hmac) -{ - jint ret = -1; - jbyte *buf = NULL; - jint mode = JNI_ABORT; - - if (!sm3_hmac_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, hmac, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, hmac) < SM3_HMAC_SIZE) { - error_print(); - goto end; - } - sm3_hmac_finish((SM3_HMAC_CTX *)sm3_hmac_ctx, (uint8_t *)buf); - mode = 0; - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, hmac, buf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_pbkdf2 - * Signature: (Ljava/lang/String;[BII)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm3_1pbkdf2( - JNIEnv *env, jclass this, - jstring pass, jbyteArray salt, jint iter, jint keylen) -{ - jbyteArray ret = NULL; - uint8_t keybuf[256]; - const char *pass_str = NULL; - jbyte *saltbuf = NULL; - jlong saltlen; - - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (iter < PBKDF2_MIN_ITER || iter > PBKDF2_MAX_ITER) { - error_print(); - goto end; - } - if (!(saltbuf = (*env)->GetByteArrayElements(env, salt, NULL))) { - error_print(); - goto end; - } - saltlen = (*env)->GetArrayLength(env, salt); - if (saltlen < 1 || saltlen > PBKDF2_MAX_SALT_SIZE) { - error_print(); - goto end; - } - if (keylen < 1 || keylen > sizeof(keybuf)) { - error_print(); - goto end; - } - - if (pbkdf2_hmac_sm3_genkey(pass_str, strlen(pass_str), - (const uint8_t *)saltbuf, saltlen, iter, keylen, keybuf) != 1) { - error_print(); - goto end; - } - - if (!(ret = (*env)->NewByteArray(env, keylen))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, keylen, (jbyte *)keybuf); - -end: - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (saltbuf) (*env)->ReleaseByteArrayElements(env, salt, saltbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_key_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1key_1new( - JNIEnv *env, jclass this) -{ - jlong sm4_key; - - if (!(sm4_key = (jlong)malloc(sizeof(SM4_KEY)))) { - error_print(); - return 0; - } - memset((SM4_KEY *)sm4_key, 0, sizeof(SM4_KEY)); - return sm4_key; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1key_1free( - JNIEnv *env, jclass this, - jlong sm4_key) -{ - if (sm4_key) { - gmssl_secure_clear((SM4_KEY *)sm4_key, sizeof(SM4_KEY)); - free((SM4_KEY *)sm4_key); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_set_encrypt_key - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1set_1encrypt_1key( - JNIEnv *env, jclass this, - jlong sm4_key, jbyteArray key) -{ - jint ret = -1; - jbyte *buf = NULL; - - if (!sm4_key) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - sm4_set_encrypt_key((SM4_KEY *)sm4_key, (uint8_t *)buf); - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_set_decrypt_key - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1set_1decrypt_1key( - JNIEnv *env, jclass this, - jlong sm4_key, jbyteArray key) -{ - jint ret = -1; - jbyte *buf = NULL; - - if (!sm4_key) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - sm4_set_decrypt_key((SM4_KEY *)sm4_key, (uint8_t *)buf); - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_encrypt - * Signature: (J[BI[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1encrypt( - JNIEnv *env, jclass this, - jlong sm4_key, - jbyteArray in, jint in_offset, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - jsize inbuflen, outbuflen; - jint mode = JNI_ABORT; - - if (!sm4_key) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, SM4_BLOCK_SIZE) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - goto end; - } - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, SM4_BLOCK_SIZE) != 1) { - error_print(); - goto end; - } - sm4_encrypt((SM4_KEY *)sm4_key, (uint8_t *)inbuf + in_offset, (uint8_t *)outbuf + out_offset); - mode = 0; - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong sm4_cbc_ctx; - - if (!(sm4_cbc_ctx = (jlong)malloc(sizeof(SM4_CBC_CTX)))) { - error_print(); - return 0; - } - memset((SM4_CBC_CTX *)sm4_cbc_ctx, 0, sizeof(SM4_CBC_CTX)); - return sm4_cbc_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1ctx_1free( - JNIEnv *env, jclass this, - jlong sm4_cbc_ctx) -{ - if (sm4_cbc_ctx) { - gmssl_secure_clear((SM4_CBC_CTX *)sm4_cbc_ctx, sizeof(SM4_CBC_CTX)); - free((SM4_CBC_CTX *)sm4_cbc_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_encrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1encrypt_1init( - JNIEnv *env, jclass this, - jlong sm4_cbc_ctx, jbyteArray key, jbyteArray iv) -{ - jint ret = -1; - jbyte *keybuf = NULL; - jbyte *ivbuf = NULL; - - if (!sm4_cbc_ctx) { - error_print(); - return -1; - } - if (!(keybuf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - if (!(ivbuf = (*env)->GetByteArrayElements(env, iv, 0))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, iv) < SM4_BLOCK_SIZE) { - error_print(); - goto end; - } - if (sm4_cbc_encrypt_init((SM4_CBC_CTX *)sm4_cbc_ctx, (uint8_t *)keybuf, (uint8_t *)ivbuf) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, keybuf, JNI_ABORT); - if (ivbuf) (*env)->ReleaseByteArrayElements(env, iv, ivbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1encrypt_1update( - JNIEnv *env, jclass this, - jlong sm4_cbc_ctx, - jbyteArray in, jint in_offset, jint inlen, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_cbc_ctx) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, inlen) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - goto end; - } - outlen = inlen + SM4_BLOCK_SIZE; - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, outlen) != 1 - || outlen < inlen) { - error_print(); - goto end; - } - if (sm4_cbc_encrypt_update((SM4_CBC_CTX *)sm4_cbc_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1encrypt_1finish( - JNIEnv *env, jclass this, - jlong sm4_cbc_ctx, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_cbc_ctx) { - error_print(); - return -1; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - return -1; - } - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, SM4_BLOCK_SIZE) != 1) { - error_print(); - goto end; - } - if (sm4_cbc_encrypt_finish((SM4_CBC_CTX *)sm4_cbc_ctx, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_decrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1decrypt_1init( - JNIEnv *env, jclass this, - jlong sm4_cbc_ctx, jbyteArray key, jbyteArray iv) -{ - jint ret = -1; - jbyte *keybuf = NULL; - jbyte *ivbuf = NULL; - - if (!sm4_cbc_ctx) { - error_print(); - return -1; - } - if (!(keybuf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - if (!(ivbuf = (*env)->GetByteArrayElements(env, iv, NULL))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, iv) < SM4_BLOCK_SIZE) { - error_print(); - goto end; - } - if (sm4_cbc_decrypt_init((SM4_CBC_CTX *)sm4_cbc_ctx, (uint8_t *)keybuf, (uint8_t *)ivbuf) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, keybuf, JNI_ABORT); - if (ivbuf) (*env)->ReleaseByteArrayElements(env, iv, ivbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_decrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1decrypt_1update( - JNIEnv *env, jclass this, - jlong sm4_cbc_ctx, - jbyteArray in, jint in_offset, jint inlen, jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_cbc_ctx) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, inlen) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, 0))) { - error_print(); - goto end; - } - outlen = inlen + SM4_BLOCK_SIZE; - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, outlen) != 1 - || outlen < inlen) { - error_print(); - goto end; - } - if (sm4_cbc_decrypt_update((SM4_CBC_CTX *)sm4_cbc_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_decrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1decrypt_1finish( - JNIEnv *env, jclass this, - jlong sm4_cbc_ctx, jbyteArray out, jint offset) -{ - jint ret = -1; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_cbc_ctx) { - error_print(); - return -1; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - return -1; - } - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), offset, SM4_BLOCK_SIZE) != 1) { - error_print(); - goto end; - } - if (sm4_cbc_decrypt_finish((SM4_CBC_CTX *)sm4_cbc_ctx, (uint8_t *)outbuf + offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong sm4_ctr_ctx; - - if (!(sm4_ctr_ctx = (jlong)malloc(sizeof(SM4_CTR_CTX)))) { - error_print(); - return 0; - } - memset((SM4_CTR_CTX *)sm4_ctr_ctx, 0, sizeof(SM4_CTR_CTX)); - return sm4_ctr_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1ctx_1free( - JNIEnv *env, jclass this, - jlong sm4_ctr_ctx) -{ - if (sm4_ctr_ctx) { - gmssl_secure_clear((SM4_CTR_CTX *)sm4_ctr_ctx, sizeof(SM4_CTR_CTX)); - free((SM4_CTR_CTX *)sm4_ctr_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_encrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1encrypt_1init( - JNIEnv *env, jclass this, - jlong sm4_ctr_ctx, jbyteArray key, jbyteArray iv) -{ - jint ret = -1; - jbyte *keybuf = NULL; - jbyte *ivbuf = NULL; - - if (!sm4_ctr_ctx) { - error_print(); - return -1; - } - if (!(keybuf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - if (!(ivbuf = (*env)->GetByteArrayElements(env, iv, NULL))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, iv) < SM4_BLOCK_SIZE) { - error_print(); - goto end; - } - if (sm4_ctr_encrypt_init((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)keybuf, (uint8_t *)ivbuf) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, keybuf, JNI_ABORT); - if (ivbuf) (*env)->ReleaseByteArrayElements(env, iv, ivbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1encrypt_1update( - JNIEnv *env, jclass this, - jlong sm4_ctr_ctx, - jbyteArray in, jint in_offset, jint inlen, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_ctr_ctx) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, inlen) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - goto end; - } - outlen = inlen + SM4_BLOCK_SIZE; - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, outlen) != 1 - || outlen < inlen) { - error_print(); - goto end; - } - if (sm4_ctr_encrypt_update((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1encrypt_1finish( - JNIEnv *env, jclass this, - jlong sm4_ctr_ctx, jbyteArray out, jint offset) -{ - jint ret = -1; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_ctr_ctx) { - error_print(); - return -1; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, 0))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, out) < offset + SM4_BLOCK_SIZE) { - error_print(); - goto end; - } - if (sm4_ctr_encrypt_finish((SM4_CTR_CTX *)sm4_ctr_ctx, - (uint8_t *)outbuf + offset, &outlen) != 1) { - error_print(); - goto end; - } - - mode = 0; - ret = (jint)outlen; -end: - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_decrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1init( - JNIEnv *env, jclass this, - jlong sm4_ctr_ctx, jbyteArray key, jbyteArray iv) -{ - jint ret = -1; - jbyte *keybuf = NULL; - jbyte *ivbuf = NULL; - - if (!sm4_ctr_ctx) { - error_print(); - return -1; - } - if (!(keybuf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - if (!(ivbuf = (*env)->GetByteArrayElements(env, iv, NULL))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, iv) < SM4_BLOCK_SIZE) { - error_print(); - goto end; - } - if (sm4_ctr_decrypt_init((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)keybuf, (uint8_t *)ivbuf) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, keybuf, JNI_ABORT); - if (ivbuf) (*env)->ReleaseByteArrayElements(env, iv, ivbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_decrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1update( - JNIEnv *env, jclass this, - jlong sm4_ctr_ctx, - jbyteArray in, jint in_offset, jint inlen, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_ctr_ctx) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, inlen) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - goto end; - } - outlen = inlen + SM4_BLOCK_SIZE; - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, outlen) != 1 - || outlen < inlen) { - error_print(); - goto end; - } - if (sm4_ctr_decrypt_update((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_decrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1finish( - JNIEnv *env, jclass this, - jlong sm4_ctr_ctx, jbyteArray out, jint offset) -{ - jint ret = -1; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_ctr_ctx) { - error_print(); - return -1; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - return -1; - } - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), offset, SM4_BLOCK_SIZE) != 1) { - error_print(); - goto end; - } - if (sm4_ctr_decrypt_finish((SM4_CTR_CTX *)sm4_ctr_ctx, - (uint8_t *)outbuf + offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong sm4_gcm_ctx; - - if (!(sm4_gcm_ctx = (jlong)malloc(sizeof(SM4_GCM_CTX)))) { - error_print(); - return 0; - } - memset((SM4_GCM_CTX *)sm4_gcm_ctx, 0, sizeof(SM4_GCM_CTX)); - return sm4_gcm_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1ctx_1free( - JNIEnv *env, jclass this, - jlong sm4_gcm_ctx) -{ - if (sm4_gcm_ctx) { - gmssl_secure_clear((SM4_GCM_CTX *)sm4_gcm_ctx, sizeof(SM4_GCM_CTX)); - free((SM4_GCM_CTX *)sm4_gcm_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_encrypt_init - * Signature: (J[B[B[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1encrypt_1init( - JNIEnv *env, jclass this, - jlong sm4_gcm_ctx, jbyteArray key, jbyteArray iv, jbyteArray aad, jint taglen) -{ - jint ret = -1; - jbyte *keybuf = NULL; - jbyte *ivbuf = NULL; - jbyte *aadbuf = NULL; - jsize ivlen, aadlen; - - if (!sm4_gcm_ctx) { - error_print(); - return -1; - } - if (!(keybuf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - if (!(ivbuf = (*env)->GetByteArrayElements(env, iv, NULL))) { - error_print(); - goto end; - } - ivlen = (*env)->GetArrayLength(env, iv); - if (!(aadbuf = (*env)->GetByteArrayElements(env, aad, NULL))) { - error_print(); - goto end; - } - aadlen = (*env)->GetArrayLength(env, aad); - if (sm4_gcm_encrypt_init((SM4_GCM_CTX *)sm4_gcm_ctx, (uint8_t *)keybuf, SM4_KEY_SIZE, - (uint8_t *)ivbuf, (size_t)ivlen, (uint8_t *)aadbuf, (size_t)aadlen, (size_t)taglen) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, keybuf, JNI_ABORT); - if (ivbuf) (*env)->ReleaseByteArrayElements(env, iv, ivbuf, JNI_ABORT); - if (aadbuf) (*env)->ReleaseByteArrayElements(env, aad, aadbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1encrypt_1update( - JNIEnv *env, jclass this, - jlong sm4_gcm_ctx, - jbyteArray in, jint in_offset, jint inlen, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_gcm_ctx) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, inlen) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - goto end; - } - outlen = inlen + SM4_BLOCK_SIZE; - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, outlen) != 1 - || outlen < inlen) { - error_print(); - goto end; - } - if (sm4_gcm_encrypt_update((SM4_GCM_CTX *)sm4_gcm_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1encrypt_1finish( - JNIEnv *env, jclass this, - jlong sm4_gcm_ctx, jbyteArray out, jint offset) -{ - jint ret = -1; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_gcm_ctx) { - error_print(); - return -1; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - return -1; - } - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), - offset, SM4_BLOCK_SIZE + SM4_GCM_MAX_TAG_SIZE) != 1) { - error_print(); - goto end; - } - if (sm4_gcm_encrypt_finish((SM4_GCM_CTX *)sm4_gcm_ctx, - (uint8_t *)outbuf + offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_decrypt_init - * Signature: (J[B[B[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1decrypt_1init( - JNIEnv *env, jclass this, - jlong sm4_gcm_ctx, jbyteArray key, jbyteArray iv, jbyteArray aad, jint taglen) -{ - jint ret = -1; - jbyte *keybuf = NULL; - jbyte *ivbuf = NULL; - jbyte *aadbuf = NULL; - jsize ivlen, aadlen; - - if (!sm4_gcm_ctx) { - error_print(); - return -1; - } - if (!(keybuf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < SM4_KEY_SIZE) { - error_print(); - goto end; - } - if (!(ivbuf = (*env)->GetByteArrayElements(env, iv, NULL))) { - error_print(); - goto end; - } - ivlen = (*env)->GetArrayLength(env, iv); - if (!(aadbuf = (*env)->GetByteArrayElements(env, aad, NULL))) { - error_print(); - goto end; - } - aadlen = (*env)->GetArrayLength(env, aad); - if (sm4_gcm_decrypt_init((SM4_GCM_CTX *)sm4_gcm_ctx, - (uint8_t *)keybuf, SM4_KEY_SIZE, (uint8_t *)ivbuf, (size_t)ivlen, - (uint8_t *)aadbuf, (size_t)aadlen, (size_t)taglen) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, keybuf, JNI_ABORT); - if (ivbuf) (*env)->ReleaseByteArrayElements(env, iv, ivbuf, JNI_ABORT); - if (aadbuf) (*env)->ReleaseByteArrayElements(env, aad, aadbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_decrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1decrypt_1update( - JNIEnv *env, jclass this, - jlong sm4_gcm_ctx, jbyteArray in, jint in_offset, jint inlen, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_gcm_ctx) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, inlen) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, 0))) { - error_print(); - goto end; - } - outlen = inlen + SM4_BLOCK_SIZE; - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, outlen) != 1) { - error_print(); - goto end; - } - if (sm4_gcm_decrypt_update((SM4_GCM_CTX *)sm4_gcm_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_decrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1decrypt_1finish( - JNIEnv *env, jclass this, - jlong sm4_gcm_ctx, jbyteArray out, jint offset) -{ - jint ret = -1; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!sm4_gcm_ctx) { - error_print(); - return -1; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - return -1; - } - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), - offset, SM4_BLOCK_SIZE + SM4_GCM_MAX_TAG_SIZE) != 1) { - error_print(); - goto end; - } - if (sm4_gcm_decrypt_finish((SM4_GCM_CTX *)sm4_gcm_ctx, - (uint8_t *)outbuf + offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_key_generate - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1key_1generate( - JNIEnv *env, jclass this) -{ - jlong sm2_key; - - if (!(sm2_key = (jlong)malloc(sizeof(SM2_KEY)))) { - error_print(); - return 0; - } - if (sm2_key_generate((SM2_KEY *)sm2_key) != 1) { - gmssl_secure_clear((SM2_KEY *)sm2_key, sizeof(SM2_KEY)); - error_print(); - return 0; - } - return sm2_key; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_zuc_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong zuc_ctx; - - if (!(zuc_ctx = (jlong)malloc(sizeof(ZUC_CTX)))) { - error_print(); - return 0; - } - memset((ZUC_CTX *)zuc_ctx, 0, sizeof(ZUC_CTX)); - return zuc_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_zuc_1ctx_1free( - JNIEnv *env, jclass this, - jlong zuc_ctx) -{ - if (zuc_ctx) { - gmssl_secure_clear((ZUC_CTX *)zuc_ctx, sizeof(ZUC_CTX)); - free((ZUC_CTX *)zuc_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_encrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_zuc_1encrypt_1init( - JNIEnv *env, jclass this, - jlong zuc_ctx, jbyteArray key, jbyteArray iv) -{ - jint ret = -1; - jbyte *keybuf = NULL; - jbyte *ivbuf = NULL; - - if (!zuc_ctx) { - error_print(); - return -1; - } - if (!(keybuf = (*env)->GetByteArrayElements(env, key, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, key) < ZUC_KEY_SIZE) { - error_print(); - goto end; - } - if (!(ivbuf = (*env)->GetByteArrayElements(env, iv, NULL))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, iv) < ZUC_IV_SIZE) { - error_print(); - goto end; - } - if (zuc_encrypt_init((ZUC_CTX *)zuc_ctx, (uint8_t *)keybuf, (uint8_t *)ivbuf) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, key, keybuf, JNI_ABORT); - if (ivbuf) (*env)->ReleaseByteArrayElements(env, iv, ivbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_zuc_1encrypt_1update( - JNIEnv *env, jclass this, - jlong zuc_ctx, - jbyteArray in, jint in_offset, jint inlen, - jbyteArray out, jint out_offset) -{ - jint ret = -1; - jbyte *inbuf = NULL; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!zuc_ctx) { - error_print(); - return -1; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return -1; - } - if (check_buf(inbuf, (*env)->GetArrayLength(env, in), in_offset, inlen) != 1) { - error_print(); - goto end; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, NULL))) { - error_print(); - goto end; - } - outlen = inlen + 4; // ZUC block size is sizeof(uint32_t) - if (check_buf(outbuf, (*env)->GetArrayLength(env, out), out_offset, outlen) != 1 - || outlen < inlen) { - error_print(); - goto end; - } - if (zuc_encrypt_update((ZUC_CTX *)zuc_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, - (uint8_t *)outbuf + out_offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_zuc_1encrypt_1finish( - JNIEnv *env, jclass this, - jlong zuc_ctx, jbyteArray out, jint offset) -{ - jint ret = -1; - jbyte *outbuf = NULL; - size_t outlen; - jint mode = JNI_ABORT; - - if (!zuc_ctx) { - error_print(); - return -1; - } - if (!(outbuf = (*env)->GetByteArrayElements(env, out, 0))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, out) < offset + 4) { // ZUC block size is sizeof(uint32) == 4 - error_print(); - goto end; - } - if (zuc_encrypt_finish((ZUC_CTX *)zuc_ctx, - (uint8_t *)outbuf + offset, &outlen) != 1) { - error_print(); - goto end; - } - mode = 0; - ret = (jint)outlen; -end: - if (outbuf) (*env)->ReleaseByteArrayElements(env, out, outbuf, mode); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm2_1key_1free( - JNIEnv *env, jclass this, - jlong sm2_key) -{ - if (sm2_key) { - gmssl_secure_clear((SM2_KEY *)sm2_key, sizeof(SM2_KEY)); - free((SM2_KEY *)sm2_key); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_to_der - * Signature: (J)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1to_1der( - JNIEnv *env, jclass this, - jlong sm2_key) -{ - jbyteArray ret = NULL; - uint8_t outbuf[1024]; - uint8_t *p = outbuf; - size_t outlen = 0; - - if (sm2_private_key_info_to_der((SM2_KEY *)sm2_key, &p, &outlen) != 1) { - error_print(); - return NULL; - } - if (!(ret = (*env)->NewByteArray(env, outlen))) { - error_print(); - gmssl_secure_clear(outbuf, sizeof(outbuf)); - return NULL; - } - (*env)->SetByteArrayRegion(env, ret, 0, outlen, (jbyte *)outbuf); - gmssl_secure_clear(outbuf, sizeof(outbuf)); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_from_der - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1from_1der( - JNIEnv *env, jclass this, - jbyteArray der) -{ - jlong ret = 0; - SM2_KEY *sm2_key = NULL; - jbyte *derbuf = NULL; - size_t derlen; - const uint8_t *attrs; - size_t attrslen; - const uint8_t *cp; - - if (!(derbuf = (*env)->GetByteArrayElements(env, der, NULL))) { - error_print(); - return 0; - } - derlen = (*env)->GetArrayLength(env, der); - - if (!(sm2_key = (SM2_KEY *)malloc(sizeof(SM2_KEY)))) { - error_print(); - goto end; - } - cp = (const uint8_t *)derbuf; - if (sm2_private_key_info_from_der(sm2_key, &attrs, &attrslen, &cp, &derlen) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm2_key; - sm2_key = NULL; -end: - (*env)->ReleaseByteArrayElements(env, der, derbuf, JNI_ABORT); - if (sm2_key) { - gmssl_secure_clear(sm2_key, sizeof(SM2_KEY)); - free(sm2_key); - } - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_to_der - * Signature: (J)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1to_1der( - JNIEnv *env, jclass this, - jlong sm2_key) -{ - jbyteArray ret = NULL; - uint8_t outbuf[1024]; - uint8_t *p = outbuf; - size_t outlen = 0; - - if (sm2_public_key_info_to_der((SM2_KEY *)sm2_key, &p, &outlen) != 1) { - error_print(); - return NULL; - } - if (!(ret = (*env)->NewByteArray(env, outlen))) { - error_print(); - gmssl_secure_clear(outbuf, sizeof(outbuf)); - return NULL; - } - (*env)->SetByteArrayRegion(env, ret, 0, outlen, (jbyte *)outbuf); - gmssl_secure_clear(outbuf, sizeof(outbuf)); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_from_der - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1from_1der( - JNIEnv *env, jclass this, - jbyteArray der) -{ - jlong ret = 0; - SM2_KEY *sm2_key = NULL; - jbyte *derbuf = NULL; - size_t derlen; - const uint8_t *cp; - - if (!(derbuf = (*env)->GetByteArrayElements(env, der, NULL))) { - error_print(); - return 0; - } - derlen = (*env)->GetArrayLength(env, der); // return jsize which is int! - - if (!(sm2_key = (SM2_KEY *)malloc(sizeof(SM2_KEY)))) { - error_print(); - goto end; - } - cp = (const uint8_t *)derbuf; - if (sm2_public_key_info_from_der(sm2_key, &cp, &derlen) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm2_key; - sm2_key = NULL; -end: - (*env)->ReleaseByteArrayElements(env, der, derbuf, JNI_ABORT); - if (sm2_key) { - gmssl_secure_clear(sm2_key, sizeof(SM2_KEY)); - free(sm2_key); - } - return ret; -} - -// FIXME: ReleaseStringUTFChars ?? no mode? - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1encrypt_1to_1pem( - JNIEnv *env, jclass this, - jlong sm2_key, jstring pass, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!sm2_key) { - error_print(); - return -1; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, NULL))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, NULL))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm2_private_key_info_encrypt_to_pem((SM2_KEY *)sm2_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1decrypt_1from_1pem( - JNIEnv *env, jclass this, - jstring pass, jstring file) -{ - jlong ret = 0; - SM2_KEY *sm2_key = NULL; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!(sm2_key = (SM2_KEY *)malloc(sizeof(SM2_KEY)))) { - error_print(); - return 0; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, NULL))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, NULL))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm2_private_key_info_decrypt_from_pem(sm2_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm2_key; - sm2_key = NULL; -end: - if (fp) fclose(fp); - if (sm2_key) { - gmssl_secure_clear(sm2_key, sizeof(SM2_KEY)); - free(sm2_key); - } - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_to_pem - * Signature: (JLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1to_1pem( - JNIEnv *env, jclass this, - jlong sm2_pub, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *file_str = NULL; - - if (!sm2_pub) { - error_print(); - return -1; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, NULL))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm2_public_key_info_to_pem((SM2_KEY *)sm2_pub, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_from_pem - * Signature: (Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1from_1pem( - JNIEnv *env, jclass this, - jstring file) -{ - jlong ret = 0; - SM2_KEY *sm2_pub = NULL; - FILE *fp = NULL; - const char *file_str = NULL; - - if (!(sm2_pub = (SM2_KEY *)malloc(sizeof(SM2_KEY)))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, NULL))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm2_public_key_info_from_pem(sm2_pub, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm2_pub; - sm2_pub = NULL; -end: - if (fp) fclose(fp); - if (sm2_pub) { - gmssl_secure_clear(sm2_pub, sizeof(SM2_KEY)); - free(sm2_pub); - } - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_compute_z - * Signature: (JLjava/lang/String;[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1compute_1z( - JNIEnv *env, jclass this, - jlong sm2_pub, jstring id, jbyteArray z) -{ - jint ret = -1; - const char *id_str = NULL; - jbyte *zbuf = NULL; - jint mode = JNI_ABORT; - - if (!sm2_pub) { - error_print(); - return -1; - } - if (!(id_str = (*env)->GetStringUTFChars(env, id, NULL))) { - error_print(); - goto end; - } - if (!(zbuf = (*env)->GetByteArrayElements(env, z, NULL))) { - error_print(); - goto end; - } - if ((*env)->GetArrayLength(env, z) < SM3_DIGEST_SIZE) { - error_print(); - goto end; - } - sm2_compute_z((uint8_t *)zbuf, &((SM2_KEY *)sm2_pub)->public_key, id_str, strlen(id_str)); - mode = 0; - ret = 1; -end: - if (id_str) (*env)->ReleaseStringUTFChars(env, id, id_str); - if (zbuf) (*env)->ReleaseByteArrayElements(env, z, zbuf, mode); - return ret; -} - -// FIXME: change the function name to sign_digest - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign - * Signature: (J[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign( - JNIEnv *env, jclass this, - jlong sm2_key, jbyteArray dgst) -{ - jbyteArray ret = NULL; - jbyte *buf = NULL; - uint8_t sig[SM2_MAX_SIGNATURE_SIZE]; - size_t siglen; - - if (!sm2_key) { - error_print(); - return NULL; - } - if (!(buf = (*env)->GetByteArrayElements(env, dgst, NULL))) { - error_print(); - return NULL; - } - if ((*env)->GetArrayLength(env, dgst) != SM3_DIGEST_SIZE) { - error_print(); - goto end; - } - if (sm2_sign((SM2_KEY *)sm2_key, (uint8_t *)buf, sig, &siglen) != 1) { - error_print(); - goto end; - } - if (!(ret = (*env)->NewByteArray(env, siglen))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, siglen, (jbyte *)sig); -end: - (*env)->ReleaseByteArrayElements(env, dgst, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify( - JNIEnv *env, jclass this, - jlong sm2_pub, jbyteArray dgst, jbyteArray sig) -{ - jint ret = -1; - jbyte *dgstbuf = NULL; - jbyte *sigbuf = NULL; - jsize siglen; - - if (!sm2_pub) { - error_print(); - return -1; - } - if (!(dgstbuf = (*env)->GetByteArrayElements(env, dgst, NULL))) { - error_print(); - return -1; - } - if ((*env)->GetArrayLength(env, dgst) != SM3_DIGEST_SIZE) { - error_print(); - goto end; - } - if (!(sigbuf = (*env)->GetByteArrayElements(env, sig, NULL))) { - error_print(); - goto end; - } - siglen = (*env)->GetArrayLength(env, sig); - if ((ret = sm2_verify((SM2_KEY *)sm2_pub, (uint8_t *)dgstbuf, (uint8_t *)sigbuf, (size_t)siglen)) < 0) { - error_print(); - goto end; - } -end: - (*env)->ReleaseByteArrayElements(env, dgst, dgstbuf, JNI_ABORT); - if (sigbuf) (*env)->ReleaseByteArrayElements(env, sig, sigbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_encrypt - * Signature: (J[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1encrypt( - JNIEnv *env, jclass this, - jlong sm2_pub, jbyteArray in) -{ - jbyteArray ret = NULL; - jbyte *inbuf = NULL; - jsize inlen; - uint8_t outbuf[SM2_MAX_CIPHERTEXT_SIZE]; - size_t outlen; - - if (!sm2_pub) { - error_print(); - return NULL; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return NULL; - } - inlen = (*env)->GetArrayLength(env, in); - if (sm2_encrypt((SM2_KEY *)sm2_pub, (uint8_t *)inbuf, (size_t)inlen, outbuf, &outlen) != 1) { - error_print(); - goto end; - } - if (!(ret = (*env)->NewByteArray(env, outlen))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, outlen, (jbyte *)outbuf); -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_decrypt - * Signature: (J[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1decrypt( - JNIEnv *env, jclass this, - jlong sm2_key, jbyteArray in) -{ - jbyteArray ret = NULL; - jbyte *inbuf = NULL; - jsize inlen; - uint8_t outbuf[SM2_MAX_PLAINTEXT_SIZE]; - size_t outlen; - - if (!sm2_key) { - error_print(); - return NULL; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - return NULL; - } - inlen = (*env)->GetArrayLength(env, in); - if (sm2_decrypt((SM2_KEY *)sm2_key, (uint8_t *)inbuf, (size_t)inlen, outbuf, &outlen) != 1) { - error_print(); - goto end; - } - if (!(ret = (*env)->NewByteArray(env, outlen))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, outlen, (jbyte *)outbuf); -end: - (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong sm2_sign_ctx; - - if (!(sm2_sign_ctx = (jlong)malloc(sizeof(SM2_SIGN_CTX)))) { - error_print(); - return 0; - } - memset((SM2_SIGN_CTX *)sm2_sign_ctx, 0, sizeof(SM2_SIGN_CTX)); - return sm2_sign_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1ctx_1free( - JNIEnv *env, jclass this, - jlong sm2_sign_ctx) -{ - if (sm2_sign_ctx) { - gmssl_secure_clear((SM2_SIGN_CTX *)sm2_sign_ctx, sizeof(SM2_SIGN_CTX)); - free((SM2_SIGN_CTX *)sm2_sign_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_init - * Signature: (JJLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1init( - JNIEnv *env, jclass this, - jlong sm2_sign_ctx, jlong sm2_key, jstring id) -{ - int ret = -1; - const char *id_str = NULL; - - if (!sm2_sign_ctx) { - error_print(); - return -1; - } - if (!sm2_key) { - error_print(); - return -1; - } - if (!(id_str = (*env)->GetStringUTFChars(env, id, NULL))) { - error_print(); - return -1; - } - if (sm2_sign_init((SM2_SIGN_CTX *)sm2_sign_ctx, (SM2_KEY *)sm2_key, id_str, strlen(id_str)) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseStringUTFChars(env, id, id_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1update( - JNIEnv *env, jclass this, - jlong sm2_sign_ctx, jbyteArray data, jint offset, jint length) -{ - jint ret = -1; - jbyte *buf = NULL; - jsize buflen; - - if (!sm2_sign_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, data, NULL))) { - error_print(); - return -1; - } - if (check_buf(buf, (*env)->GetArrayLength(env, data), offset, length) != 1) { - error_print(); - goto end; - } - if (sm2_sign_update((SM2_SIGN_CTX *)sm2_sign_ctx, (uint8_t *)buf + offset, (size_t)length) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, data, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_finish - * Signature: (J)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1finish( - JNIEnv *env, jclass this, - jlong sm2_sign_ctx) -{ - jbyteArray ret = NULL; - uint8_t sig[SM2_MAX_SIGNATURE_SIZE]; - size_t siglen; - - if (!sm2_sign_ctx) { - error_print(); - return NULL; - } - if (sm2_sign_finish((SM2_SIGN_CTX *)sm2_sign_ctx, sig, &siglen) != 1) { - error_print(); - return NULL; - } - if (!(ret = (*env)->NewByteArray(env, siglen))) { - error_print(); - return NULL; - } - (*env)->SetByteArrayRegion(env, ret, 0, siglen, (jbyte *)sig); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify_init - * Signature: (JJLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify_1init( - JNIEnv *env, jclass this, - jlong sm2_sign_ctx, jlong sm2_pub, jstring id) -{ - int ret = -1; - const char *id_str = NULL; - - if (!sm2_sign_ctx) { - error_print(); - return -1; - } - if (!sm2_pub) { - error_print(); - return -1; - } - if (!(id_str = (*env)->GetStringUTFChars(env, id, NULL))) { - error_print(); - return -1; - } - if (sm2_verify_init((SM2_SIGN_CTX *)sm2_sign_ctx, (SM2_KEY *)sm2_pub, id_str, strlen(id_str)) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseStringUTFChars(env, id, id_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify_1update( - JNIEnv *env, jclass this, - jlong sm2_sign_ctx, jbyteArray data, jint offset, jint length) -{ - jint ret = -1; - jbyte *buf = NULL; - jsize buflen; - - if (!sm2_sign_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, data, NULL))) { - error_print(); - return -1; - } - if (check_buf(buf, (*env)->GetArrayLength(env, data), offset, length) != 1) { - error_print(); - goto end; - } - if (sm2_verify_update((SM2_SIGN_CTX *)sm2_sign_ctx, (uint8_t *)buf + offset, (size_t)length) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, data, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify_finish - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify_1finish( - JNIEnv *env, jclass this, - jlong sm2_sign_ctx, jbyteArray sig) -{ - jint ret = -1; - jbyte *sigbuf = NULL; - jsize siglen; - - if (!sm2_sign_ctx) { - error_print(); - return -1; - } - if (!(sigbuf = (*env)->GetByteArrayElements(env, sig, NULL))) { - error_print(); - return -1; - } - siglen = (*env)->GetArrayLength(env, sig); - if ((ret = sm2_verify_finish((SM2_SIGN_CTX *)sm2_sign_ctx, (uint8_t *)sigbuf, (size_t)siglen)) < 0) { - error_print(); - goto end; - } -end: - (*env)->ReleaseByteArrayElements(env, sig, sigbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_generate - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1generate( - JNIEnv *env, jclass this) -{ - jlong sm9_sign_master_key; - - if (!(sm9_sign_master_key = (jlong)malloc(sizeof(SM9_SIGN_MASTER_KEY)))) { - error_print(); - return 0; - } - if (sm9_sign_master_key_generate((SM9_SIGN_MASTER_KEY *)sm9_sign_master_key) != 1) { - gmssl_secure_clear((SM9_SIGN_MASTER_KEY *)sm9_sign_master_key, sizeof(SM9_SIGN_MASTER_KEY)); - error_print(); - return 0; - } - return sm9_sign_master_key; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1free( - JNIEnv *env, jclass this, - jlong sm9_sign_master_key) -{ - if (sm9_sign_master_key) { - gmssl_secure_clear((SM9_SIGN_MASTER_KEY *)sm9_sign_master_key, sizeof(SM9_SIGN_MASTER_KEY)); - free((SM9_SIGN_MASTER_KEY *)sm9_sign_master_key); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1info_1encrypt_1to_1pem( - JNIEnv *env, jclass this, - jlong sm9_sign_master_key, jstring pass, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!sm9_sign_master_key) { - error_print(); - return -1; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm9_sign_master_key_info_encrypt_to_pem((SM9_SIGN_MASTER_KEY *)sm9_sign_master_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1info_1decrypt_1from_1pem( - JNIEnv *env, jclass this, - jstring pass, jstring file) -{ - jlong ret = 0; - SM9_SIGN_MASTER_KEY *sm9_sign_master_key = NULL; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!(sm9_sign_master_key = (SM9_SIGN_MASTER_KEY *)malloc(sizeof(SM9_SIGN_MASTER_KEY)))) { - error_print(); - return 0; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm9_sign_master_key_info_decrypt_from_pem(sm9_sign_master_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_sign_master_key; - sm9_sign_master_key = NULL; -end: - if (fp) fclose(fp); - if (sm9_sign_master_key) { - gmssl_secure_clear(sm9_sign_master_key, sizeof(SM9_SIGN_MASTER_KEY)); - free(sm9_sign_master_key); - } - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_public_key_to_pem - * Signature: (JLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1public_1key_1to_1pem( - JNIEnv *env, jclass this, - jlong sm9_sign_master_pub, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *file_str = NULL; - - if (!sm9_sign_master_pub) { - error_print(); - return -1; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm9_sign_master_public_key_to_pem((SM9_SIGN_MASTER_KEY *)sm9_sign_master_pub, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_public_key_from_pem - * Signature: (Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1public_1key_1from_1pem( - JNIEnv *env, jclass this, - jstring file) -{ - jlong ret = 0; - SM9_SIGN_MASTER_KEY *sm9_sign_master_pub = NULL; - FILE *fp = NULL; - const char *file_str = NULL; - - if (!(sm9_sign_master_pub = (SM9_SIGN_MASTER_KEY *)malloc(sizeof(SM9_SIGN_MASTER_KEY)))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm9_sign_master_public_key_from_pem(sm9_sign_master_pub, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_sign_master_pub; - sm9_sign_master_pub = NULL; -end: - if (fp) fclose(fp); - if (sm9_sign_master_pub) { - gmssl_secure_clear(sm9_sign_master_pub, sizeof(SM9_SIGN_MASTER_KEY)); - free(sm9_sign_master_pub); - } - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_extract_key - * Signature: (JLjava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1extract_1key( - JNIEnv *env, jclass this, - jlong sm9_sign_master_key, jstring id) -{ - jlong ret = 0; - SM9_SIGN_KEY *sm9_sign_key = NULL; - const char *id_str = NULL; - - if (!sm9_sign_master_key) { - error_print(); - return 0; - } - if (!(id_str = (*env)->GetStringUTFChars(env, id, 0))) { - error_print(); - goto end; - } - if (!(sm9_sign_key = (SM9_SIGN_KEY *)malloc(sizeof(SM9_SIGN_KEY)))) { - error_print(); - goto end; - } - if (sm9_sign_master_key_extract_key((SM9_SIGN_MASTER_KEY *)sm9_sign_master_key, - id_str, strlen(id_str), sm9_sign_key) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_sign_key; - sm9_sign_key = NULL; -end: - if (id_str) (*env)->ReleaseStringUTFChars(env, id, id_str); - if (sm9_sign_key) { - gmssl_secure_clear(sm9_sign_key, sizeof(SM9_SIGN_KEY)); - free(sm9_sign_key); - } - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1key_1free( - JNIEnv *env, jclass this, - jlong sm9_sign_key) -{ - if (sm9_sign_key) { - gmssl_secure_clear((SM9_SIGN_KEY *)sm9_sign_key, sizeof(SM9_SIGN_KEY)); - free((SM9_SIGN_KEY *)sm9_sign_key); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1key_1info_1encrypt_1to_1pem( - JNIEnv *env, jclass this, - jlong sm9_sign_key, jstring pass, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!sm9_sign_key) { - error_print(); - return -1; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm9_sign_key_info_encrypt_to_pem((SM9_SIGN_KEY *)sm9_sign_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1key_1info_1decrypt_1from_1pem( - JNIEnv *env, jclass this, - jstring pass, jstring file) -{ - jlong ret = 0; - SM9_SIGN_KEY *sm9_sign_key = NULL; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!(sm9_sign_key = (SM9_SIGN_KEY *)malloc(sizeof(SM9_SIGN_KEY)))) { - error_print(); - return 0; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm9_sign_key_info_decrypt_from_pem(sm9_sign_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_sign_key; - sm9_sign_key = NULL; -end: - if (fp) fclose(fp); - if (sm9_sign_key) { - gmssl_secure_clear(sm9_sign_key, sizeof(SM9_SIGN_KEY)); - free(sm9_sign_key); - } - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1ctx_1new( - JNIEnv *env, jclass this) -{ - jlong sm9_sign_ctx; - - if (!(sm9_sign_ctx = (jlong)malloc(sizeof(SM9_SIGN_CTX)))) { - error_print(); - return 0; - } - memset((SM9_SIGN_CTX *)sm9_sign_ctx, 0, sizeof(SM9_SIGN_CTX)); - return sm9_sign_ctx; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1ctx_1free( - JNIEnv *env, jclass this, - jlong sm9_sign_ctx) -{ - if (sm9_sign_ctx) { - gmssl_secure_clear((SM9_SIGN_CTX *)sm9_sign_ctx, sizeof(SM9_SIGN_CTX)); - free((SM9_SIGN_CTX *)sm9_sign_ctx); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_init - * Signature: (J)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1init( - JNIEnv *env, jclass this, - jlong sm9_sign_ctx) -{ - if (!sm9_sign_ctx) { - error_print(); - return -1; - } - if (sm9_sign_init((SM9_SIGN_CTX *)sm9_sign_ctx) != 1) { - error_print(); - return -1; - } - return 1; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1update( - JNIEnv *env, jclass this, - jlong sm9_sign_ctx, jbyteArray data, jint offset, jint length) -{ - jint ret = -1; - jbyte *buf = NULL; - jsize buflen; - - if (!sm9_sign_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, data, NULL))) { - error_print(); - goto end; - } - if (check_buf(buf, (*env)->GetArrayLength(env, data), offset, length) != 1) { - error_print(); - goto end; - } - if (sm9_sign_update((SM9_SIGN_CTX *)sm9_sign_ctx, (uint8_t *)buf + offset, (size_t)length) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, data, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_finish - * Signature: (JJ)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1finish( - JNIEnv *env, jclass this, - jlong sm9_sign_ctx, jlong sm9_sign_key) -{ - jbyteArray ret = NULL; - uint8_t sig[SM9_SIGNATURE_SIZE]; - size_t siglen; - - if (!sm9_sign_ctx) { - error_print(); - return NULL; - } - if (!sm9_sign_key) { - error_print(); - return NULL; - } - if (sm9_sign_finish((SM9_SIGN_CTX *)sm9_sign_ctx, (SM9_SIGN_KEY *)sm9_sign_key, sig, &siglen) != 1) { - error_print(); - return NULL; - } - if (!(ret = (*env)->NewByteArray(env, siglen))) { - error_print(); - return NULL; - } - (*env)->SetByteArrayRegion(env, ret, 0, siglen, (jbyte *)sig); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_verify_init - * Signature: (J)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1verify_1init( - JNIEnv *env, jclass this, - jlong sm9_sign_ctx) -{ - if (!sm9_sign_ctx) { - error_print(); - return -1; - } - if (sm9_verify_init((SM9_SIGN_CTX *)sm9_sign_ctx) != 1) { - error_print(); - return -1; - } - return 1; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_verify_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1verify_1update( - JNIEnv *env, jclass this, - jlong sm9_sign_ctx, jbyteArray data, jint offset, jint length) -{ - jint ret = -1; - jbyte *buf = NULL; - jsize buflen; - - if (!sm9_sign_ctx) { - error_print(); - return -1; - } - if (!(buf = (*env)->GetByteArrayElements(env, data, NULL))) { - error_print(); - return -1; - } - if (check_buf(buf, (*env)->GetArrayLength(env, data), offset, length) != 1) { - error_print(); - goto end; - } - if (sm9_verify_update((SM9_SIGN_CTX *)sm9_sign_ctx, (uint8_t *)buf + offset, (size_t)length) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, data, buf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_verify_finish - * Signature: (J[BJLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1verify_1finish( - JNIEnv *env, jclass this, - jlong sm9_sign_ctx, jbyteArray sig, jlong sm9_sign_master_pub, jstring id) -{ - jint ret = -1; - jbyte *sigbuf = NULL; - jsize siglen; - const char *id_str = NULL; - - if (!sm9_sign_ctx) { - error_print(); - return -1; - } - if (!sm9_sign_master_pub) { - error_print(); - return -1; - } - if (!(sigbuf = (*env)->GetByteArrayElements(env, sig, NULL))) { - error_print(); - return -1; - } - siglen = (*env)->GetArrayLength(env, sig); - if (!(id_str = (*env)->GetStringUTFChars(env, id, 0))) { - error_print(); - goto end; - } - if ((ret = sm9_verify_finish((SM9_SIGN_CTX *)sm9_sign_ctx, (uint8_t *)sigbuf, (size_t)siglen, - (SM9_SIGN_MASTER_KEY *)sm9_sign_master_pub, id_str, strlen(id_str))) < 0) { - error_print(); - goto end; - } -end: - (*env)->ReleaseByteArrayElements(env, sig, sigbuf, JNI_ABORT); - if (id_str) (*env)->ReleaseStringUTFChars(env, id, id_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_generate - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1generate( - JNIEnv * env, jclass this) -{ - jlong sm9_enc_master_key; - - if (!(sm9_enc_master_key = (jlong)malloc(sizeof(SM9_ENC_MASTER_KEY)))) { - error_print(); - return 0; - } - if (sm9_enc_master_key_generate((SM9_ENC_MASTER_KEY *)sm9_enc_master_key) != 1) { - gmssl_secure_clear((SM9_ENC_MASTER_KEY *)sm9_enc_master_key, sizeof(SM9_ENC_MASTER_KEY)); - error_print(); - return 0; - } - return sm9_enc_master_key; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1free( - JNIEnv *env, jclass this, - jlong sm9_enc_master_key) -{ - if (sm9_enc_master_key) { - gmssl_secure_clear((SM9_ENC_MASTER_KEY *)sm9_enc_master_key, sizeof(SM9_ENC_MASTER_KEY)); - free((SM9_ENC_MASTER_KEY *)sm9_enc_master_key); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1info_1encrypt_1to_1pem( - JNIEnv *env, jclass this, - jlong sm9_enc_master_key, jstring pass, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!sm9_enc_master_key) { - error_print(); - return -1; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm9_enc_master_key_info_encrypt_to_pem((SM9_ENC_MASTER_KEY *)sm9_enc_master_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1info_1decrypt_1from_1pem( - JNIEnv *env, jclass this, - jstring pass, jstring file) -{ - jlong ret = 0; - SM9_ENC_MASTER_KEY *sm9_enc_master_key = NULL; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!(sm9_enc_master_key = (SM9_ENC_MASTER_KEY *)malloc(sizeof(SM9_ENC_MASTER_KEY)))) { - error_print(); - return 0; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm9_enc_master_key_info_decrypt_from_pem(sm9_enc_master_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_enc_master_key; - sm9_enc_master_key = NULL; -end: - if (fp) fclose(fp); - if (sm9_enc_master_key) { - gmssl_secure_clear(sm9_enc_master_key, sizeof(SM9_ENC_MASTER_KEY)); - free(sm9_enc_master_key); - } - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; - return 0; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_public_key_to_pem - * Signature: (JLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1public_1key_1to_1pem( - JNIEnv *env, jclass this, - jlong sm9_enc_master_pub, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *file_str = NULL; - - if (!sm9_enc_master_pub) { - error_print(); - return -1; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm9_enc_master_public_key_to_pem((SM9_ENC_MASTER_KEY *)sm9_enc_master_pub, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_public_key_from_pem - * Signature: (Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1public_1key_1from_1pem( - JNIEnv *env, jclass this, - jstring file) -{ - jlong ret = 0; - SM9_ENC_MASTER_KEY *sm9_enc_master_pub = NULL; - FILE *fp = NULL; - const char *file_str = NULL; - - if (!(sm9_enc_master_pub = (SM9_ENC_MASTER_KEY *)malloc(sizeof(SM9_ENC_MASTER_KEY)))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm9_enc_master_public_key_from_pem(sm9_enc_master_pub, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_enc_master_pub; - sm9_enc_master_pub = NULL; -end: - if (fp) fclose(fp); - if (sm9_enc_master_pub) { - gmssl_secure_clear(sm9_enc_master_pub, sizeof(SM9_ENC_MASTER_KEY)); - free(sm9_enc_master_pub); - } - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_extract_key - * Signature: (JLjava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1extract_1key( - JNIEnv *env, jclass this, - jlong sm9_enc_master_key, jstring id) -{ - jlong ret = 0; - SM9_ENC_KEY *sm9_enc_key = NULL; - const char *id_str = NULL; - - if (!sm9_enc_master_key) { - error_print(); - return 0; - } - if (!(id_str = (*env)->GetStringUTFChars(env, id, 0))) { - error_print(); - goto end; - } - if (!(sm9_enc_key = (SM9_ENC_KEY *)malloc(sizeof(SM9_ENC_KEY)))) { - error_print(); - goto end; - } - if (sm9_enc_master_key_extract_key((SM9_ENC_MASTER_KEY *)sm9_enc_master_key, - id_str, strlen(id_str), sm9_enc_key) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_enc_key; - sm9_enc_key = NULL; -end: - if (id_str) (*env)->ReleaseStringUTFChars(env, id, id_str); - if (sm9_enc_key) { - gmssl_secure_clear(sm9_enc_key, sizeof(SM9_ENC_KEY)); - free(sm9_enc_key); - } - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1key_1free( - JNIEnv *env, jclass this, - jlong sm9_enc_key) -{ - if (sm9_enc_key) { - gmssl_secure_clear((SM9_ENC_KEY *)sm9_enc_key, sizeof(SM9_ENC_KEY)); - free((SM9_ENC_KEY *)sm9_enc_key); - } -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1key_1info_1encrypt_1to_1pem( - JNIEnv *env, jclass this, - jlong sm9_enc_key, jstring pass, jstring file) -{ - jint ret = -1; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!sm9_enc_key) { - error_print(); - return -1; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (sm9_enc_key_info_encrypt_to_pem((SM9_ENC_KEY *)sm9_enc_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - if (fp) fclose(fp); - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1key_1info_1decrypt_1from_1pem( - JNIEnv *env, jclass this, - jstring pass, jstring file) -{ - jlong ret = 0; - SM9_ENC_KEY *sm9_enc_key = NULL; - FILE *fp = NULL; - const char *pass_str = NULL; - const char *file_str = NULL; - - if (!(sm9_enc_key = (SM9_ENC_KEY *)malloc(sizeof(SM9_ENC_KEY)))) { - error_print(); - return 0; - } - if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { - error_print(); - goto end; - } - if (!(file_str = (*env)->GetStringUTFChars(env, file, 0))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "rb"))) { - error_print(); - goto end; - } - if (sm9_enc_key_info_decrypt_from_pem(sm9_enc_key, pass_str, fp) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm9_enc_key; - sm9_enc_key = NULL; -end: - if (fp) fclose(fp); - if (sm9_enc_key) { - gmssl_secure_clear(sm9_enc_key, sizeof(SM9_ENC_KEY)); - free(sm9_enc_key); - } - if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_encrypt - * Signature: (JLjava/lang/String;[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm9_1encrypt( - JNIEnv *env, jclass this, - jlong sm9_enc_master_pub, jstring id, jbyteArray in) -{ - jbyteArray ret = NULL; - const char *id_str = NULL; - jbyte *inbuf = NULL; - jsize inlen; - uint8_t outbuf[SM9_MAX_CIPHERTEXT_SIZE]; - size_t outlen; - - if (!sm9_enc_master_pub) { - error_print(); - return NULL; - } - if (!(id_str = (*env)->GetStringUTFChars(env, id, NULL))) { - error_print(); - return NULL; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, 0))) { - error_print(); - goto end; - } - inlen = (*env)->GetArrayLength(env, in); - if (sm9_encrypt((SM9_ENC_MASTER_KEY *)sm9_enc_master_pub, id_str, strlen(id_str), - (uint8_t *)inbuf, (size_t)inlen, outbuf, &outlen) != 1) { - error_print(); - goto end; - } - if (!(ret = (*env)->NewByteArray(env, outlen))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, outlen, (jbyte *)outbuf); -end: - (*env)->ReleaseStringUTFChars(env, id, id_str); - if (inbuf) (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_decrypt - * Signature: (JLjava/lang/String;[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm9_1decrypt( - JNIEnv *env, jclass this, - jlong sm9_enc_key, jstring id, jbyteArray in) -{ - jbyteArray ret = NULL; - const char *id_str = NULL; - jbyte *inbuf = NULL; - jsize inlen; - uint8_t outbuf[SM9_MAX_CIPHERTEXT_SIZE]; - size_t outlen; - - if (!sm9_enc_key) { - error_print(); - return NULL; - } - if (!(id_str = (*env)->GetStringUTFChars(env, id, NULL))) { - error_print(); - return NULL; - } - if (!(inbuf = (*env)->GetByteArrayElements(env, in, NULL))) { - error_print(); - goto end; - } - inlen = (*env)->GetArrayLength(env, in); - if (sm9_decrypt((SM9_ENC_KEY *)sm9_enc_key, id_str, strlen(id_str), - (uint8_t *)inbuf, (size_t)inlen, outbuf, &outlen) != 1) { - error_print(); - goto end; - } - if (!(ret = (*env)->NewByteArray(env, outlen))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, outlen, (jbyte *)outbuf); -end: - (*env)->ReleaseStringUTFChars(env, id, id_str); - if (inbuf) (*env)->ReleaseByteArrayElements(env, in, inbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_from_pem - * Signature: (Ljava/lang/String;)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1from_1pem( - JNIEnv *env, jclass this, jstring file) -{ - jbyteArray ret = NULL; - const char *file_str = NULL; - uint8_t *cert = NULL; - size_t certlen; - - if (!(file_str = (*env)->GetStringUTFChars(env, file, NULL))) { - error_print(); - return 0; - } - if (x509_cert_new_from_file(&cert, &certlen, file_str) != 1) { - error_print(); - goto end; - } - if (!(ret = (*env)->NewByteArray(env, certlen))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, certlen, (jbyte *)cert); -end: - (*env)->ReleaseStringUTFChars(env, file, file_str); - if (cert) free(cert); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_to_pem - * Signature: ([BLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_cert_1to_1pem( - JNIEnv *env, jclass this, jbyteArray cert, jstring file) -{ - jint ret = -1; - jbyte *certbuf; - jsize certlen; - const char *file_str = NULL; - FILE *fp = NULL; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return -1; - } - certlen = (*env)->GetArrayLength(env, cert); - if (!(file_str = (*env)->GetStringUTFChars(env, file, NULL))) { - error_print(); - goto end; - } - if (!(fp = fopen(file_str, "wb"))) { - error_print(); - goto end; - } - if (x509_cert_to_pem((uint8_t *)certbuf, (size_t)certlen, fp) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - if (file_str) (*env)->ReleaseStringUTFChars(env, file, file_str); - if (fp) fclose(fp); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_serial_number - * Signature: ([B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1serial_1number( - JNIEnv *env, jclass this, jbyteArray cert) -{ - jbyteArray ret = NULL; - jbyte *certbuf; - jsize certlen; - const uint8_t *serial; - size_t serial_len; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return NULL; - } - certlen = (*env)->GetArrayLength(env, cert); - if (x509_cert_get_issuer_and_serial_number((uint8_t *)certbuf, certlen, - NULL, NULL, &serial, &serial_len) != 1) { - error_print(); - goto end; - } - if (!(ret = (*env)->NewByteArray(env, serial_len))) { - error_print(); - goto end; - } - (*env)->SetByteArrayRegion(env, ret, 0, serial_len, (jbyte *)serial); -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - return ret; -} - -static int gmssl_name_cnt(const uint8_t *d, size_t dlen, int *count) -{ - int cnt = 0; - - while (dlen) { - const uint8_t *rdn; - size_t rdnlen; - - if (asn1_set_from_der(&rdn, &rdnlen, &d, &dlen) != 1) { - error_print(); - return -1; - } - while (rdnlen) { - const uint8_t *p; - size_t len; - - if (asn1_sequence_from_der(&p, &len, &rdn, &rdnlen) != 1) { - error_print(); - return -1; - } - cnt++; - } - } - *count = cnt; - return 1; -} - -static int gmssl_parse_attr_type_and_value(JNIEnv *env, jobjectArray arr, int *index, const uint8_t *d, size_t dlen) -{ - int oid, tag; - const uint8_t *val; - size_t vlen; - char *c_str = NULL; - size_t c_str_len; - jstring str = NULL; - - - if (x509_name_type_from_der(&oid, &d, &dlen) != 1) { - error_print(); - return -1; - } - c_str_len = strlen(x509_name_type_name(oid)) + 1; - - if (oid == OID_email_address) { - if (asn1_ia5_string_from_der((const char **)&val, &vlen, &d, &dlen) != 1) { - error_print(); - return -1; - } - } else { - if (x509_directory_name_from_der(&tag, &val, &vlen, &d, &dlen) != 1) { - error_print(); - return -1; - } - } - c_str_len += vlen + 1; - - if (asn1_length_is_zero(dlen) != 1) { - error_print(); - return -1; - } - - if (!(c_str = malloc(c_str_len))) { - error_print(); - return -1; - } - strcpy(c_str, x509_name_type_name(oid)); - c_str[strlen(x509_name_type_name(oid))] = ':'; - memcpy(c_str + strlen(x509_name_type_name(oid)) + 1, val, vlen); - c_str[c_str_len-1] = 0; - - if (!(str = (*env)->NewStringUTF(env, c_str))) { - error_print(); - return -1; - } - free(c_str); - (*env)->SetObjectArrayElement(env, arr, *index, str); - (*index)++; - return 1; -} - -static int gmssl_parse_rdn(JNIEnv *env, jobjectArray arr, int *index, const uint8_t *d, size_t dlen) -{ - const uint8_t *p; - size_t len; - - while (dlen) { - if (asn1_sequence_from_der(&p, &len, &d, &dlen) != 1) { - error_print(); - return -1; - } - if (gmssl_parse_attr_type_and_value(env, arr, index, p, len) != 1) { - error_print(); - return -1; - } - } - return 1; -} - -static int gmssl_parse_name(JNIEnv *env, jobjectArray arr, const uint8_t *d, size_t dlen) -{ - const uint8_t *p; - size_t len; - int index = 0; - - while (dlen) { - if (asn1_set_from_der(&p, &len, &d, &dlen) != 1) { - error_print(); - return -1; - } - if (gmssl_parse_rdn(env, arr, &index, p, len) != 1) { - error_print(); - return -1; - } - } - return 1; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_issuer - * Signature: ([B)[Ljava/lang/String; - */ -JNIEXPORT jobjectArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1issuer( - JNIEnv *env, jclass this, jbyteArray cert) -{ - jobjectArray ret = NULL; - jobjectArray arr = NULL; - jbyte *certbuf; - jsize certlen; - const uint8_t *name; - size_t namelen; - int cnt; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return NULL; - } - certlen = (*env)->GetArrayLength(env, cert); - if (x509_cert_get_issuer((uint8_t *)certbuf, certlen, &name, &namelen) != 1) { - error_print(); - goto end; - } - if (gmssl_name_cnt(name, namelen, &cnt) != 1) { - error_print(); - goto end; - } - if (!(arr = (*env)->NewObjectArray(env, cnt, (*env)->FindClass(env, "java/lang/String"), 0))) { - error_print(); - goto end; - } - if (gmssl_parse_name(env, arr, name, namelen) != 1) { - error_print(); - //goto end; - // FIXME: how to release arr ??? - } - ret = arr; - arr = NULL; -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - return ret; -} -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_subject - * Signature: ([B)[Ljava/lang/String; - */ -JNIEXPORT jobjectArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1subject( - JNIEnv *env, jclass this, jbyteArray cert) -{ - jobjectArray ret = NULL; - jobjectArray arr = NULL; - jbyte *certbuf; - jsize certlen; - const uint8_t *name; - size_t namelen; - int cnt; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return NULL; - } - certlen = (*env)->GetArrayLength(env, cert); - if (x509_cert_get_subject((uint8_t *)certbuf, certlen, &name, &namelen) != 1) { - error_print(); - goto end; - } - if (gmssl_name_cnt(name, namelen, &cnt) != 1) { - error_print(); - goto end; - } - if (!(arr = (*env)->NewObjectArray(env, cnt, (*env)->FindClass(env, "java/lang/String"), 0))) { - error_print(); - goto end; - } - if (gmssl_parse_name(env, arr, name, namelen) != 1) { - error_print(); - //goto end; - // FIXME: how to release arr ??? - } - ret = arr; - arr = NULL; -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - return ret; -} - - -#define x509_cert_get_validity(cert,certlen,not_before,not_after) \ - x509_cert_get_details(cert,certlen,\ - NULL,\ - NULL,NULL,\ - NULL,\ - NULL,NULL,\ - not_before,not_after,\ - NULL,NULL,\ - NULL,\ - NULL,NULL,\ - NULL,NULL,\ - NULL,NULL,\ - NULL,\ - NULL,NULL) - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_not_before - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1not_1before( - JNIEnv *env, jclass this, jbyteArray cert) -{ - jlong ret = -1; - jbyte *certbuf; - jsize certlen; - time_t not_before, not_after; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return -1; - } - certlen = (*env)->GetArrayLength(env, cert); - if (x509_cert_get_validity((uint8_t *)certbuf, certlen, ¬_before, ¬_after) != 1) { - error_print(); - goto end; - } - ret = (jlong)not_before; -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_not_after - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1not_1after( - JNIEnv *env, jclass this, jbyteArray cert) -{ - jlong ret = -1; - jbyte *certbuf; - jsize certlen; - time_t not_before, not_after; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return -1; - } - certlen = (*env)->GetArrayLength(env, cert); - if (x509_cert_get_validity((uint8_t *)certbuf, certlen, ¬_before, ¬_after) != 1) { - error_print(); - goto end; - } - ret = (jlong)not_after; -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_subject_public_key - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1subject_1public_1key( - JNIEnv *env, jclass this, jbyteArray cert) -{ - jlong ret = 0; - jbyte *certbuf; - jsize certlen; - SM2_KEY *sm2_pub = NULL; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return -1; - } - certlen = (*env)->GetArrayLength(env, cert); - if (!(sm2_pub = (SM2_KEY *)malloc(sizeof(SM2_KEY)))) { - error_print(); - goto end; - } - memset(sm2_pub, 0, sizeof(SM2_KEY)); - if (x509_cert_get_subject_public_key((uint8_t *)certbuf, certlen, sm2_pub) != 1) { - error_print(); - goto end; - } - ret = (jlong)sm2_pub; - sm2_pub = NULL; -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - if (sm2_pub) free(sm2_pub); - return ret; -} - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_verify_by_ca_cert - * Signature: ([B[BLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_cert_1verify_1by_1ca_1cert( - JNIEnv *env, jclass this, jbyteArray cert, jbyteArray cacert, jstring ca_sm2_id) -{ - jint ret = -1; - jbyte *certbuf = NULL; - jsize certlen; - jbyte *cacertbuf = NULL; - jsize cacertlen; - const char *id_str = NULL; - - if (!(certbuf = (*env)->GetByteArrayElements(env, cert, NULL))) { - error_print(); - return -1; - } - certlen = (*env)->GetArrayLength(env, cert); - if (!(cacertbuf = (*env)->GetByteArrayElements(env, cacert, NULL))) { - error_print(); - goto end; - } - cacertlen = (*env)->GetArrayLength(env, cacert); - if (!(id_str = (*env)->GetStringUTFChars(env, ca_sm2_id, NULL))) { - error_print(); - goto end; - } - if (x509_cert_verify_by_ca_cert((uint8_t *)certbuf, certlen, (uint8_t *)cacertbuf, cacertlen, - id_str, strlen(id_str)) != 1) { - error_print(); - goto end; - } - ret = 1; -end: - (*env)->ReleaseByteArrayElements(env, cert, certbuf, JNI_ABORT); - if (cacertbuf) (*env)->ReleaseByteArrayElements(env, cacert, cacertbuf, JNI_ABORT); - if (id_str) (*env)->ReleaseStringUTFChars(env, ca_sm2_id, id_str); - return ret; -} - diff --git a/gmssljni.h b/gmssljni.h deleted file mode 100644 index 9dd0b4c..0000000 --- a/gmssljni.h +++ /dev/null @@ -1,919 +0,0 @@ -/* DO NOT EDIT THIS FILE - it is machine generated */ -#include -/* Header for class org_gmssl_GmSSLJNI */ - -#ifndef _Included_org_gmssl_GmSSLJNI -#define _Included_org_gmssl_GmSSLJNI -#ifdef __cplusplus -extern "C" { -#endif -#undef org_gmssl_GmSSLJNI_SM3_DIGEST_SIZE -#define org_gmssl_GmSSLJNI_SM3_DIGEST_SIZE 32L -#undef org_gmssl_GmSSLJNI_SM3_HMAC_SIZE -#define org_gmssl_GmSSLJNI_SM3_HMAC_SIZE 32L -#undef org_gmssl_GmSSLJNI_SM3_HMAC_MIN_KEY_SIZE -#define org_gmssl_GmSSLJNI_SM3_HMAC_MIN_KEY_SIZE 16L -#undef org_gmssl_GmSSLJNI_SM4_KEY_SIZE -#define org_gmssl_GmSSLJNI_SM4_KEY_SIZE 16L -#undef org_gmssl_GmSSLJNI_SM4_BLOCK_SIZE -#define org_gmssl_GmSSLJNI_SM4_BLOCK_SIZE 16L -#undef org_gmssl_GmSSLJNI_SM4_GCM_MIN_IV_SIZE -#define org_gmssl_GmSSLJNI_SM4_GCM_MIN_IV_SIZE 1L -#undef org_gmssl_GmSSLJNI_SM4_GCM_MAX_IV_SIZE -#define org_gmssl_GmSSLJNI_SM4_GCM_MAX_IV_SIZE 64L -#undef org_gmssl_GmSSLJNI_SM4_GCM_DEFAULT_IV_SIZE -#define org_gmssl_GmSSLJNI_SM4_GCM_DEFAULT_IV_SIZE 12L -#undef org_gmssl_GmSSLJNI_SM4_GCM_MAX_TAG_SIZE -#define org_gmssl_GmSSLJNI_SM4_GCM_MAX_TAG_SIZE 16L -#undef org_gmssl_GmSSLJNI_SM2_MAX_PLAINTEXT_SIZE -#define org_gmssl_GmSSLJNI_SM2_MAX_PLAINTEXT_SIZE 255L -#undef org_gmssl_GmSSLJNI_SM9_MAX_PLAINTEXT_SIZE -#define org_gmssl_GmSSLJNI_SM9_MAX_PLAINTEXT_SIZE 255L -#undef org_gmssl_GmSSLJNI_ZUC_KEY_SIZE -#define org_gmssl_GmSSLJNI_ZUC_KEY_SIZE 16L -#undef org_gmssl_GmSSLJNI_ZUC_IV_SIZE -#define org_gmssl_GmSSLJNI_ZUC_IV_SIZE 16L -/* - * Class: org_gmssl_GmSSLJNI - * Method: version_num - * Signature: ()I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_version_1num - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: version_str - * Signature: ()Ljava/lang/String; - */ -JNIEXPORT jstring JNICALL Java_org_gmssl_GmSSLJNI_version_1str - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: rand_bytes - * Signature: ([BIJ)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_rand_1bytes - (JNIEnv *, jclass, jbyteArray, jint, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm3_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm3_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_init - * Signature: (J)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1init - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_finish - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1finish - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_init - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1init - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_hmac_finish - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1finish - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm3_pbkdf2 - * Signature: (Ljava/lang/String;[BII)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm3_1pbkdf2 - (JNIEnv *, jclass, jstring, jbyteArray, jint, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_key_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1key_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1key_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_set_encrypt_key - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1set_1encrypt_1key - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_set_decrypt_key - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1set_1decrypt_1key - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_encrypt - * Signature: (J[BI[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1encrypt - (JNIEnv *, jclass, jlong, jbyteArray, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_encrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1encrypt_1init - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1encrypt_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1encrypt_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_decrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1decrypt_1init - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_decrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1decrypt_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_cbc_decrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1cbc_1decrypt_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_encrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1encrypt_1init - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1encrypt_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1encrypt_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_decrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1init - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_decrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_ctr_decrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_encrypt_init - * Signature: (J[B[B[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1encrypt_1init - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1encrypt_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1encrypt_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_decrypt_init - * Signature: (J[B[B[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1decrypt_1init - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_decrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1decrypt_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm4_gcm_decrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1gcm_1decrypt_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_zuc_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_zuc_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_encrypt_init - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_zuc_1encrypt_1init - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_encrypt_update - * Signature: (J[BII[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_zuc_1encrypt_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: zuc_encrypt_finish - * Signature: (J[BI)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_zuc_1encrypt_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_key_generate - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1key_1generate - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm2_1key_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_to_der - * Signature: (J)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1to_1der - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_from_der - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1from_1der - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_to_der - * Signature: (J)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1to_1der - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_from_der - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1from_1der - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1encrypt_1to_1pem - (JNIEnv *, jclass, jlong, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_private_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1private_1key_1info_1decrypt_1from_1pem - (JNIEnv *, jclass, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_to_pem - * Signature: (JLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1to_1pem - (JNIEnv *, jclass, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_public_key_info_from_pem - * Signature: (Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1public_1key_1info_1from_1pem - (JNIEnv *, jclass, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_compute_z - * Signature: (JLjava/lang/String;[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1compute_1z - (JNIEnv *, jclass, jlong, jstring, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign - * Signature: (J[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify - * Signature: (J[B[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify - (JNIEnv *, jclass, jlong, jbyteArray, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_encrypt - * Signature: (J[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1encrypt - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_decrypt - * Signature: (J[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1decrypt - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_init - * Signature: (JJLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1init - (JNIEnv *, jclass, jlong, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_sign_finish - * Signature: (J)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm2_1sign_1finish - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify_init - * Signature: (JJLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify_1init - (JNIEnv *, jclass, jlong, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm2_verify_finish - * Signature: (J[B)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm2_1verify_1finish - (JNIEnv *, jclass, jlong, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_generate - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1generate - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1info_1encrypt_1to_1pem - (JNIEnv *, jclass, jlong, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1info_1decrypt_1from_1pem - (JNIEnv *, jclass, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_public_key_to_pem - * Signature: (JLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1public_1key_1to_1pem - (JNIEnv *, jclass, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_public_key_from_pem - * Signature: (Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1public_1key_1from_1pem - (JNIEnv *, jclass, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_master_key_extract_key - * Signature: (JLjava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1master_1key_1extract_1key - (JNIEnv *, jclass, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1key_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1key_1info_1encrypt_1to_1pem - (JNIEnv *, jclass, jlong, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1key_1info_1decrypt_1from_1pem - (JNIEnv *, jclass, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_ctx_new - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1ctx_1new - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_ctx_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1ctx_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_init - * Signature: (J)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1init - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_sign_finish - * Signature: (JJ)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm9_1sign_1finish - (JNIEnv *, jclass, jlong, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_verify_init - * Signature: (J)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1verify_1init - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_verify_update - * Signature: (J[BII)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1verify_1update - (JNIEnv *, jclass, jlong, jbyteArray, jint, jint); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_verify_finish - * Signature: (J[BJLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1verify_1finish - (JNIEnv *, jclass, jlong, jbyteArray, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_generate - * Signature: ()J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1generate - (JNIEnv *, jclass); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1info_1encrypt_1to_1pem - (JNIEnv *, jclass, jlong, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1info_1decrypt_1from_1pem - (JNIEnv *, jclass, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_public_key_to_pem - * Signature: (JLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1public_1key_1to_1pem - (JNIEnv *, jclass, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_public_key_from_pem - * Signature: (Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1public_1key_1from_1pem - (JNIEnv *, jclass, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_master_key_extract_key - * Signature: (JLjava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1master_1key_1extract_1key - (JNIEnv *, jclass, jlong, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_key_free - * Signature: (J)V - */ -JNIEXPORT void JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1key_1free - (JNIEnv *, jclass, jlong); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_key_info_encrypt_to_pem - * Signature: (JLjava/lang/String;Ljava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1key_1info_1encrypt_1to_1pem - (JNIEnv *, jclass, jlong, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_enc_key_info_decrypt_from_pem - * Signature: (Ljava/lang/String;Ljava/lang/String;)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_sm9_1enc_1key_1info_1decrypt_1from_1pem - (JNIEnv *, jclass, jstring, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_encrypt - * Signature: (JLjava/lang/String;[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm9_1encrypt - (JNIEnv *, jclass, jlong, jstring, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: sm9_decrypt - * Signature: (JLjava/lang/String;[B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm9_1decrypt - (JNIEnv *, jclass, jlong, jstring, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_from_pem - * Signature: (Ljava/lang/String;)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1from_1pem - (JNIEnv *, jclass, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_to_pem - * Signature: ([BLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_cert_1to_1pem - (JNIEnv *, jclass, jbyteArray, jstring); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_serial_number - * Signature: ([B)[B - */ -JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1serial_1number - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_issuer - * Signature: ([B)[Ljava/lang/String; - */ -JNIEXPORT jobjectArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1issuer - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_subject - * Signature: ([B)[Ljava/lang/String; - */ -JNIEXPORT jobjectArray JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1subject - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_not_before - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1not_1before - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_not_after - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1not_1after - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_get_subject_public_key - * Signature: ([B)J - */ -JNIEXPORT jlong JNICALL Java_org_gmssl_GmSSLJNI_cert_1get_1subject_1public_1key - (JNIEnv *, jclass, jbyteArray); - -/* - * Class: org_gmssl_GmSSLJNI - * Method: cert_verify_by_ca_cert - * Signature: ([B[BLjava/lang/String;)I - */ -JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_cert_1verify_1by_1ca_1cert - (JNIEnv *, jclass, jbyteArray, jbyteArray, jstring); - -#ifdef __cplusplus -} -#endif -#endif diff --git a/jni/jni.h b/jni/jni.h deleted file mode 100755 index b56fb7f..0000000 --- a/jni/jni.h +++ /dev/null @@ -1,1961 +0,0 @@ -/* - * @(#)jni.h 1.62 06/02/02 - * - * Copyright 2006 Sun Microsystems, Inc. All rights reserved. - * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. - */ - -/* - * We used part of Netscape's Java Runtime Interface (JRI) as the starting - * point of our design and implementation. - */ - -/****************************************************************************** - * Java Runtime Interface - * Copyright (c) 1996 Netscape Communications Corporation. All rights reserved. - *****************************************************************************/ - -#ifndef _JAVASOFT_JNI_H_ -#define _JAVASOFT_JNI_H_ - -#include -#include - -/* jni_md.h contains the machine-dependent typedefs for jbyte, jint - and jlong */ - -#include "jni_md.h" - -#ifdef __cplusplus -extern "C" { -#endif - -/* - * JNI Types - */ - -#ifndef JNI_TYPES_ALREADY_DEFINED_IN_JNI_MD_H - -typedef unsigned char jboolean; -typedef unsigned short jchar; -typedef short jshort; -typedef float jfloat; -typedef double jdouble; - -typedef jint jsize; - -#ifdef __cplusplus - -class _jobject {}; -class _jclass : public _jobject {}; -class _jthrowable : public _jobject {}; -class _jstring : public _jobject {}; -class _jarray : public _jobject {}; -class _jbooleanArray : public _jarray {}; -class _jbyteArray : public _jarray {}; -class _jcharArray : public _jarray {}; -class _jshortArray : public _jarray {}; -class _jintArray : public _jarray {}; -class _jlongArray : public _jarray {}; -class _jfloatArray : public _jarray {}; -class _jdoubleArray : public _jarray {}; -class _jobjectArray : public _jarray {}; - -typedef _jobject *jobject; -typedef _jclass *jclass; -typedef _jthrowable *jthrowable; -typedef _jstring *jstring; -typedef _jarray *jarray; -typedef _jbooleanArray *jbooleanArray; -typedef _jbyteArray *jbyteArray; -typedef _jcharArray *jcharArray; -typedef _jshortArray *jshortArray; -typedef _jintArray *jintArray; -typedef _jlongArray *jlongArray; -typedef _jfloatArray *jfloatArray; -typedef _jdoubleArray *jdoubleArray; -typedef _jobjectArray *jobjectArray; - -#else - -struct _jobject; - -typedef struct _jobject *jobject; -typedef jobject jclass; -typedef jobject jthrowable; -typedef jobject jstring; -typedef jobject jarray; -typedef jarray jbooleanArray; -typedef jarray jbyteArray; -typedef jarray jcharArray; -typedef jarray jshortArray; -typedef jarray jintArray; -typedef jarray jlongArray; -typedef jarray jfloatArray; -typedef jarray jdoubleArray; -typedef jarray jobjectArray; - -#endif - -typedef jobject jweak; - -typedef union jvalue { - jboolean z; - jbyte b; - jchar c; - jshort s; - jint i; - jlong j; - jfloat f; - jdouble d; - jobject l; -} jvalue; - -struct _jfieldID; -typedef struct _jfieldID *jfieldID; - -struct _jmethodID; -typedef struct _jmethodID *jmethodID; - -/* Return values from jobjectRefType */ -typedef enum _jobjectType { - JNIInvalidRefType = 0, - JNILocalRefType = 1, - JNIGlobalRefType = 2, - JNIWeakGlobalRefType = 3 -} jobjectRefType; - - -#endif /* JNI_TYPES_ALREADY_DEFINED_IN_JNI_MD_H */ - -/* - * jboolean constants - */ - -#define JNI_FALSE 0 -#define JNI_TRUE 1 - -/* - * possible return values for JNI functions. - */ - -#define JNI_OK 0 /* success */ -#define JNI_ERR (-1) /* unknown error */ -#define JNI_EDETACHED (-2) /* thread detached from the VM */ -#define JNI_EVERSION (-3) /* JNI version error */ -#define JNI_ENOMEM (-4) /* not enough memory */ -#define JNI_EEXIST (-5) /* VM already created */ -#define JNI_EINVAL (-6) /* invalid arguments */ - -/* - * used in ReleaseScalarArrayElements - */ - -#define JNI_COMMIT 1 -#define JNI_ABORT 2 - -/* - * used in RegisterNatives to describe native method name, signature, - * and function pointer. - */ - -typedef struct { - char *name; - char *signature; - void *fnPtr; -} JNINativeMethod; - -/* - * JNI Native Method Interface. - */ - -struct JNINativeInterface_; - -struct JNIEnv_; - -#ifdef __cplusplus -typedef JNIEnv_ JNIEnv; -#else -typedef const struct JNINativeInterface_ *JNIEnv; -#endif - -/* - * JNI Invocation Interface. - */ - -struct JNIInvokeInterface_; - -struct JavaVM_; - -#ifdef __cplusplus -typedef JavaVM_ JavaVM; -#else -typedef const struct JNIInvokeInterface_ *JavaVM; -#endif - -struct JNINativeInterface_ { - void *reserved0; - void *reserved1; - void *reserved2; - - void *reserved3; - -#if !TARGET_RT_MAC_CFM && defined(__ppc__) - void* cfm_vectors[225]; -#endif /* !TARGET_RT_MAC_CFM && defined(__ppc__) */ - - jint (JNICALL *GetVersion)(JNIEnv *env); - - jclass (JNICALL *DefineClass) - (JNIEnv *env, const char *name, jobject loader, const jbyte *buf, - jsize len); - jclass (JNICALL *FindClass) - (JNIEnv *env, const char *name); - - jmethodID (JNICALL *FromReflectedMethod) - (JNIEnv *env, jobject method); - jfieldID (JNICALL *FromReflectedField) - (JNIEnv *env, jobject field); - - jobject (JNICALL *ToReflectedMethod) - (JNIEnv *env, jclass cls, jmethodID methodID, jboolean isStatic); - - jclass (JNICALL *GetSuperclass) - (JNIEnv *env, jclass sub); - jboolean (JNICALL *IsAssignableFrom) - (JNIEnv *env, jclass sub, jclass sup); - - jobject (JNICALL *ToReflectedField) - (JNIEnv *env, jclass cls, jfieldID fieldID, jboolean isStatic); - - jint (JNICALL *Throw) - (JNIEnv *env, jthrowable obj); - jint (JNICALL *ThrowNew) - (JNIEnv *env, jclass clazz, const char *msg); - jthrowable (JNICALL *ExceptionOccurred) - (JNIEnv *env); - void (JNICALL *ExceptionDescribe) - (JNIEnv *env); - void (JNICALL *ExceptionClear) - (JNIEnv *env); - void (JNICALL *FatalError) - (JNIEnv *env, const char *msg); - - jint (JNICALL *PushLocalFrame) - (JNIEnv *env, jint capacity); - jobject (JNICALL *PopLocalFrame) - (JNIEnv *env, jobject result); - - jobject (JNICALL *NewGlobalRef) - (JNIEnv *env, jobject lobj); - void (JNICALL *DeleteGlobalRef) - (JNIEnv *env, jobject gref); - void (JNICALL *DeleteLocalRef) - (JNIEnv *env, jobject obj); - jboolean (JNICALL *IsSameObject) - (JNIEnv *env, jobject obj1, jobject obj2); - jobject (JNICALL *NewLocalRef) - (JNIEnv *env, jobject ref); - jint (JNICALL *EnsureLocalCapacity) - (JNIEnv *env, jint capacity); - - jobject (JNICALL *AllocObject) - (JNIEnv *env, jclass clazz); - jobject (JNICALL *NewObject) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jobject (JNICALL *NewObjectV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jobject (JNICALL *NewObjectA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jclass (JNICALL *GetObjectClass) - (JNIEnv *env, jobject obj); - jboolean (JNICALL *IsInstanceOf) - (JNIEnv *env, jobject obj, jclass clazz); - - jmethodID (JNICALL *GetMethodID) - (JNIEnv *env, jclass clazz, const char *name, const char *sig); - - jobject (JNICALL *CallObjectMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jobject (JNICALL *CallObjectMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jobject (JNICALL *CallObjectMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue * args); - - jboolean (JNICALL *CallBooleanMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jboolean (JNICALL *CallBooleanMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jboolean (JNICALL *CallBooleanMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue * args); - - jbyte (JNICALL *CallByteMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jbyte (JNICALL *CallByteMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jbyte (JNICALL *CallByteMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args); - - jchar (JNICALL *CallCharMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jchar (JNICALL *CallCharMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jchar (JNICALL *CallCharMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args); - - jshort (JNICALL *CallShortMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jshort (JNICALL *CallShortMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jshort (JNICALL *CallShortMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args); - - jint (JNICALL *CallIntMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jint (JNICALL *CallIntMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jint (JNICALL *CallIntMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args); - - jlong (JNICALL *CallLongMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jlong (JNICALL *CallLongMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jlong (JNICALL *CallLongMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args); - - jfloat (JNICALL *CallFloatMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jfloat (JNICALL *CallFloatMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jfloat (JNICALL *CallFloatMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args); - - jdouble (JNICALL *CallDoubleMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - jdouble (JNICALL *CallDoubleMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - jdouble (JNICALL *CallDoubleMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args); - - void (JNICALL *CallVoidMethod) - (JNIEnv *env, jobject obj, jmethodID methodID, ...); - void (JNICALL *CallVoidMethodV) - (JNIEnv *env, jobject obj, jmethodID methodID, va_list args); - void (JNICALL *CallVoidMethodA) - (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue * args); - - jobject (JNICALL *CallNonvirtualObjectMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jobject (JNICALL *CallNonvirtualObjectMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jobject (JNICALL *CallNonvirtualObjectMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue * args); - - jboolean (JNICALL *CallNonvirtualBooleanMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jboolean (JNICALL *CallNonvirtualBooleanMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jboolean (JNICALL *CallNonvirtualBooleanMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue * args); - - jbyte (JNICALL *CallNonvirtualByteMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jbyte (JNICALL *CallNonvirtualByteMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jbyte (JNICALL *CallNonvirtualByteMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue *args); - - jchar (JNICALL *CallNonvirtualCharMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jchar (JNICALL *CallNonvirtualCharMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jchar (JNICALL *CallNonvirtualCharMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue *args); - - jshort (JNICALL *CallNonvirtualShortMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jshort (JNICALL *CallNonvirtualShortMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jshort (JNICALL *CallNonvirtualShortMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue *args); - - jint (JNICALL *CallNonvirtualIntMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jint (JNICALL *CallNonvirtualIntMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jint (JNICALL *CallNonvirtualIntMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue *args); - - jlong (JNICALL *CallNonvirtualLongMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jlong (JNICALL *CallNonvirtualLongMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jlong (JNICALL *CallNonvirtualLongMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue *args); - - jfloat (JNICALL *CallNonvirtualFloatMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jfloat (JNICALL *CallNonvirtualFloatMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jfloat (JNICALL *CallNonvirtualFloatMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue *args); - - jdouble (JNICALL *CallNonvirtualDoubleMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - jdouble (JNICALL *CallNonvirtualDoubleMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - jdouble (JNICALL *CallNonvirtualDoubleMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue *args); - - void (JNICALL *CallNonvirtualVoidMethod) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...); - void (JNICALL *CallNonvirtualVoidMethodV) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - va_list args); - void (JNICALL *CallNonvirtualVoidMethodA) - (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, - const jvalue * args); - - jfieldID (JNICALL *GetFieldID) - (JNIEnv *env, jclass clazz, const char *name, const char *sig); - - jobject (JNICALL *GetObjectField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jboolean (JNICALL *GetBooleanField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jbyte (JNICALL *GetByteField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jchar (JNICALL *GetCharField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jshort (JNICALL *GetShortField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jint (JNICALL *GetIntField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jlong (JNICALL *GetLongField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jfloat (JNICALL *GetFloatField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - jdouble (JNICALL *GetDoubleField) - (JNIEnv *env, jobject obj, jfieldID fieldID); - - void (JNICALL *SetObjectField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jobject val); - void (JNICALL *SetBooleanField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jboolean val); - void (JNICALL *SetByteField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jbyte val); - void (JNICALL *SetCharField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jchar val); - void (JNICALL *SetShortField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jshort val); - void (JNICALL *SetIntField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jint val); - void (JNICALL *SetLongField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jlong val); - void (JNICALL *SetFloatField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jfloat val); - void (JNICALL *SetDoubleField) - (JNIEnv *env, jobject obj, jfieldID fieldID, jdouble val); - - jmethodID (JNICALL *GetStaticMethodID) - (JNIEnv *env, jclass clazz, const char *name, const char *sig); - - jobject (JNICALL *CallStaticObjectMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jobject (JNICALL *CallStaticObjectMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jobject (JNICALL *CallStaticObjectMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jboolean (JNICALL *CallStaticBooleanMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jboolean (JNICALL *CallStaticBooleanMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jboolean (JNICALL *CallStaticBooleanMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jbyte (JNICALL *CallStaticByteMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jbyte (JNICALL *CallStaticByteMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jbyte (JNICALL *CallStaticByteMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jchar (JNICALL *CallStaticCharMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jchar (JNICALL *CallStaticCharMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jchar (JNICALL *CallStaticCharMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jshort (JNICALL *CallStaticShortMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jshort (JNICALL *CallStaticShortMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jshort (JNICALL *CallStaticShortMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jint (JNICALL *CallStaticIntMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jint (JNICALL *CallStaticIntMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jint (JNICALL *CallStaticIntMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jlong (JNICALL *CallStaticLongMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jlong (JNICALL *CallStaticLongMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jlong (JNICALL *CallStaticLongMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jfloat (JNICALL *CallStaticFloatMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jfloat (JNICALL *CallStaticFloatMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jfloat (JNICALL *CallStaticFloatMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - jdouble (JNICALL *CallStaticDoubleMethod) - (JNIEnv *env, jclass clazz, jmethodID methodID, ...); - jdouble (JNICALL *CallStaticDoubleMethodV) - (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args); - jdouble (JNICALL *CallStaticDoubleMethodA) - (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args); - - void (JNICALL *CallStaticVoidMethod) - (JNIEnv *env, jclass cls, jmethodID methodID, ...); - void (JNICALL *CallStaticVoidMethodV) - (JNIEnv *env, jclass cls, jmethodID methodID, va_list args); - void (JNICALL *CallStaticVoidMethodA) - (JNIEnv *env, jclass cls, jmethodID methodID, const jvalue * args); - - jfieldID (JNICALL *GetStaticFieldID) - (JNIEnv *env, jclass clazz, const char *name, const char *sig); - jobject (JNICALL *GetStaticObjectField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jboolean (JNICALL *GetStaticBooleanField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jbyte (JNICALL *GetStaticByteField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jchar (JNICALL *GetStaticCharField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jshort (JNICALL *GetStaticShortField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jint (JNICALL *GetStaticIntField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jlong (JNICALL *GetStaticLongField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jfloat (JNICALL *GetStaticFloatField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - jdouble (JNICALL *GetStaticDoubleField) - (JNIEnv *env, jclass clazz, jfieldID fieldID); - - void (JNICALL *SetStaticObjectField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jobject value); - void (JNICALL *SetStaticBooleanField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jboolean value); - void (JNICALL *SetStaticByteField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jbyte value); - void (JNICALL *SetStaticCharField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jchar value); - void (JNICALL *SetStaticShortField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jshort value); - void (JNICALL *SetStaticIntField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jint value); - void (JNICALL *SetStaticLongField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jlong value); - void (JNICALL *SetStaticFloatField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jfloat value); - void (JNICALL *SetStaticDoubleField) - (JNIEnv *env, jclass clazz, jfieldID fieldID, jdouble value); - - jstring (JNICALL *NewString) - (JNIEnv *env, const jchar *unicode, jsize len); - jsize (JNICALL *GetStringLength) - (JNIEnv *env, jstring str); - const jchar *(JNICALL *GetStringChars) - (JNIEnv *env, jstring str, jboolean *isCopy); - void (JNICALL *ReleaseStringChars) - (JNIEnv *env, jstring str, const jchar *chars); - - jstring (JNICALL *NewStringUTF) - (JNIEnv *env, const char *utf); - jsize (JNICALL *GetStringUTFLength) - (JNIEnv *env, jstring str); - const char* (JNICALL *GetStringUTFChars) - (JNIEnv *env, jstring str, jboolean *isCopy); - void (JNICALL *ReleaseStringUTFChars) - (JNIEnv *env, jstring str, const char* chars); - - - jsize (JNICALL *GetArrayLength) - (JNIEnv *env, jarray array); - - jobjectArray (JNICALL *NewObjectArray) - (JNIEnv *env, jsize len, jclass clazz, jobject init); - jobject (JNICALL *GetObjectArrayElement) - (JNIEnv *env, jobjectArray array, jsize index); - void (JNICALL *SetObjectArrayElement) - (JNIEnv *env, jobjectArray array, jsize index, jobject val); - - jbooleanArray (JNICALL *NewBooleanArray) - (JNIEnv *env, jsize len); - jbyteArray (JNICALL *NewByteArray) - (JNIEnv *env, jsize len); - jcharArray (JNICALL *NewCharArray) - (JNIEnv *env, jsize len); - jshortArray (JNICALL *NewShortArray) - (JNIEnv *env, jsize len); - jintArray (JNICALL *NewIntArray) - (JNIEnv *env, jsize len); - jlongArray (JNICALL *NewLongArray) - (JNIEnv *env, jsize len); - jfloatArray (JNICALL *NewFloatArray) - (JNIEnv *env, jsize len); - jdoubleArray (JNICALL *NewDoubleArray) - (JNIEnv *env, jsize len); - - jboolean * (JNICALL *GetBooleanArrayElements) - (JNIEnv *env, jbooleanArray array, jboolean *isCopy); - jbyte * (JNICALL *GetByteArrayElements) - (JNIEnv *env, jbyteArray array, jboolean *isCopy); - jchar * (JNICALL *GetCharArrayElements) - (JNIEnv *env, jcharArray array, jboolean *isCopy); - jshort * (JNICALL *GetShortArrayElements) - (JNIEnv *env, jshortArray array, jboolean *isCopy); - jint * (JNICALL *GetIntArrayElements) - (JNIEnv *env, jintArray array, jboolean *isCopy); - jlong * (JNICALL *GetLongArrayElements) - (JNIEnv *env, jlongArray array, jboolean *isCopy); - jfloat * (JNICALL *GetFloatArrayElements) - (JNIEnv *env, jfloatArray array, jboolean *isCopy); - jdouble * (JNICALL *GetDoubleArrayElements) - (JNIEnv *env, jdoubleArray array, jboolean *isCopy); - - void (JNICALL *ReleaseBooleanArrayElements) - (JNIEnv *env, jbooleanArray array, jboolean *elems, jint mode); - void (JNICALL *ReleaseByteArrayElements) - (JNIEnv *env, jbyteArray array, jbyte *elems, jint mode); - void (JNICALL *ReleaseCharArrayElements) - (JNIEnv *env, jcharArray array, jchar *elems, jint mode); - void (JNICALL *ReleaseShortArrayElements) - (JNIEnv *env, jshortArray array, jshort *elems, jint mode); - void (JNICALL *ReleaseIntArrayElements) - (JNIEnv *env, jintArray array, jint *elems, jint mode); - void (JNICALL *ReleaseLongArrayElements) - (JNIEnv *env, jlongArray array, jlong *elems, jint mode); - void (JNICALL *ReleaseFloatArrayElements) - (JNIEnv *env, jfloatArray array, jfloat *elems, jint mode); - void (JNICALL *ReleaseDoubleArrayElements) - (JNIEnv *env, jdoubleArray array, jdouble *elems, jint mode); - - void (JNICALL *GetBooleanArrayRegion) - (JNIEnv *env, jbooleanArray array, jsize start, jsize l, jboolean *buf); - void (JNICALL *GetByteArrayRegion) - (JNIEnv *env, jbyteArray array, jsize start, jsize len, jbyte *buf); - void (JNICALL *GetCharArrayRegion) - (JNIEnv *env, jcharArray array, jsize start, jsize len, jchar *buf); - void (JNICALL *GetShortArrayRegion) - (JNIEnv *env, jshortArray array, jsize start, jsize len, jshort *buf); - void (JNICALL *GetIntArrayRegion) - (JNIEnv *env, jintArray array, jsize start, jsize len, jint *buf); - void (JNICALL *GetLongArrayRegion) - (JNIEnv *env, jlongArray array, jsize start, jsize len, jlong *buf); - void (JNICALL *GetFloatArrayRegion) - (JNIEnv *env, jfloatArray array, jsize start, jsize len, jfloat *buf); - void (JNICALL *GetDoubleArrayRegion) - (JNIEnv *env, jdoubleArray array, jsize start, jsize len, jdouble *buf); - - void (JNICALL *SetBooleanArrayRegion) - (JNIEnv *env, jbooleanArray array, jsize start, jsize l, const jboolean *buf); - void (JNICALL *SetByteArrayRegion) - (JNIEnv *env, jbyteArray array, jsize start, jsize len, const jbyte *buf); - void (JNICALL *SetCharArrayRegion) - (JNIEnv *env, jcharArray array, jsize start, jsize len, const jchar *buf); - void (JNICALL *SetShortArrayRegion) - (JNIEnv *env, jshortArray array, jsize start, jsize len, const jshort *buf); - void (JNICALL *SetIntArrayRegion) - (JNIEnv *env, jintArray array, jsize start, jsize len, const jint *buf); - void (JNICALL *SetLongArrayRegion) - (JNIEnv *env, jlongArray array, jsize start, jsize len, const jlong *buf); - void (JNICALL *SetFloatArrayRegion) - (JNIEnv *env, jfloatArray array, jsize start, jsize len, const jfloat *buf); - void (JNICALL *SetDoubleArrayRegion) - (JNIEnv *env, jdoubleArray array, jsize start, jsize len, const jdouble *buf); - - jint (JNICALL *RegisterNatives) - (JNIEnv *env, jclass clazz, const JNINativeMethod *methods, - jint nMethods); - jint (JNICALL *UnregisterNatives) - (JNIEnv *env, jclass clazz); - - jint (JNICALL *MonitorEnter) - (JNIEnv *env, jobject obj); - jint (JNICALL *MonitorExit) - (JNIEnv *env, jobject obj); - - jint (JNICALL *GetJavaVM) - (JNIEnv *env, JavaVM **vm); - - void (JNICALL *GetStringRegion) - (JNIEnv *env, jstring str, jsize start, jsize len, jchar *buf); - void (JNICALL *GetStringUTFRegion) - (JNIEnv *env, jstring str, jsize start, jsize len, char *buf); - - void * (JNICALL *GetPrimitiveArrayCritical) - (JNIEnv *env, jarray array, jboolean *isCopy); - void (JNICALL *ReleasePrimitiveArrayCritical) - (JNIEnv *env, jarray array, void *carray, jint mode); - - const jchar * (JNICALL *GetStringCritical) - (JNIEnv *env, jstring string, jboolean *isCopy); - void (JNICALL *ReleaseStringCritical) - (JNIEnv *env, jstring string, const jchar *cstring); - - jweak (JNICALL *NewWeakGlobalRef) - (JNIEnv *env, jobject obj); - void (JNICALL *DeleteWeakGlobalRef) - (JNIEnv *env, jweak ref); - - jboolean (JNICALL *ExceptionCheck) - (JNIEnv *env); - - jobject (JNICALL *NewDirectByteBuffer) - (JNIEnv* env, void* address, jlong capacity); - void* (JNICALL *GetDirectBufferAddress) - (JNIEnv* env, jobject buf); - jlong (JNICALL *GetDirectBufferCapacity) - (JNIEnv* env, jobject buf); - - /* New JNI 1.6 Features */ - - jobjectRefType (JNICALL *GetObjectRefType) - (JNIEnv* env, jobject obj); - - #if TARGET_RT_MAC_CFM && defined(__ppc__) - void* real_functions[228]; - #endif /* TARGET_RT_MAC_CFM && defined(__ppc__) */ -}; - -/* - * We use inlined functions for C++ so that programmers can write: - * - * env->FindClass("java/lang/String") - * - * in C++ rather than: - * - * (*env)->FindClass(env, "java/lang/String") - * - * in C. - */ - -struct JNIEnv_ { - const struct JNINativeInterface_ *functions; -#ifdef __cplusplus - - jint GetVersion() { - return functions->GetVersion(this); - } - jclass DefineClass(const char *name, jobject loader, const jbyte *buf, - jsize len) { - return functions->DefineClass(this, name, loader, buf, len); - } - jclass FindClass(const char *name) { - return functions->FindClass(this, name); - } - jmethodID FromReflectedMethod(jobject method) { - return functions->FromReflectedMethod(this,method); - } - jfieldID FromReflectedField(jobject field) { - return functions->FromReflectedField(this,field); - } - - jobject ToReflectedMethod(jclass cls, jmethodID methodID, jboolean isStatic) { - return functions->ToReflectedMethod(this, cls, methodID, isStatic); - } - - jclass GetSuperclass(jclass sub) { - return functions->GetSuperclass(this, sub); - } - jboolean IsAssignableFrom(jclass sub, jclass sup) { - return functions->IsAssignableFrom(this, sub, sup); - } - - jobject ToReflectedField(jclass cls, jfieldID fieldID, jboolean isStatic) { - return functions->ToReflectedField(this,cls,fieldID,isStatic); - } - - jint Throw(jthrowable obj) { - return functions->Throw(this, obj); - } - jint ThrowNew(jclass clazz, const char *msg) { - return functions->ThrowNew(this, clazz, msg); - } - jthrowable ExceptionOccurred() { - return functions->ExceptionOccurred(this); - } - void ExceptionDescribe() { - functions->ExceptionDescribe(this); - } - void ExceptionClear() { - functions->ExceptionClear(this); - } - void FatalError(const char *msg) { - functions->FatalError(this, msg); - } - - jint PushLocalFrame(jint capacity) { - return functions->PushLocalFrame(this,capacity); - } - jobject PopLocalFrame(jobject result) { - return functions->PopLocalFrame(this,result); - } - - jobject NewGlobalRef(jobject lobj) { - return functions->NewGlobalRef(this,lobj); - } - void DeleteGlobalRef(jobject gref) { - functions->DeleteGlobalRef(this,gref); - } - void DeleteLocalRef(jobject obj) { - functions->DeleteLocalRef(this, obj); - } - - jboolean IsSameObject(jobject obj1, jobject obj2) { - return functions->IsSameObject(this,obj1,obj2); - } - - jobject NewLocalRef(jobject ref) { - return functions->NewLocalRef(this,ref); - } - jint EnsureLocalCapacity(jint capacity) { - return functions->EnsureLocalCapacity(this,capacity); - } - - jobject AllocObject(jclass clazz) { - return functions->AllocObject(this,clazz); - } - jobject NewObject(jclass clazz, jmethodID methodID, ...) { - va_list args; - jobject result; - va_start(args, methodID); - result = functions->NewObjectV(this,clazz,methodID,args); - va_end(args); - return result; - } - jobject NewObjectV(jclass clazz, jmethodID methodID, - va_list args) { - return functions->NewObjectV(this,clazz,methodID,args); - } - jobject NewObjectA(jclass clazz, jmethodID methodID, - const jvalue *args) { - return functions->NewObjectA(this,clazz,methodID,args); - } - - jclass GetObjectClass(jobject obj) { - return functions->GetObjectClass(this,obj); - } - jboolean IsInstanceOf(jobject obj, jclass clazz) { - return functions->IsInstanceOf(this,obj,clazz); - } - - jmethodID GetMethodID(jclass clazz, const char *name, - const char *sig) { - return functions->GetMethodID(this,clazz,name,sig); - } - - jobject CallObjectMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jobject result; - va_start(args,methodID); - result = functions->CallObjectMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jobject CallObjectMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallObjectMethodV(this,obj,methodID,args); - } - jobject CallObjectMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallObjectMethodA(this,obj,methodID,args); - } - - jboolean CallBooleanMethod(jobject obj, - jmethodID methodID, ...) { - va_list args; - jboolean result; - va_start(args,methodID); - result = functions->CallBooleanMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jboolean CallBooleanMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallBooleanMethodV(this,obj,methodID,args); - } - jboolean CallBooleanMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallBooleanMethodA(this,obj,methodID, args); - } - - jbyte CallByteMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jbyte result; - va_start(args,methodID); - result = functions->CallByteMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jbyte CallByteMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallByteMethodV(this,obj,methodID,args); - } - jbyte CallByteMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallByteMethodA(this,obj,methodID,args); - } - - jchar CallCharMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jchar result; - va_start(args,methodID); - result = functions->CallCharMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jchar CallCharMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallCharMethodV(this,obj,methodID,args); - } - jchar CallCharMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallCharMethodA(this,obj,methodID,args); - } - - jshort CallShortMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jshort result; - va_start(args,methodID); - result = functions->CallShortMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jshort CallShortMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallShortMethodV(this,obj,methodID,args); - } - jshort CallShortMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallShortMethodA(this,obj,methodID,args); - } - - jint CallIntMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jint result; - va_start(args,methodID); - result = functions->CallIntMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jint CallIntMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallIntMethodV(this,obj,methodID,args); - } - jint CallIntMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallIntMethodA(this,obj,methodID,args); - } - - jlong CallLongMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jlong result; - va_start(args,methodID); - result = functions->CallLongMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jlong CallLongMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallLongMethodV(this,obj,methodID,args); - } - jlong CallLongMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallLongMethodA(this,obj,methodID,args); - } - - jfloat CallFloatMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jfloat result; - va_start(args,methodID); - result = functions->CallFloatMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jfloat CallFloatMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallFloatMethodV(this,obj,methodID,args); - } - jfloat CallFloatMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallFloatMethodA(this,obj,methodID,args); - } - - jdouble CallDoubleMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - jdouble result; - va_start(args,methodID); - result = functions->CallDoubleMethodV(this,obj,methodID,args); - va_end(args); - return result; - } - jdouble CallDoubleMethodV(jobject obj, jmethodID methodID, - va_list args) { - return functions->CallDoubleMethodV(this,obj,methodID,args); - } - jdouble CallDoubleMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - return functions->CallDoubleMethodA(this,obj,methodID,args); - } - - void CallVoidMethod(jobject obj, jmethodID methodID, ...) { - va_list args; - va_start(args,methodID); - functions->CallVoidMethodV(this,obj,methodID,args); - va_end(args); - } - void CallVoidMethodV(jobject obj, jmethodID methodID, - va_list args) { - functions->CallVoidMethodV(this,obj,methodID,args); - } - void CallVoidMethodA(jobject obj, jmethodID methodID, - const jvalue * args) { - functions->CallVoidMethodA(this,obj,methodID,args); - } - - jobject CallNonvirtualObjectMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jobject result; - va_start(args,methodID); - result = functions->CallNonvirtualObjectMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jobject CallNonvirtualObjectMethodV(jobject obj, jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallNonvirtualObjectMethodV(this,obj,clazz, - methodID,args); - } - jobject CallNonvirtualObjectMethodA(jobject obj, jclass clazz, - jmethodID methodID, const jvalue * args) { - return functions->CallNonvirtualObjectMethodA(this,obj,clazz, - methodID,args); - } - - jboolean CallNonvirtualBooleanMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jboolean result; - va_start(args,methodID); - result = functions->CallNonvirtualBooleanMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jboolean CallNonvirtualBooleanMethodV(jobject obj, jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallNonvirtualBooleanMethodV(this,obj,clazz, - methodID,args); - } - jboolean CallNonvirtualBooleanMethodA(jobject obj, jclass clazz, - jmethodID methodID, const jvalue * args) { - return functions->CallNonvirtualBooleanMethodA(this,obj,clazz, - methodID, args); - } - - jbyte CallNonvirtualByteMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jbyte result; - va_start(args,methodID); - result = functions->CallNonvirtualByteMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jbyte CallNonvirtualByteMethodV(jobject obj, jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallNonvirtualByteMethodV(this,obj,clazz, - methodID,args); - } - jbyte CallNonvirtualByteMethodA(jobject obj, jclass clazz, - jmethodID methodID, const jvalue * args) { - return functions->CallNonvirtualByteMethodA(this,obj,clazz, - methodID,args); - } - - jchar CallNonvirtualCharMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jchar result; - va_start(args,methodID); - result = functions->CallNonvirtualCharMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jchar CallNonvirtualCharMethodV(jobject obj, jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallNonvirtualCharMethodV(this,obj,clazz, - methodID,args); - } - jchar CallNonvirtualCharMethodA(jobject obj, jclass clazz, - jmethodID methodID, const jvalue * args) { - return functions->CallNonvirtualCharMethodA(this,obj,clazz, - methodID,args); - } - - jshort CallNonvirtualShortMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jshort result; - va_start(args,methodID); - result = functions->CallNonvirtualShortMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jshort CallNonvirtualShortMethodV(jobject obj, jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallNonvirtualShortMethodV(this,obj,clazz, - methodID,args); - } - jshort CallNonvirtualShortMethodA(jobject obj, jclass clazz, - jmethodID methodID, const jvalue * args) { - return functions->CallNonvirtualShortMethodA(this,obj,clazz, - methodID,args); - } - - jint CallNonvirtualIntMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jint result; - va_start(args,methodID); - result = functions->CallNonvirtualIntMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jint CallNonvirtualIntMethodV(jobject obj, jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallNonvirtualIntMethodV(this,obj,clazz, - methodID,args); - } - jint CallNonvirtualIntMethodA(jobject obj, jclass clazz, - jmethodID methodID, const jvalue * args) { - return functions->CallNonvirtualIntMethodA(this,obj,clazz, - methodID,args); - } - - jlong CallNonvirtualLongMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jlong result; - va_start(args,methodID); - result = functions->CallNonvirtualLongMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jlong CallNonvirtualLongMethodV(jobject obj, jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallNonvirtualLongMethodV(this,obj,clazz, - methodID,args); - } - jlong CallNonvirtualLongMethodA(jobject obj, jclass clazz, - jmethodID methodID, const jvalue * args) { - return functions->CallNonvirtualLongMethodA(this,obj,clazz, - methodID,args); - } - - jfloat CallNonvirtualFloatMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jfloat result; - va_start(args,methodID); - result = functions->CallNonvirtualFloatMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jfloat CallNonvirtualFloatMethodV(jobject obj, jclass clazz, - jmethodID methodID, - va_list args) { - return functions->CallNonvirtualFloatMethodV(this,obj,clazz, - methodID,args); - } - jfloat CallNonvirtualFloatMethodA(jobject obj, jclass clazz, - jmethodID methodID, - const jvalue * args) { - return functions->CallNonvirtualFloatMethodA(this,obj,clazz, - methodID,args); - } - - jdouble CallNonvirtualDoubleMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - jdouble result; - va_start(args,methodID); - result = functions->CallNonvirtualDoubleMethodV(this,obj,clazz, - methodID,args); - va_end(args); - return result; - } - jdouble CallNonvirtualDoubleMethodV(jobject obj, jclass clazz, - jmethodID methodID, - va_list args) { - return functions->CallNonvirtualDoubleMethodV(this,obj,clazz, - methodID,args); - } - jdouble CallNonvirtualDoubleMethodA(jobject obj, jclass clazz, - jmethodID methodID, - const jvalue * args) { - return functions->CallNonvirtualDoubleMethodA(this,obj,clazz, - methodID,args); - } - - void CallNonvirtualVoidMethod(jobject obj, jclass clazz, - jmethodID methodID, ...) { - va_list args; - va_start(args,methodID); - functions->CallNonvirtualVoidMethodV(this,obj,clazz,methodID,args); - va_end(args); - } - void CallNonvirtualVoidMethodV(jobject obj, jclass clazz, - jmethodID methodID, - va_list args) { - functions->CallNonvirtualVoidMethodV(this,obj,clazz,methodID,args); - } - void CallNonvirtualVoidMethodA(jobject obj, jclass clazz, - jmethodID methodID, - const jvalue * args) { - functions->CallNonvirtualVoidMethodA(this,obj,clazz,methodID,args); - } - - jfieldID GetFieldID(jclass clazz, const char *name, - const char *sig) { - return functions->GetFieldID(this,clazz,name,sig); - } - - jobject GetObjectField(jobject obj, jfieldID fieldID) { - return functions->GetObjectField(this,obj,fieldID); - } - jboolean GetBooleanField(jobject obj, jfieldID fieldID) { - return functions->GetBooleanField(this,obj,fieldID); - } - jbyte GetByteField(jobject obj, jfieldID fieldID) { - return functions->GetByteField(this,obj,fieldID); - } - jchar GetCharField(jobject obj, jfieldID fieldID) { - return functions->GetCharField(this,obj,fieldID); - } - jshort GetShortField(jobject obj, jfieldID fieldID) { - return functions->GetShortField(this,obj,fieldID); - } - jint GetIntField(jobject obj, jfieldID fieldID) { - return functions->GetIntField(this,obj,fieldID); - } - jlong GetLongField(jobject obj, jfieldID fieldID) { - return functions->GetLongField(this,obj,fieldID); - } - jfloat GetFloatField(jobject obj, jfieldID fieldID) { - return functions->GetFloatField(this,obj,fieldID); - } - jdouble GetDoubleField(jobject obj, jfieldID fieldID) { - return functions->GetDoubleField(this,obj,fieldID); - } - - void SetObjectField(jobject obj, jfieldID fieldID, jobject val) { - functions->SetObjectField(this,obj,fieldID,val); - } - void SetBooleanField(jobject obj, jfieldID fieldID, - jboolean val) { - functions->SetBooleanField(this,obj,fieldID,val); - } - void SetByteField(jobject obj, jfieldID fieldID, - jbyte val) { - functions->SetByteField(this,obj,fieldID,val); - } - void SetCharField(jobject obj, jfieldID fieldID, - jchar val) { - functions->SetCharField(this,obj,fieldID,val); - } - void SetShortField(jobject obj, jfieldID fieldID, - jshort val) { - functions->SetShortField(this,obj,fieldID,val); - } - void SetIntField(jobject obj, jfieldID fieldID, - jint val) { - functions->SetIntField(this,obj,fieldID,val); - } - void SetLongField(jobject obj, jfieldID fieldID, - jlong val) { - functions->SetLongField(this,obj,fieldID,val); - } - void SetFloatField(jobject obj, jfieldID fieldID, - jfloat val) { - functions->SetFloatField(this,obj,fieldID,val); - } - void SetDoubleField(jobject obj, jfieldID fieldID, - jdouble val) { - functions->SetDoubleField(this,obj,fieldID,val); - } - - jmethodID GetStaticMethodID(jclass clazz, const char *name, - const char *sig) { - return functions->GetStaticMethodID(this,clazz,name,sig); - } - - jobject CallStaticObjectMethod(jclass clazz, jmethodID methodID, - ...) { - va_list args; - jobject result; - va_start(args,methodID); - result = functions->CallStaticObjectMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jobject CallStaticObjectMethodV(jclass clazz, jmethodID methodID, - va_list args) { - return functions->CallStaticObjectMethodV(this,clazz,methodID,args); - } - jobject CallStaticObjectMethodA(jclass clazz, jmethodID methodID, - const jvalue *args) { - return functions->CallStaticObjectMethodA(this,clazz,methodID,args); - } - - jboolean CallStaticBooleanMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jboolean result; - va_start(args,methodID); - result = functions->CallStaticBooleanMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jboolean CallStaticBooleanMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticBooleanMethodV(this,clazz,methodID,args); - } - jboolean CallStaticBooleanMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticBooleanMethodA(this,clazz,methodID,args); - } - - jbyte CallStaticByteMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jbyte result; - va_start(args,methodID); - result = functions->CallStaticByteMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jbyte CallStaticByteMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticByteMethodV(this,clazz,methodID,args); - } - jbyte CallStaticByteMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticByteMethodA(this,clazz,methodID,args); - } - - jchar CallStaticCharMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jchar result; - va_start(args,methodID); - result = functions->CallStaticCharMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jchar CallStaticCharMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticCharMethodV(this,clazz,methodID,args); - } - jchar CallStaticCharMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticCharMethodA(this,clazz,methodID,args); - } - - jshort CallStaticShortMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jshort result; - va_start(args,methodID); - result = functions->CallStaticShortMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jshort CallStaticShortMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticShortMethodV(this,clazz,methodID,args); - } - jshort CallStaticShortMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticShortMethodA(this,clazz,methodID,args); - } - - jint CallStaticIntMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jint result; - va_start(args,methodID); - result = functions->CallStaticIntMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jint CallStaticIntMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticIntMethodV(this,clazz,methodID,args); - } - jint CallStaticIntMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticIntMethodA(this,clazz,methodID,args); - } - - jlong CallStaticLongMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jlong result; - va_start(args,methodID); - result = functions->CallStaticLongMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jlong CallStaticLongMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticLongMethodV(this,clazz,methodID,args); - } - jlong CallStaticLongMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticLongMethodA(this,clazz,methodID,args); - } - - jfloat CallStaticFloatMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jfloat result; - va_start(args,methodID); - result = functions->CallStaticFloatMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jfloat CallStaticFloatMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticFloatMethodV(this,clazz,methodID,args); - } - jfloat CallStaticFloatMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticFloatMethodA(this,clazz,methodID,args); - } - - jdouble CallStaticDoubleMethod(jclass clazz, - jmethodID methodID, ...) { - va_list args; - jdouble result; - va_start(args,methodID); - result = functions->CallStaticDoubleMethodV(this,clazz,methodID,args); - va_end(args); - return result; - } - jdouble CallStaticDoubleMethodV(jclass clazz, - jmethodID methodID, va_list args) { - return functions->CallStaticDoubleMethodV(this,clazz,methodID,args); - } - jdouble CallStaticDoubleMethodA(jclass clazz, - jmethodID methodID, const jvalue *args) { - return functions->CallStaticDoubleMethodA(this,clazz,methodID,args); - } - - void CallStaticVoidMethod(jclass cls, jmethodID methodID, ...) { - va_list args; - va_start(args,methodID); - functions->CallStaticVoidMethodV(this,cls,methodID,args); - va_end(args); - } - void CallStaticVoidMethodV(jclass cls, jmethodID methodID, - va_list args) { - functions->CallStaticVoidMethodV(this,cls,methodID,args); - } - void CallStaticVoidMethodA(jclass cls, jmethodID methodID, - const jvalue * args) { - functions->CallStaticVoidMethodA(this,cls,methodID,args); - } - - jfieldID GetStaticFieldID(jclass clazz, const char *name, - const char *sig) { - return functions->GetStaticFieldID(this,clazz,name,sig); - } - jobject GetStaticObjectField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticObjectField(this,clazz,fieldID); - } - jboolean GetStaticBooleanField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticBooleanField(this,clazz,fieldID); - } - jbyte GetStaticByteField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticByteField(this,clazz,fieldID); - } - jchar GetStaticCharField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticCharField(this,clazz,fieldID); - } - jshort GetStaticShortField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticShortField(this,clazz,fieldID); - } - jint GetStaticIntField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticIntField(this,clazz,fieldID); - } - jlong GetStaticLongField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticLongField(this,clazz,fieldID); - } - jfloat GetStaticFloatField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticFloatField(this,clazz,fieldID); - } - jdouble GetStaticDoubleField(jclass clazz, jfieldID fieldID) { - return functions->GetStaticDoubleField(this,clazz,fieldID); - } - - void SetStaticObjectField(jclass clazz, jfieldID fieldID, - jobject value) { - functions->SetStaticObjectField(this,clazz,fieldID,value); - } - void SetStaticBooleanField(jclass clazz, jfieldID fieldID, - jboolean value) { - functions->SetStaticBooleanField(this,clazz,fieldID,value); - } - void SetStaticByteField(jclass clazz, jfieldID fieldID, - jbyte value) { - functions->SetStaticByteField(this,clazz,fieldID,value); - } - void SetStaticCharField(jclass clazz, jfieldID fieldID, - jchar value) { - functions->SetStaticCharField(this,clazz,fieldID,value); - } - void SetStaticShortField(jclass clazz, jfieldID fieldID, - jshort value) { - functions->SetStaticShortField(this,clazz,fieldID,value); - } - void SetStaticIntField(jclass clazz, jfieldID fieldID, - jint value) { - functions->SetStaticIntField(this,clazz,fieldID,value); - } - void SetStaticLongField(jclass clazz, jfieldID fieldID, - jlong value) { - functions->SetStaticLongField(this,clazz,fieldID,value); - } - void SetStaticFloatField(jclass clazz, jfieldID fieldID, - jfloat value) { - functions->SetStaticFloatField(this,clazz,fieldID,value); - } - void SetStaticDoubleField(jclass clazz, jfieldID fieldID, - jdouble value) { - functions->SetStaticDoubleField(this,clazz,fieldID,value); - } - - jstring NewString(const jchar *unicode, jsize len) { - return functions->NewString(this,unicode,len); - } - jsize GetStringLength(jstring str) { - return functions->GetStringLength(this,str); - } - const jchar *GetStringChars(jstring str, jboolean *isCopy) { - return functions->GetStringChars(this,str,isCopy); - } - void ReleaseStringChars(jstring str, const jchar *chars) { - functions->ReleaseStringChars(this,str,chars); - } - - jstring NewStringUTF(const char *utf) { - return functions->NewStringUTF(this,utf); - } - jsize GetStringUTFLength(jstring str) { - return functions->GetStringUTFLength(this,str); - } - const char* GetStringUTFChars(jstring str, jboolean *isCopy) { - return functions->GetStringUTFChars(this,str,isCopy); - } - void ReleaseStringUTFChars(jstring str, const char* chars) { - functions->ReleaseStringUTFChars(this,str,chars); - } - - jsize GetArrayLength(jarray array) { - return functions->GetArrayLength(this,array); - } - - jobjectArray NewObjectArray(jsize len, jclass clazz, - jobject init) { - return functions->NewObjectArray(this,len,clazz,init); - } - jobject GetObjectArrayElement(jobjectArray array, jsize index) { - return functions->GetObjectArrayElement(this,array,index); - } - void SetObjectArrayElement(jobjectArray array, jsize index, - jobject val) { - functions->SetObjectArrayElement(this,array,index,val); - } - - jbooleanArray NewBooleanArray(jsize len) { - return functions->NewBooleanArray(this,len); - } - jbyteArray NewByteArray(jsize len) { - return functions->NewByteArray(this,len); - } - jcharArray NewCharArray(jsize len) { - return functions->NewCharArray(this,len); - } - jshortArray NewShortArray(jsize len) { - return functions->NewShortArray(this,len); - } - jintArray NewIntArray(jsize len) { - return functions->NewIntArray(this,len); - } - jlongArray NewLongArray(jsize len) { - return functions->NewLongArray(this,len); - } - jfloatArray NewFloatArray(jsize len) { - return functions->NewFloatArray(this,len); - } - jdoubleArray NewDoubleArray(jsize len) { - return functions->NewDoubleArray(this,len); - } - - jboolean * GetBooleanArrayElements(jbooleanArray array, jboolean *isCopy) { - return functions->GetBooleanArrayElements(this,array,isCopy); - } - jbyte * GetByteArrayElements(jbyteArray array, jboolean *isCopy) { - return functions->GetByteArrayElements(this,array,isCopy); - } - jchar * GetCharArrayElements(jcharArray array, jboolean *isCopy) { - return functions->GetCharArrayElements(this,array,isCopy); - } - jshort * GetShortArrayElements(jshortArray array, jboolean *isCopy) { - return functions->GetShortArrayElements(this,array,isCopy); - } - jint * GetIntArrayElements(jintArray array, jboolean *isCopy) { - return functions->GetIntArrayElements(this,array,isCopy); - } - jlong * GetLongArrayElements(jlongArray array, jboolean *isCopy) { - return functions->GetLongArrayElements(this,array,isCopy); - } - jfloat * GetFloatArrayElements(jfloatArray array, jboolean *isCopy) { - return functions->GetFloatArrayElements(this,array,isCopy); - } - jdouble * GetDoubleArrayElements(jdoubleArray array, jboolean *isCopy) { - return functions->GetDoubleArrayElements(this,array,isCopy); - } - - void ReleaseBooleanArrayElements(jbooleanArray array, - jboolean *elems, - jint mode) { - functions->ReleaseBooleanArrayElements(this,array,elems,mode); - } - void ReleaseByteArrayElements(jbyteArray array, - jbyte *elems, - jint mode) { - functions->ReleaseByteArrayElements(this,array,elems,mode); - } - void ReleaseCharArrayElements(jcharArray array, - jchar *elems, - jint mode) { - functions->ReleaseCharArrayElements(this,array,elems,mode); - } - void ReleaseShortArrayElements(jshortArray array, - jshort *elems, - jint mode) { - functions->ReleaseShortArrayElements(this,array,elems,mode); - } - void ReleaseIntArrayElements(jintArray array, - jint *elems, - jint mode) { - functions->ReleaseIntArrayElements(this,array,elems,mode); - } - void ReleaseLongArrayElements(jlongArray array, - jlong *elems, - jint mode) { - functions->ReleaseLongArrayElements(this,array,elems,mode); - } - void ReleaseFloatArrayElements(jfloatArray array, - jfloat *elems, - jint mode) { - functions->ReleaseFloatArrayElements(this,array,elems,mode); - } - void ReleaseDoubleArrayElements(jdoubleArray array, - jdouble *elems, - jint mode) { - functions->ReleaseDoubleArrayElements(this,array,elems,mode); - } - - void GetBooleanArrayRegion(jbooleanArray array, - jsize start, jsize len, jboolean *buf) { - functions->GetBooleanArrayRegion(this,array,start,len,buf); - } - void GetByteArrayRegion(jbyteArray array, - jsize start, jsize len, jbyte *buf) { - functions->GetByteArrayRegion(this,array,start,len,buf); - } - void GetCharArrayRegion(jcharArray array, - jsize start, jsize len, jchar *buf) { - functions->GetCharArrayRegion(this,array,start,len,buf); - } - void GetShortArrayRegion(jshortArray array, - jsize start, jsize len, jshort *buf) { - functions->GetShortArrayRegion(this,array,start,len,buf); - } - void GetIntArrayRegion(jintArray array, - jsize start, jsize len, jint *buf) { - functions->GetIntArrayRegion(this,array,start,len,buf); - } - void GetLongArrayRegion(jlongArray array, - jsize start, jsize len, jlong *buf) { - functions->GetLongArrayRegion(this,array,start,len,buf); - } - void GetFloatArrayRegion(jfloatArray array, - jsize start, jsize len, jfloat *buf) { - functions->GetFloatArrayRegion(this,array,start,len,buf); - } - void GetDoubleArrayRegion(jdoubleArray array, - jsize start, jsize len, jdouble *buf) { - functions->GetDoubleArrayRegion(this,array,start,len,buf); - } - - void SetBooleanArrayRegion(jbooleanArray array, jsize start, jsize len, - const jboolean *buf) { - functions->SetBooleanArrayRegion(this,array,start,len,buf); - } - void SetByteArrayRegion(jbyteArray array, jsize start, jsize len, - const jbyte *buf) { - functions->SetByteArrayRegion(this,array,start,len,buf); - } - void SetCharArrayRegion(jcharArray array, jsize start, jsize len, - const jchar *buf) { - functions->SetCharArrayRegion(this,array,start,len,buf); - } - void SetShortArrayRegion(jshortArray array, jsize start, jsize len, - const jshort *buf) { - functions->SetShortArrayRegion(this,array,start,len,buf); - } - void SetIntArrayRegion(jintArray array, jsize start, jsize len, - const jint *buf) { - functions->SetIntArrayRegion(this,array,start,len,buf); - } - void SetLongArrayRegion(jlongArray array, jsize start, jsize len, - const jlong *buf) { - functions->SetLongArrayRegion(this,array,start,len,buf); - } - void SetFloatArrayRegion(jfloatArray array, jsize start, jsize len, - const jfloat *buf) { - functions->SetFloatArrayRegion(this,array,start,len,buf); - } - void SetDoubleArrayRegion(jdoubleArray array, jsize start, jsize len, - const jdouble *buf) { - functions->SetDoubleArrayRegion(this,array,start,len,buf); - } - - jint RegisterNatives(jclass clazz, const JNINativeMethod *methods, - jint nMethods) { - return functions->RegisterNatives(this,clazz,methods,nMethods); - } - jint UnregisterNatives(jclass clazz) { - return functions->UnregisterNatives(this,clazz); - } - - jint MonitorEnter(jobject obj) { - return functions->MonitorEnter(this,obj); - } - jint MonitorExit(jobject obj) { - return functions->MonitorExit(this,obj); - } - - jint GetJavaVM(JavaVM **vm) { - return functions->GetJavaVM(this,vm); - } - - void GetStringRegion(jstring str, jsize start, jsize len, jchar *buf) { - functions->GetStringRegion(this,str,start,len,buf); - } - void GetStringUTFRegion(jstring str, jsize start, jsize len, char *buf) { - functions->GetStringUTFRegion(this,str,start,len,buf); - } - - void * GetPrimitiveArrayCritical(jarray array, jboolean *isCopy) { - return functions->GetPrimitiveArrayCritical(this,array,isCopy); - } - void ReleasePrimitiveArrayCritical(jarray array, void *carray, jint mode) { - functions->ReleasePrimitiveArrayCritical(this,array,carray,mode); - } - - const jchar * GetStringCritical(jstring string, jboolean *isCopy) { - return functions->GetStringCritical(this,string,isCopy); - } - void ReleaseStringCritical(jstring string, const jchar *cstring) { - functions->ReleaseStringCritical(this,string,cstring); - } - - jweak NewWeakGlobalRef(jobject obj) { - return functions->NewWeakGlobalRef(this,obj); - } - void DeleteWeakGlobalRef(jweak ref) { - functions->DeleteWeakGlobalRef(this,ref); - } - - jboolean ExceptionCheck() { - return functions->ExceptionCheck(this); - } - - jobject NewDirectByteBuffer(void* address, jlong capacity) { - return functions->NewDirectByteBuffer(this, address, capacity); - } - void* GetDirectBufferAddress(jobject buf) { - return functions->GetDirectBufferAddress(this, buf); - } - jlong GetDirectBufferCapacity(jobject buf) { - return functions->GetDirectBufferCapacity(this, buf); - } - jobjectRefType GetObjectRefType(jobject obj) { - return functions->GetObjectRefType(this, obj); - } - -#endif /* __cplusplus */ -}; - -typedef struct JavaVMOption { - char *optionString; - void *extraInfo; -} JavaVMOption; - -typedef struct JavaVMInitArgs { - jint version; - - jint nOptions; - JavaVMOption *options; - jboolean ignoreUnrecognized; -} JavaVMInitArgs; - -typedef struct JavaVMAttachArgs { - jint version; - - char *name; - jobject group; -} JavaVMAttachArgs; - -/* These will be VM-specific. */ - -#define JDK1_2 -#define JDK1_4 - -/* End VM-specific. */ - -struct JNIInvokeInterface_ { - void *reserved0; - void *reserved1; - void *reserved2; - -#if !TARGET_RT_MAC_CFM && defined(__ppc__) - void* cfm_vectors[4]; -#endif /* !TARGET_RT_MAC_CFM && defined(__ppc__) */ - - jint (JNICALL *DestroyJavaVM)(JavaVM *vm); - - jint (JNICALL *AttachCurrentThread)(JavaVM *vm, void **penv, void *args); - - jint (JNICALL *DetachCurrentThread)(JavaVM *vm); - - jint (JNICALL *GetEnv)(JavaVM *vm, void **penv, jint version); - - jint (JNICALL *AttachCurrentThreadAsDaemon)(JavaVM *vm, void **penv, void *args); - -#if TARGET_RT_MAC_CFM && defined(__ppc__) - void* real_functions[5]; -#endif /* TARGET_RT_MAC_CFM && defined(__ppc__) */ -}; - -struct JavaVM_ { - const struct JNIInvokeInterface_ *functions; -#ifdef __cplusplus - - jint DestroyJavaVM() { - return functions->DestroyJavaVM(this); - } - jint AttachCurrentThread(void **penv, void *args) { - return functions->AttachCurrentThread(this, penv, args); - } - jint DetachCurrentThread() { - return functions->DetachCurrentThread(this); - } - - jint GetEnv(void **penv, jint version) { - return functions->GetEnv(this, penv, version); - } - jint AttachCurrentThreadAsDaemon(void **penv, void *args) { - return functions->AttachCurrentThreadAsDaemon(this, penv, args); - } -#endif -}; - -#ifdef _JNI_IMPLEMENTATION_ -#define _JNI_IMPORT_OR_EXPORT_ JNIEXPORT -#else -#define _JNI_IMPORT_OR_EXPORT_ JNIIMPORT -#endif -_JNI_IMPORT_OR_EXPORT_ jint JNICALL -JNI_GetDefaultJavaVMInitArgs(void *args); - -_JNI_IMPORT_OR_EXPORT_ jint JNICALL -JNI_CreateJavaVM(JavaVM **pvm, void **penv, void *args); - -_JNI_IMPORT_OR_EXPORT_ jint JNICALL -JNI_GetCreatedJavaVMs(JavaVM **, jsize, jsize *); - -/* Defined by native libraries. */ -JNIEXPORT jint JNICALL -JNI_OnLoad(JavaVM *vm, void *reserved); - -JNIEXPORT void JNICALL -JNI_OnUnload(JavaVM *vm, void *reserved); - -#define JNI_VERSION_1_1 0x00010001 -#define JNI_VERSION_1_2 0x00010002 -#define JNI_VERSION_1_4 0x00010004 -#define JNI_VERSION_1_6 0x00010006 - -#ifdef __cplusplus -} /* extern "C" */ -#endif /* __cplusplus */ - -#endif /* !_JAVASOFT_JNI_H_ */ - - - diff --git a/jni/jni_md.h b/jni/jni_md.h deleted file mode 100755 index a3289ee..0000000 --- a/jni/jni_md.h +++ /dev/null @@ -1,23 +0,0 @@ -/* - * @(#)jni_md.h 1.19 05/11/17 - * - * Copyright 2006 Sun Microsystems, Inc. All rights reserved. - * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. - */ - -#ifndef _JAVASOFT_JNI_MD_H_ -#define _JAVASOFT_JNI_MD_H_ - -#define JNIEXPORT __attribute__((visibility("default"))) -#define JNIIMPORT -#define JNICALL - -#if __LP64__ -typedef int jint; -#else -typedef long jint; -#endif -typedef long long jlong; -typedef signed char jbyte; - -#endif /* !_JAVASOFT_JNI_MD_H_ */ diff --git a/pom.xml b/pom.xml index 9ff1c5a..184d92d 100644 --- a/pom.xml +++ b/pom.xml @@ -2,7 +2,7 @@ 4.0.0 org.gmssl GmSSLJNI - 2.1.0-dev + 3.1.1 GmSSL-Java jar GmSSL Java SDK @@ -17,12 +17,6 @@ gmssljni - C:/Program Files/GmSSL/include - C:/Program Files/GmSSL/lib - /usr/local/include - /usr/local/lib - /usr/local/include - /usr/local/lib @@ -63,12 +57,6 @@ --> - ${winIncludePath} - ${winLibPath} - ${linuxIncludePath} - ${linuxLibPath} - ${macIncludePath} - ${macLibPath} ${cmake.compile.config} ${libName} @@ -98,7 +86,6 @@ ${project.build.directory}/build - value diff --git a/src/main/c/CMakeLists.txt b/src/main/c/CMakeLists.txt index 56a1c1b..a16c4b3 100644 --- a/src/main/c/CMakeLists.txt +++ b/src/main/c/CMakeLists.txt @@ -1,11 +1,19 @@ cmake_minimum_required(VERSION 3.11) project(gmssljni) +find_program(GMSSL_EXECUTABLE NAMES gmssl) +if(GMSSL_EXECUTABLE) + get_filename_component(GMSSL_BIN_DIR "${GMSSL_EXECUTABLE}" DIRECTORY) + get_filename_component(GMSSL_PARENT_DIR "${GMSSL_BIN_DIR}" DIRECTORY) +else() + message(FATAL_ERROR "gmssl not found!") +endif() + if(WIN32) message(STATUS "->Now is windows") - link_directories("$ENV{winLibPath}") + link_directories(${GMSSL_PARENT_DIR}/lib) add_library(gmssljni-native SHARED gmssljni.c) - target_include_directories(gmssljni-native PUBLIC "$ENV{winIncludePath}") + target_include_directories(gmssljni-native PUBLIC ${GMSSL_PARENT_DIR}/include) #target_include_directories(gmssljni-native PUBLIC ${CMAKE_SOURCE_DIR}/jni) find_package(JNI REQUIRED) include_directories(${JNI_INCLUDE_DIRS}) @@ -15,20 +23,20 @@ elseif(APPLE) message(STATUS "->Now is Apple systems.") set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/$ENV{libSubFolder}) add_library(gmssljni-native SHARED gmssljni.c) - target_link_libraries(gmssljni-native -L"$ENV{macLibPath}") + target_link_libraries(gmssljni-native -L"${GMSSL_PARENT_DIR}/lib") find_package(JNI REQUIRED) include_directories(${JNI_INCLUDE_DIRS}) - include_directories("$ENV{macIncludePath}") + include_directories(${GMSSL_PARENT_DIR}/include) target_link_libraries(gmssljni-native gmssl) set_target_properties(gmssljni-native PROPERTIES OUTPUT_NAME $ENV{libName}) elseif(UNIX) message(STATUS "->Now is UNIX-like OS's.") set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/$ENV{libSubFolder}) add_library(gmssljni-native SHARED gmssljni.c) - target_link_libraries(gmssljni-native -L"$ENV{linuxLibPath}") + target_link_libraries(gmssljni-native -L"${GMSSL_PARENT_DIR}/lib") find_package(JNI REQUIRED) include_directories(${JNI_INCLUDE_DIRS}) - include_directories("$ENV{linuxIncludePath}") + include_directories(${GMSSL_PARENT_DIR}/include) target_link_libraries(gmssljni-native gmssl) set_target_properties(gmssljni-native PROPERTIES OUTPUT_NAME $ENV{libName}) else() diff --git a/src/main/c/gmssljni.c b/src/main/c/gmssljni.c index 5a2615c..fe1cc72 100644 --- a/src/main/c/gmssljni.c +++ b/src/main/c/gmssljni.c @@ -18,8 +18,10 @@ #include #include #include +#include #include #include +#include #include #include "gmssljni.h" @@ -351,6 +353,61 @@ JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1finish( return ret; } +/* + * Class: org_gmssl_GmSSLJNI + * Method: sm3_pbkdf2 + * Signature: (Ljava/lang/String;[BII)[B + */ +JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm3_1pbkdf2( + JNIEnv *env, jclass this, + jstring pass, jbyteArray salt, jint iter, jint keylen) +{ + jbyteArray ret = NULL; + uint8_t keybuf[256]; + const char *pass_str = NULL; + jbyte *saltbuf = NULL; + jlong saltlen; + + if (!(pass_str = (*env)->GetStringUTFChars(env, pass, 0))) { + error_print(); + goto end; + } + if (iter < PBKDF2_MIN_ITER || iter > PBKDF2_MAX_ITER) { + error_print(); + goto end; + } + if (!(saltbuf = (*env)->GetByteArrayElements(env, salt, NULL))) { + error_print(); + goto end; + } + saltlen = (*env)->GetArrayLength(env, salt); + if (saltlen < 1 || saltlen > PBKDF2_MAX_SALT_SIZE) { + error_print(); + goto end; + } + if (keylen < 1 || keylen > sizeof(keybuf)) { + error_print(); + goto end; + } + + if (pbkdf2_hmac_sm3_genkey(pass_str, strlen(pass_str), + (const uint8_t *)saltbuf, saltlen, iter, keylen, keybuf) != 1) { + error_print(); + goto end; + } + + if (!(ret = (*env)->NewByteArray(env, keylen))) { + error_print(); + goto end; + } + (*env)->SetByteArrayRegion(env, ret, 0, keylen, (jbyte *)keybuf); + +end: + if (pass_str) (*env)->ReleaseStringUTFChars(env, pass, pass_str); + if (saltbuf) (*env)->ReleaseByteArrayElements(env, salt, saltbuf, JNI_ABORT); + return ret; +} + /* * Class: org_gmssl_GmSSLJNI * Method: sm4_key_new @@ -994,7 +1051,7 @@ JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1init( error_print(); goto end; } - if (sm4_ctr_encrypt_init((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)keybuf, (uint8_t *)ivbuf) != 1) { + if (sm4_ctr_decrypt_init((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)keybuf, (uint8_t *)ivbuf) != 1) { error_print(); goto end; } @@ -1044,7 +1101,7 @@ JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1update( error_print(); goto end; } - if (sm4_ctr_encrypt_update((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, + if (sm4_ctr_decrypt_update((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)inbuf + in_offset, (size_t)inlen, (uint8_t *)outbuf + out_offset, &outlen) != 1) { error_print(); goto end; @@ -1083,7 +1140,7 @@ JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm4_1ctr_1decrypt_1finish( error_print(); goto end; } - if (sm4_ctr_encrypt_finish((SM4_CTR_CTX *)sm4_ctr_ctx, + if (sm4_ctr_decrypt_finish((SM4_CTR_CTX *)sm4_ctr_ctx, (uint8_t *)outbuf + offset, &outlen) != 1) { error_print(); goto end; diff --git a/src/main/c/gmssljni.h b/src/main/c/gmssljni.h index 9b6ed31..f9dbe2a 100644 --- a/src/main/c/gmssljni.h +++ b/src/main/c/gmssljni.h @@ -13,10 +13,24 @@ extern "C" { #define org_gmssl_GmSSLJNI_SM3_HMAC_SIZE 32L #undef org_gmssl_GmSSLJNI_SM3_HMAC_MIN_KEY_SIZE #define org_gmssl_GmSSLJNI_SM3_HMAC_MIN_KEY_SIZE 16L +#undef org_gmssl_GmSSLJNI_SM3_PBKDF2_MIN_ITER +#define org_gmssl_GmSSLJNI_SM3_PBKDF2_MIN_ITER 10000L +#undef org_gmssl_GmSSLJNI_SM3_PBKDF2_MAX_ITER +#define org_gmssl_GmSSLJNI_SM3_PBKDF2_MAX_ITER 16777216L +#undef org_gmssl_GmSSLJNI_SM3_PBKDF2_MAX_SALT_SIZE +#define org_gmssl_GmSSLJNI_SM3_PBKDF2_MAX_SALT_SIZE 64L +#undef org_gmssl_GmSSLJNI_SM3_PBKDF2_DEFAULT_SALT_SIZE +#define org_gmssl_GmSSLJNI_SM3_PBKDF2_DEFAULT_SALT_SIZE 8L +#undef org_gmssl_GmSSLJNI_SM3_PBKDF2_MAX_KEY_SIZE +#define org_gmssl_GmSSLJNI_SM3_PBKDF2_MAX_KEY_SIZE 256L #undef org_gmssl_GmSSLJNI_SM4_KEY_SIZE #define org_gmssl_GmSSLJNI_SM4_KEY_SIZE 16L #undef org_gmssl_GmSSLJNI_SM4_BLOCK_SIZE #define org_gmssl_GmSSLJNI_SM4_BLOCK_SIZE 16L +#undef org_gmssl_GmSSLJNI_SM4_CBC_IV_SIZE +#define org_gmssl_GmSSLJNI_SM4_CBC_IV_SIZE 16L +#undef org_gmssl_GmSSLJNI_SM4_CTR_IV_SIZE +#define org_gmssl_GmSSLJNI_SM4_CTR_IV_SIZE 16L #undef org_gmssl_GmSSLJNI_SM4_GCM_MIN_IV_SIZE #define org_gmssl_GmSSLJNI_SM4_GCM_MIN_IV_SIZE 1L #undef org_gmssl_GmSSLJNI_SM4_GCM_MAX_IV_SIZE @@ -137,6 +151,14 @@ JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1update JNIEXPORT jint JNICALL Java_org_gmssl_GmSSLJNI_sm3_1hmac_1finish (JNIEnv *, jclass, jlong, jbyteArray); +/* + * Class: org_gmssl_GmSSLJNI + * Method: sm3_pbkdf2 + * Signature: (Ljava/lang/String;[BII)[B + */ +JNIEXPORT jbyteArray JNICALL Java_org_gmssl_GmSSLJNI_sm3_1pbkdf2 + (JNIEnv *, jclass, jstring, jbyteArray, jint, jint); + /* * Class: org_gmssl_GmSSLJNI * Method: sm4_key_new diff --git a/src/main/java/org/gmssl/GmSSLException.java b/src/main/java/org/gmssl/GmSSLException.java index 011e66e..393db56 100644 --- a/src/main/java/org/gmssl/GmSSLException.java +++ b/src/main/java/org/gmssl/GmSSLException.java @@ -9,6 +9,9 @@ package org.gmssl; +/** + * @author gmssl + */ public class GmSSLException extends RuntimeException { public GmSSLException(String reason) { diff --git a/src/main/java/org/gmssl/GmSSLJNI.java b/src/main/java/org/gmssl/GmSSLJNI.java index b0e7b91..64e6dbb 100644 --- a/src/main/java/org/gmssl/GmSSLJNI.java +++ b/src/main/java/org/gmssl/GmSSLJNI.java @@ -11,7 +11,7 @@ public class GmSSLJNI { - public final static String GMSSL_JNI_VERSION = "GmSSL JNI 2.1.0 dev"; + public final static String GMSSL_JNI_VERSION = "GmSSL JNI 3.1.1"; public final static int SM3_DIGEST_SIZE = 32; public final static int SM3_HMAC_SIZE = 32; diff --git a/src/main/java/org/gmssl/NativeLoader.java b/src/main/java/org/gmssl/NativeLoader.java index fe12985..dc119b8 100644 --- a/src/main/java/org/gmssl/NativeLoader.java +++ b/src/main/java/org/gmssl/NativeLoader.java @@ -12,6 +12,7 @@ import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.StandardCopyOption; +import java.util.Optional; import java.util.Properties; /** @@ -116,9 +117,14 @@ static String libExtension(){ private static void checkReferencedLib(){ if("osx".equals(osType())){ String macReferencedLib=PROPERTIES.getProperty("macReferencedLib"); - if(null!=macReferencedLib){ - System.load(macReferencedLib); + Optional optionalStr = Optional.ofNullable(macReferencedLib); + if(optionalStr.isPresent() && !optionalStr.get().isEmpty()){ + File libFile = new File(macReferencedLib); + if(libFile.exists()){ + System.load(macReferencedLib); + } } + } } diff --git a/src/test/java/org/gmssl/Sm3Pbkdf2Test.java b/src/test/java/org/gmssl/Sm3Pbkdf2Test.java index 942c13a..f1aae21 100644 --- a/src/test/java/org/gmssl/Sm3Pbkdf2Test.java +++ b/src/test/java/org/gmssl/Sm3Pbkdf2Test.java @@ -9,6 +9,7 @@ package org.gmssl; +import org.junit.Assert; import org.junit.Test; /** @@ -24,7 +25,7 @@ public class Sm3Pbkdf2Test { * It employs a pseudorandom function to generate the key, and the length of the derived key can be arbitrarily chosen. However, PBKDF2 allows for multiple iterations of the computation to further enhance security. * By incorporating a salt value (random data) along with the plaintext password, PBKDF2 generates a salted key, which greatly improves resistance against attacks like rainbow table attacks. */ - //@Test + @Test public void deriveKeyTest(){ Sm3Pbkdf2 kdf = new Sm3Pbkdf2(); @@ -33,30 +34,9 @@ public void deriveKeyTest(){ String pass = "P@ssw0rd"; byte[] key = kdf.deriveKey(pass, salt, Sm3Pbkdf2.MIN_ITER * 2, 16); - //TODO fix 链接c库异常,可能是C库未找到匹配的方法. 报错信息:Exception in thread "main" java.lang.UnsatisfiedLinkError: 'byte[] org.gmssl.GmSSLJNI.sm3_pbkdf2(java.lang.String, byte[], int, int)' String keyHexStr = HexUtil.byteToHex(key); - System.out.println(keyHexStr); + //System.out.println(keyHexStr); + Assert.assertNotNull("data is empty exception!",keyHexStr); } - - public static void main(String[] args) { - - Sm3Pbkdf2 kdf = new Sm3Pbkdf2(); - - Random rng = new Random(); - byte[] salt = rng.randBytes(Sm3Pbkdf2.DEFAULT_SALT_SIZE); - - String pass = "P@ssw0rd"; - byte[] key = kdf.deriveKey(pass, salt, Sm3Pbkdf2.MIN_ITER * 2, 16); - //TODO fix - //没有对应到方法 - //Exception in thread "main" java.lang.UnsatisfiedLinkError: 'byte[] org.gmssl.GmSSLJNI.sm3_pbkdf2(java.lang.String, byte[], int, int)' - - int i; - System.out.printf("pbkdf2(pass, salt, iter, keylen): "); - for (i = 0; i < key.length; i++) { - System.out.printf("%02x", key[i]); - } - System.out.print("\n"); - } } From a4fc87eb9dcb83409bb5fccc6e7554d75ae365bb Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 15:46:18 +0800 Subject: [PATCH 02/42] Create Maven-CI-release-Windows.yml --- .../workflows/Maven-CI-release-Windows.yml | 61 +++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 .github/workflows/Maven-CI-release-Windows.yml diff --git a/.github/workflows/Maven-CI-release-Windows.yml b/.github/workflows/Maven-CI-release-Windows.yml new file mode 100644 index 0000000..b878a09 --- /dev/null +++ b/.github/workflows/Maven-CI-release-Windows.yml @@ -0,0 +1,61 @@ +# This workflow will build a Java project with Maven, and cache/restore any dependencies to improve the workflow execution time +# For more information see: https://docs.github.com/en/actions/automating-builds-and-tests/building-and-testing-java-with-maven + +# This workflow uses actions that are not certified by GitHub. +# They are provided by a third-party and are governed by +# separate terms of service, privacy policy, and support +# documentation. + +name: Java CI with Maven release-windows + +on: + push: + branches: [ "main" ] + pull_request: + branches: [ "main" ] + +jobs: + build: + + runs-on: windows-latest + + steps: + - uses: actions/checkout@v4 + + - name: Configure build for x86 + uses: ilammy/msvc-dev-cmd@v1 + with: + arch: amd64_x86 + + - name: Set up JDK 18 + uses: actions/setup-java@v2 + with: + java-version: '18' + distribution: 'temurin' + cache: maven + + - name: Download GmSSL release + run: | + Invoke-WebRequest -Uri "https://github.com/guanzhi/GmSSL/archive/refs/tags/v3.1.1.zip" -OutFile "GmSSL-v3.1.1.zip" + + - name: Extract GmSSL + run: | + Expand-Archive -Path "GmSSL-v3.1.1.zip" -DestinationPath "GmSSL" + + - name: Build GmSSL + run: | + cd GmSSL-3.1.1 + mkdir build; + cd build; + cmake .. -G "NMake Makefiles" -DWIN32=ON; + nmake ; + nmake install; + + - name: Build with Maven + run: mvn clean install + + - name: Clean up + if: always() + run: | + Remove-Item -Recurse -Force GmSSLjava-version: '18' + Remove-Item GmSSL-v3.1.1.zip From 60ede8f14eb3fc98d8c07149f798a3b51a8f3761 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 16:58:53 +0800 Subject: [PATCH 03/42] Update Maven-CI-release-Windows.yml --- .github/workflows/Maven-CI-release-Windows.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/Maven-CI-release-Windows.yml b/.github/workflows/Maven-CI-release-Windows.yml index b878a09..d6ae43f 100644 --- a/.github/workflows/Maven-CI-release-Windows.yml +++ b/.github/workflows/Maven-CI-release-Windows.yml @@ -50,6 +50,7 @@ jobs: cmake .. -G "NMake Makefiles" -DWIN32=ON; nmake ; nmake install; + set path=%path%;C:\Program Files\GmSSL\bin; - name: Build with Maven run: mvn clean install From f3f937222f8d966a4db72f2a1ae7738def34aeb4 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 17:25:54 +0800 Subject: [PATCH 04/42] Update Maven-CI-release-Windows.yml --- .github/workflows/Maven-CI-release-Windows.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/Maven-CI-release-Windows.yml b/.github/workflows/Maven-CI-release-Windows.yml index d6ae43f..6c6a87a 100644 --- a/.github/workflows/Maven-CI-release-Windows.yml +++ b/.github/workflows/Maven-CI-release-Windows.yml @@ -50,7 +50,8 @@ jobs: cmake .. -G "NMake Makefiles" -DWIN32=ON; nmake ; nmake install; - set path=%path%;C:\Program Files\GmSSL\bin; + $gmsslPath = "C:\Program Files\GmSSL\bin"; + $env:PATH += ";$gmsslPath"; - name: Build with Maven run: mvn clean install From e5081f4c9e252ff4bb7b1ff9251b15512f9c5f4a Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 17:32:39 +0800 Subject: [PATCH 05/42] Update Maven-CI-release-Windows.yml --- .github/workflows/Maven-CI-release-Windows.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Maven-CI-release-Windows.yml b/.github/workflows/Maven-CI-release-Windows.yml index 6c6a87a..60c7912 100644 --- a/.github/workflows/Maven-CI-release-Windows.yml +++ b/.github/workflows/Maven-CI-release-Windows.yml @@ -44,7 +44,7 @@ jobs: - name: Build GmSSL run: | - cd GmSSL-3.1.1 + cd GmSSL; mkdir build; cd build; cmake .. -G "NMake Makefiles" -DWIN32=ON; From 64610ea0b6d6dbc98f04dca050fcae2b58d806d1 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 17:42:15 +0800 Subject: [PATCH 06/42] Update Maven-CI-release-Windows.yml --- .github/workflows/Maven-CI-release-Windows.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/Maven-CI-release-Windows.yml b/.github/workflows/Maven-CI-release-Windows.yml index 60c7912..ee48653 100644 --- a/.github/workflows/Maven-CI-release-Windows.yml +++ b/.github/workflows/Maven-CI-release-Windows.yml @@ -45,6 +45,7 @@ jobs: - name: Build GmSSL run: | cd GmSSL; + cd GmSSL-3.1.1; mkdir build; cd build; cmake .. -G "NMake Makefiles" -DWIN32=ON; From e8e76479d6a3fff8db036def672cf306486a686f Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 19:34:28 +0800 Subject: [PATCH 07/42] Update and rename Maven-CI-release-Windows.yml to maven-ci-release-windows.yml --- ...n-CI-release-Windows.yml => maven-ci-release-windows.yml} | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) rename .github/workflows/{Maven-CI-release-Windows.yml => maven-ci-release-windows.yml} (94%) diff --git a/.github/workflows/Maven-CI-release-Windows.yml b/.github/workflows/maven-ci-release-windows.yml similarity index 94% rename from .github/workflows/Maven-CI-release-Windows.yml rename to .github/workflows/maven-ci-release-windows.yml index ee48653..ae9b1bf 100644 --- a/.github/workflows/Maven-CI-release-Windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -51,8 +51,9 @@ jobs: cmake .. -G "NMake Makefiles" -DWIN32=ON; nmake ; nmake install; - $gmsslPath = "C:\Program Files\GmSSL\bin"; - $env:PATH += ";$gmsslPath"; + $env:PATH += ";C:\Program Files\GmSSL\bin"; + echo $env:PATH; + gmssl version; - name: Build with Maven run: mvn clean install From 2c6818fe722db4569378d11d152779439b043655 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 20:03:53 +0800 Subject: [PATCH 08/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index ae9b1bf..2a6af59 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -6,7 +6,7 @@ # separate terms of service, privacy policy, and support # documentation. -name: Java CI with Maven release-windows +name: maven-ci-release-windows on: push: From ae500808ae5f73272dc3319ebbc9c07eee56ea18 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 20:22:34 +0800 Subject: [PATCH 09/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index 2a6af59..3ca3d7c 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -51,10 +51,17 @@ jobs: cmake .. -G "NMake Makefiles" -DWIN32=ON; nmake ; nmake install; - $env:PATH += ";C:\Program Files\GmSSL\bin"; - echo $env:PATH; - gmssl version; - + + - name: Build GmSSL + shell: cmd + run: | + echo "##vso[task.prependpath]C:\Program Files\GmSSL\bin" + + - name: Use PATH entry + shell: cmd + run: | + gmssl version + - name: Build with Maven run: mvn clean install From 0eb888ab60a00edfa5847d9c47effcf4148d6e45 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 20:28:10 +0800 Subject: [PATCH 10/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index 3ca3d7c..2cd3967 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -42,7 +42,7 @@ jobs: run: | Expand-Archive -Path "GmSSL-v3.1.1.zip" -DestinationPath "GmSSL" - - name: Build GmSSL + - name: Build GmSSL run: | cd GmSSL; cd GmSSL-3.1.1; @@ -52,7 +52,7 @@ jobs: nmake ; nmake install; - - name: Build GmSSL + - name: Set PATH entry shell: cmd run: | echo "##vso[task.prependpath]C:\Program Files\GmSSL\bin" @@ -60,7 +60,8 @@ jobs: - name: Use PATH entry shell: cmd run: | - gmssl version + echo $env:PATH; + gmssl version; - name: Build with Maven run: mvn clean install From 9a296d9542da50a1735f16a30bd6f0b093cf5dd6 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 20:36:33 +0800 Subject: [PATCH 11/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index 2cd3967..c02b99a 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -55,13 +55,13 @@ jobs: - name: Set PATH entry shell: cmd run: | - echo "##vso[task.prependpath]C:\Program Files\GmSSL\bin" + $env:PATH += ";C:\\Program Files\\GmSSL\bin" + echo "PATH updated to: $env:PATH" - - name: Use PATH entry + - name: Verify PATH entry shell: cmd run: | - echo $env:PATH; - gmssl version; + gmssl version - name: Build with Maven run: mvn clean install From 81bdbbb8d7c885b819975d516b6ceccf387b783e Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Fri, 26 Apr 2024 20:39:14 +0800 Subject: [PATCH 12/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index c02b99a..cb22088 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -55,7 +55,7 @@ jobs: - name: Set PATH entry shell: cmd run: | - $env:PATH += ";C:\\Program Files\\GmSSL\bin" + $env:PATH += ";C:\\Program Files\\GmSSL\\bin" echo "PATH updated to: $env:PATH" - name: Verify PATH entry From d6ba27abe75a1839de9b5a5c599a02a83d288247 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Sun, 28 Apr 2024 08:46:11 +0800 Subject: [PATCH 13/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index cb22088..f5609bf 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -57,6 +57,7 @@ jobs: run: | $env:PATH += ";C:\\Program Files\\GmSSL\\bin" echo "PATH updated to: $env:PATH" + gmssl version - name: Verify PATH entry shell: cmd From f7ce07068940a45192c9cb8bb7afd3c6bdc48208 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Sun, 28 Apr 2024 09:04:16 +0800 Subject: [PATCH 14/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index f5609bf..c074869 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -20,7 +20,7 @@ jobs: runs-on: windows-latest steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@v3 - name: Configure build for x86 uses: ilammy/msvc-dev-cmd@v1 @@ -36,11 +36,11 @@ jobs: - name: Download GmSSL release run: | - Invoke-WebRequest -Uri "https://github.com/guanzhi/GmSSL/archive/refs/tags/v3.1.1.zip" -OutFile "GmSSL-v3.1.1.zip" + Invoke-WebRequest -Uri "https://github.com/guanzhi/GmSSL/archive/refs/tags/v3.1.1.zip" -OutFile "GmSSL.zip" - name: Extract GmSSL run: | - Expand-Archive -Path "GmSSL-v3.1.1.zip" -DestinationPath "GmSSL" + Expand-Archive -Path "GmSSL.zip" -DestinationPath "." - name: Build GmSSL run: | @@ -52,14 +52,12 @@ jobs: nmake ; nmake install; - - name: Set PATH entry + - name: Set up environment shell: cmd run: | - $env:PATH += ";C:\\Program Files\\GmSSL\\bin" - echo "PATH updated to: $env:PATH" - gmssl version + echo "C:\Program Files\GmSSL\bin" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8 -InputObject "Path += ';'" - - name: Verify PATH entry + - name: Verify Installation and Environment shell: cmd run: | gmssl version @@ -71,4 +69,4 @@ jobs: if: always() run: | Remove-Item -Recurse -Force GmSSLjava-version: '18' - Remove-Item GmSSL-v3.1.1.zip + Remove-Item GmSSL.zip From 25b49643fae12c46be4e2e3ff22828721387e08d Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Sun, 28 Apr 2024 09:07:11 +0800 Subject: [PATCH 15/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index c074869..d9bff0d 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -44,7 +44,6 @@ jobs: - name: Build GmSSL run: | - cd GmSSL; cd GmSSL-3.1.1; mkdir build; cd build; From 7d94d9796eab04b83dea0e6191056f3a7bb97be6 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Sun, 28 Apr 2024 09:12:33 +0800 Subject: [PATCH 16/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index d9bff0d..b54636c 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -54,7 +54,7 @@ jobs: - name: Set up environment shell: cmd run: | - echo "C:\Program Files\GmSSL\bin" | Out-File -FilePath $env:GITHUB_ENV -Append -Encoding utf8 -InputObject "Path += ';'" + echo "Path += ';C:\Program Files\GmSSL\bin'" >> $Env:GITHUB_ENV - name: Verify Installation and Environment shell: cmd From c9bfe6f5c78adf16c49bd8f44a6962c564fb6732 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Sun, 28 Apr 2024 09:17:12 +0800 Subject: [PATCH 17/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index b54636c..c189355 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -52,12 +52,12 @@ jobs: nmake install; - name: Set up environment - shell: cmd + shell: pwsh run: | echo "Path += ';C:\Program Files\GmSSL\bin'" >> $Env:GITHUB_ENV - name: Verify Installation and Environment - shell: cmd + shell: pwsh run: | gmssl version From d012137a59262f44f47bb2acff895e3605363e39 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Sun, 28 Apr 2024 09:26:45 +0800 Subject: [PATCH 18/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index c189355..e58a1e4 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -54,7 +54,7 @@ jobs: - name: Set up environment shell: pwsh run: | - echo "Path += ';C:\Program Files\GmSSL\bin'" >> $Env:GITHUB_ENV + echo "C:\Program Files\GmSSL\bin" >> $GITHUB_PATH - name: Verify Installation and Environment shell: pwsh From 0a2fb7122aafeecd2a6c4048302372f15f15d2ad Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Sun, 28 Apr 2024 09:36:30 +0800 Subject: [PATCH 19/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index e58a1e4..a9325fa 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -52,12 +52,10 @@ jobs: nmake install; - name: Set up environment - shell: pwsh run: | echo "C:\Program Files\GmSSL\bin" >> $GITHUB_PATH - name: Verify Installation and Environment - shell: pwsh run: | gmssl version From 7de826b7d1c47677517767b6dcf93f05bcf72352 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 14:09:21 +0800 Subject: [PATCH 20/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index a9325fa..dfaf8d8 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -33,6 +33,12 @@ jobs: java-version: '18' distribution: 'temurin' cache: maven + + - name: Append path to an environment variable in windows + uses: myci-actions/append-to-path-windows@2 + with: + path: C:\Program Files\GmSSL\bin + env-var: PATH - name: Download GmSSL release run: | From 76831226845e37f8c1897e40d862205d203e2de5 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 14:19:28 +0800 Subject: [PATCH 21/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index dfaf8d8..f719a83 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -34,7 +34,7 @@ jobs: distribution: 'temurin' cache: maven - - name: Append path to an environment variable in windows + - name: Set up environment variable in windows uses: myci-actions/append-to-path-windows@2 with: path: C:\Program Files\GmSSL\bin @@ -56,10 +56,6 @@ jobs: cmake .. -G "NMake Makefiles" -DWIN32=ON; nmake ; nmake install; - - - name: Set up environment - run: | - echo "C:\Program Files\GmSSL\bin" >> $GITHUB_PATH - name: Verify Installation and Environment run: | From 13883384dbea748290049bc45f4619cf15ab354a Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 14:29:56 +0800 Subject: [PATCH 22/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index f719a83..a84a354 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -25,7 +25,7 @@ jobs: - name: Configure build for x86 uses: ilammy/msvc-dev-cmd@v1 with: - arch: amd64_x86 + arch: amd64 - name: Set up JDK 18 uses: actions/setup-java@v2 From fdd721c121db3b1bb57937ba51db5b624b3c907b Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 14:38:42 +0800 Subject: [PATCH 23/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index a84a354..83bf9c2 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -67,5 +67,4 @@ jobs: - name: Clean up if: always() run: | - Remove-Item -Recurse -Force GmSSLjava-version: '18' Remove-Item GmSSL.zip From 9eba88a459f86ba906473c05f35aaa07a8ad2b69 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 15:00:48 +0800 Subject: [PATCH 24/42] Create maven-ci-release-ubuntu.yml --- .github/workflows/maven-ci-release-ubuntu.yml | 51 +++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 .github/workflows/maven-ci-release-ubuntu.yml diff --git a/.github/workflows/maven-ci-release-ubuntu.yml b/.github/workflows/maven-ci-release-ubuntu.yml new file mode 100644 index 0000000..c0ae4c6 --- /dev/null +++ b/.github/workflows/maven-ci-release-ubuntu.yml @@ -0,0 +1,51 @@ +name: maven-ci-release-ubuntu + +on: + push: + branches: [ "main" ] + pull_request: + branches: [ "main" ] + +jobs: + build: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v3 + + - name: Set up JDK 18 + uses: actions/setup-java@v2 + with: + java-version: '18' + distribution: 'temurin' + cache: maven + + + + - name: Install dependencies + run: sudo apt-get update && sudo apt-get install -y cmake build-essential + + - name: Download GmSSL release + run: wget "https://github.com/guanzhi/GmSSL/archive/refs/tags/v3.1.1.zip" -O "GmSSL.zip" + + - name: Extract GmSSL + run: unzip GmSSL.zip + + - name: Build GmSSL + run: | + cd GmSSL-3.1.1 + mkdir build + cd build + cmake .. + make + sudo make install + + - name: Verify Installation and Environment + run: gmssl version + + - name: Build with Maven + run: mvn clean install + + - name: Clean up + if: always() + run: rm GmSSL.zip From 781c46a0217e57a3a675561e88b1edd12a6c7f42 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 15:10:21 +0800 Subject: [PATCH 25/42] Update maven-ci-release-ubuntu.yml --- .github/workflows/maven-ci-release-ubuntu.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/maven-ci-release-ubuntu.yml b/.github/workflows/maven-ci-release-ubuntu.yml index c0ae4c6..c468890 100644 --- a/.github/workflows/maven-ci-release-ubuntu.yml +++ b/.github/workflows/maven-ci-release-ubuntu.yml @@ -39,6 +39,7 @@ jobs: cmake .. make sudo make install + sudo ldconfig - name: Verify Installation and Environment run: gmssl version From c52c2abad0359cf9cbb305ba97bfb3f49058e90d Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 15:27:44 +0800 Subject: [PATCH 26/42] Create maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 46 ++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 .github/workflows/maven-ci-release-macos.yml diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml new file mode 100644 index 0000000..f4f30d6 --- /dev/null +++ b/.github/workflows/maven-ci-release-macos.yml @@ -0,0 +1,46 @@ +name: maven-ci-release-macos + +on: + push: + branches: [ "main" ] + pull_request: + branches: [ "main" ] + +jobs: + build: + runs-on: macos-latest + + steps: + - uses: actions/checkout@v3 + + - name: Set up JDK 18 + uses: actions/setup-java@v2 + with: + java-version: '18' + distribution: 'temurin' + cache: maven + + - name: Download GmSSL release + run: curl -L "https://github.com/guanzhi/GmSSL/archive/refs/tags/v3.1.1.zip" -o "GmSSL.zip" + + - name: Extract GmSSL + run: unzip GmSSL.zip + + - name: Build GmSSL + run: | + cd GmSSL-3.1.1 + mkdir build + cd build + cmake .. + make + sudo make install + + - name: Verify Installation and Environment + run: gmssl version + + - name: Build with Maven + run: mvn clean install + + - name: Clean up + if: always() + run: rm GmSSL.zip From 927352c176c907bc4d05ed86383374a7e73abc82 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 15:28:04 +0800 Subject: [PATCH 27/42] Update maven-ci-release-ubuntu.yml --- .github/workflows/maven-ci-release-ubuntu.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.github/workflows/maven-ci-release-ubuntu.yml b/.github/workflows/maven-ci-release-ubuntu.yml index c468890..31a8046 100644 --- a/.github/workflows/maven-ci-release-ubuntu.yml +++ b/.github/workflows/maven-ci-release-ubuntu.yml @@ -20,8 +20,6 @@ jobs: distribution: 'temurin' cache: maven - - - name: Install dependencies run: sudo apt-get update && sudo apt-get install -y cmake build-essential From d7f02f304e90e34a00e9f6c3528a37fd04e8a81f Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 15:31:22 +0800 Subject: [PATCH 28/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index f4f30d6..e26480c 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -34,9 +34,6 @@ jobs: cmake .. make sudo make install - - - name: Verify Installation and Environment - run: gmssl version - name: Build with Maven run: mvn clean install From a8f7e487053e32011bb345ecdafd27a583622d17 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 15:54:20 +0800 Subject: [PATCH 29/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index e26480c..db255c0 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -34,7 +34,10 @@ jobs: cmake .. make sudo make install - + + - name: Verify Installation and Environment + run: gmssl version + - name: Build with Maven run: mvn clean install From bb25221db275f5aa5fa8a4923d3e9e9797d5703c Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 15:56:32 +0800 Subject: [PATCH 30/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index db255c0..ffd8a25 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -34,6 +34,7 @@ jobs: cmake .. make sudo make install + install_name_tool -change /usr/local/lib/libgmssl.3.dylib @rpath/libgmssl.3.dylib /usr/local/lib/libgmssl.dylib - name: Verify Installation and Environment run: gmssl version From 505f087240e6a1a60f2845d6fb13e3d9777d4a36 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:03:57 +0800 Subject: [PATCH 31/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index ffd8a25..011c0d1 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -34,7 +34,7 @@ jobs: cmake .. make sudo make install - install_name_tool -change /usr/local/lib/libgmssl.3.dylib @rpath/libgmssl.3.dylib /usr/local/lib/libgmssl.dylib + sudo install_name_tool -change /usr/local/lib/libgmssl.3.dylib @rpath/libgmssl.3.dylib /usr/local/lib/libgmssl.dylib - name: Verify Installation and Environment run: gmssl version From e3fc86688217c92602c5f90f68a7eeed8de18732 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:10:39 +0800 Subject: [PATCH 32/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index 011c0d1..9eafb73 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -34,7 +34,9 @@ jobs: cmake .. make sudo make install - sudo install_name_tool -change /usr/local/lib/libgmssl.3.dylib @rpath/libgmssl.3.dylib /usr/local/lib/libgmssl.dylib + + - name: Set DYLD_LIBRARY_PATH + run: echo "DYLD_LIBRARY_PATH=/usr/local/lib:$DYLD_LIBRARY_PATH" - name: Verify Installation and Environment run: gmssl version From 2f6c1137fe0e181fd85916b5f7a4b8e77c5128b4 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:13:48 +0800 Subject: [PATCH 33/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index 9eafb73..3db2a5b 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -36,7 +36,7 @@ jobs: sudo make install - name: Set DYLD_LIBRARY_PATH - run: echo "DYLD_LIBRARY_PATH=/usr/local/lib:$DYLD_LIBRARY_PATH" + run: echo "DYLD_LIBRARY_PATH=/usr/local/lib:$DYLD_LIBRARY_PATH" >> $GITHUB_ENV - name: Verify Installation and Environment run: gmssl version From 0bc7a8e91047825205886c96e5c0d17fd1c81414 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:19:57 +0800 Subject: [PATCH 34/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index 3db2a5b..5f73d7e 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -31,7 +31,7 @@ jobs: cd GmSSL-3.1.1 mkdir build cd build - cmake .. + cmake .. -DCMAKE_OSX_ARCHITECTURES=x86_64 make sudo make install From a634ae628a361bbc424302e0d3d895447e8f76e9 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:28:04 +0800 Subject: [PATCH 35/42] Update maven-ci-windows.yml --- .github/workflows/maven-ci-windows.yml | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/.github/workflows/maven-ci-windows.yml b/.github/workflows/maven-ci-windows.yml index 20cce08..470959d 100644 --- a/.github/workflows/maven-ci-windows.yml +++ b/.github/workflows/maven-ci-windows.yml @@ -26,7 +26,7 @@ jobs: - name: Configure build for x86 uses: ilammy/msvc-dev-cmd@v1 with: - arch: amd64_x86 + arch: amd64 - name: Set up JDK 18 uses: actions/setup-java@v2 @@ -35,7 +35,12 @@ jobs: distribution: 'temurin' cache: maven - + - name: Set up environment variable in windows + uses: myci-actions/append-to-path-windows@2 + with: + path: C:\Program Files\GmSSL\bin + env-var: PATH + - name: Build GmSSL run : | git clone https://github.com/guanzhi/GmSSL.git; From cbb3a2ab69963f6ff8c8f93bccc534f072545d6d Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:30:10 +0800 Subject: [PATCH 36/42] Update maven-ci-release-windows.yml --- .github/workflows/maven-ci-release-windows.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-release-windows.yml b/.github/workflows/maven-ci-release-windows.yml index 83bf9c2..3463cb8 100644 --- a/.github/workflows/maven-ci-release-windows.yml +++ b/.github/workflows/maven-ci-release-windows.yml @@ -13,10 +13,11 @@ on: branches: [ "main" ] pull_request: branches: [ "main" ] +env: + BUILD_TYPE: Release jobs: build: - runs-on: windows-latest steps: From 670ee4f40c20564f5372e8a4b41613123d794a1d Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:30:55 +0800 Subject: [PATCH 37/42] Update maven-ci-release-ubuntu.yml --- .github/workflows/maven-ci-release-ubuntu.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/maven-ci-release-ubuntu.yml b/.github/workflows/maven-ci-release-ubuntu.yml index 31a8046..f4696b7 100644 --- a/.github/workflows/maven-ci-release-ubuntu.yml +++ b/.github/workflows/maven-ci-release-ubuntu.yml @@ -5,6 +5,8 @@ on: branches: [ "main" ] pull_request: branches: [ "main" ] +env: + BUILD_TYPE: Release jobs: build: From d06b785575c7826f4f4d49f59399696f52631e47 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:31:24 +0800 Subject: [PATCH 38/42] Update maven-ci-release-macos.yml --- .github/workflows/maven-ci-release-macos.yml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/.github/workflows/maven-ci-release-macos.yml b/.github/workflows/maven-ci-release-macos.yml index 5f73d7e..6e1e689 100644 --- a/.github/workflows/maven-ci-release-macos.yml +++ b/.github/workflows/maven-ci-release-macos.yml @@ -5,6 +5,8 @@ on: branches: [ "main" ] pull_request: branches: [ "main" ] +env: + BUILD_TYPE: Release jobs: build: From 059d84cf1ad091d3271bd4636e18482498f4a1f6 Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:36:06 +0800 Subject: [PATCH 39/42] Update maven-ci-macos.yml --- .github/workflows/maven-ci-macos.yml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-macos.yml b/.github/workflows/maven-ci-macos.yml index 8630e1a..a0c5cb2 100644 --- a/.github/workflows/maven-ci-macos.yml +++ b/.github/workflows/maven-ci-macos.yml @@ -35,9 +35,12 @@ jobs: cd GmSSL mkdir build cd build - cmake .. + cmake .. -DCMAKE_OSX_ARCHITECTURES=x86_64 make sudo make install + - name: Set DYLD_LIBRARY_PATH + run: echo "DYLD_LIBRARY_PATH=/usr/local/lib:$DYLD_LIBRARY_PATH" >> $GITHUB_ENV + - name: Build with Maven run: sudo mvn -B -X package --file pom.xml From efbcc80036b65f33d14d8d1090a7e142c751b77a Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:38:20 +0800 Subject: [PATCH 40/42] Update maven-ci-macos.yml --- .github/workflows/maven-ci-macos.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-macos.yml b/.github/workflows/maven-ci-macos.yml index a0c5cb2..bab7ddb 100644 --- a/.github/workflows/maven-ci-macos.yml +++ b/.github/workflows/maven-ci-macos.yml @@ -13,7 +13,7 @@ on: pull_request: branches: [ "main" ] env: - BUILD_TYPE: Release + BUILD_TYPE: Debug jobs: build: From 27753a5fdc0bced177dea4b35a3e073a3e0b5fec Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:38:43 +0800 Subject: [PATCH 41/42] Update maven-ci-ubuntu.yml --- .github/workflows/maven-ci-ubuntu.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-ubuntu.yml b/.github/workflows/maven-ci-ubuntu.yml index 42cf713..923889e 100644 --- a/.github/workflows/maven-ci-ubuntu.yml +++ b/.github/workflows/maven-ci-ubuntu.yml @@ -14,7 +14,7 @@ on: branches: [ "main" ] env: # Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.) - BUILD_TYPE: Release + BUILD_TYPE: Debug jobs: build: From 5a4e20dba8bb443511e7469f3bdf1a704047d8cb Mon Sep 17 00:00:00 2001 From: "yongfei.li" <290836576@qq.com> Date: Mon, 29 Apr 2024 16:39:05 +0800 Subject: [PATCH 42/42] Update maven-ci-windows.yml --- .github/workflows/maven-ci-windows.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/maven-ci-windows.yml b/.github/workflows/maven-ci-windows.yml index 470959d..dba7e61 100644 --- a/.github/workflows/maven-ci-windows.yml +++ b/.github/workflows/maven-ci-windows.yml @@ -14,7 +14,7 @@ on: pull_request: branches: [ "main" ] env: - BUILD_TYPE: Release + BUILD_TYPE: Debug jobs: build: