From 564bfe0ac41cb78635d5ab27acb7959dd0f31778 Mon Sep 17 00:00:00 2001 From: dmitrybugakov Date: Sat, 26 Aug 2023 23:27:33 +0200 Subject: [PATCH] [WIP]: Add clickhouse SSL\TLS connection --- .../github/housepower/jdbc/AbstractITest.java | 19 +- .../resources/clickhouse/config/config.xml | 1198 +++++++++++++++++ .../resources/clickhouse/config/users.xml | 123 ++ .../src/test/resources/clickhouse/server.crt | 19 + .../src/test/resources/clickhouse/server.jks | Bin 0 -> 2134 bytes .../src/test/resources/clickhouse/server.key | 28 + .../src/test/resources/clickhouse/server.p12 | Bin 0 -> 2594 bytes .../src/test/resources/grpc_config.xml | 32 - .../resources/keymanagement/bin/generate.sh | 42 + 9 files changed, 1424 insertions(+), 37 deletions(-) create mode 100644 clickhouse-native-jdbc/src/test/resources/clickhouse/config/config.xml create mode 100644 clickhouse-native-jdbc/src/test/resources/clickhouse/config/users.xml create mode 100644 clickhouse-native-jdbc/src/test/resources/clickhouse/server.crt create mode 100644 clickhouse-native-jdbc/src/test/resources/clickhouse/server.jks create mode 100644 clickhouse-native-jdbc/src/test/resources/clickhouse/server.key create mode 100644 clickhouse-native-jdbc/src/test/resources/clickhouse/server.p12 delete mode 100644 clickhouse-native-jdbc/src/test/resources/grpc_config.xml create mode 100644 clickhouse-native-jdbc/src/test/resources/keymanagement/bin/generate.sh diff --git a/clickhouse-native-jdbc/src/test/java/com/github/housepower/jdbc/AbstractITest.java b/clickhouse-native-jdbc/src/test/java/com/github/housepower/jdbc/AbstractITest.java index 7175d06b..f5937302 100644 --- a/clickhouse-native-jdbc/src/test/java/com/github/housepower/jdbc/AbstractITest.java +++ b/clickhouse-native-jdbc/src/test/java/com/github/housepower/jdbc/AbstractITest.java @@ -41,27 +41,36 @@ public abstract class AbstractITest implements Serializable { protected static final String CLICKHOUSE_PASSWORD = SystemUtil.loadProp("CLICKHOUSE_PASSWORD", ""); protected static final String CLICKHOUSE_DB = SystemUtil.loadProp("CLICKHOUSE_DB", ""); - protected static final int CLICKHOUSE_GRPC_PORT = 9100; protected static final int CLICKHOUSE_HTTP_PORT = 8123; + protected static final int CLICKHOUSE_HTTPS_PORT = 8443; protected static final int CLICKHOUSE_NATIVE_PORT = 9000; + protected static final int CLICKHOUSE_NATIVE_SECURE_PORT = 9440; @Container public static ClickHouseContainer container = new ClickHouseContainer(CLICKHOUSE_IMAGE) .withEnv("CLICKHOUSE_USER", CLICKHOUSE_USER) .withEnv("CLICKHOUSE_PASSWORD", CLICKHOUSE_PASSWORD) .withEnv("CLICKHOUSE_DB", CLICKHOUSE_DB) - .withExposedPorts(CLICKHOUSE_HTTP_PORT, CLICKHOUSE_NATIVE_PORT, CLICKHOUSE_GRPC_PORT) - .withCopyFileToContainer(MountableFile.forClasspathResource("grpc_config.xml"), "/etc/clickhouse-server/config.d/grpc_config.xml"); + .withExposedPorts(CLICKHOUSE_HTTP_PORT, + CLICKHOUSE_HTTPS_PORT, + CLICKHOUSE_NATIVE_PORT, + CLICKHOUSE_NATIVE_SECURE_PORT) + .withCopyFileToContainer(MountableFile.forClasspathResource("clickhouse/config/config.xml"), + "/etc/clickhouse-server/config.xml") + .withCopyFileToContainer(MountableFile.forClasspathResource("clickhouse/config/users.xml"), + "/etc/clickhouse-server/users.xml") + .withCopyFileToContainer(MountableFile.forClasspathResource("clickhouse/server.key"), + "/etc/clickhouse-server/server.key") + .withCopyFileToContainer(MountableFile.forClasspathResource("clickhouse/server.crt"), + "/etc/clickhouse-server/server.crt"); protected static String CK_HOST; protected static int CK_PORT; - protected static int CK_GRPC_PORT; @BeforeAll public static void extractContainerInfo() { CK_HOST = container.getHost(); CK_PORT = container.getMappedPort(CLICKHOUSE_NATIVE_PORT); - CK_GRPC_PORT = container.getMappedPort(CLICKHOUSE_GRPC_PORT); } /** diff --git a/clickhouse-native-jdbc/src/test/resources/clickhouse/config/config.xml b/clickhouse-native-jdbc/src/test/resources/clickhouse/config/config.xml new file mode 100644 index 00000000..202070de --- /dev/null +++ b/clickhouse-native-jdbc/src/test/resources/clickhouse/config/config.xml @@ -0,0 +1,1198 @@ + + + + + + trace + /var/log/clickhouse-server/clickhouse-server.log + /var/log/clickhouse-server/clickhouse-server.err.log + + 1000M + 10 + + + + + + + + + + + + + + 8123 + + + 9000 + + + 9004 + + + 9005 + + + 8443 + + + 9440 + + + + + + 9009 + + + + + + + + + + + + + + + + + + + + + + + + + + + + 4096 + + + 3 + + + + + false + + + /path/to/ssl_cert_file + /path/to/ssl_key_file + + + false + + + /path/to/ssl_ca_cert_file + + + deflate + + + medium + + + -1 + -1 + + + false + + + + + + + /etc/clickhouse-server/server.crt + /etc/clickhouse-server/server.key + + + none + true + true + sslv2,sslv3 + true + + + + true + true + sslv2,sslv3 + true + + + + RejectCertificateHandler + + + + + + + + + 100 + + + 0 + + + + 10000 + + + 0.9 + + + 4194304 + + + 0 + + + + + + 8589934592 + + + 5368709120 + + + + 1000 + + + 134217728 + + + /var/lib/clickhouse/ + + + /var/lib/clickhouse/tmp/ + + + + + + /var/lib/clickhouse/user_files/ + + + + + + + + + + + + + users.xml + + + + /var/lib/clickhouse/access/ + + + + + + + default + + + + + + + + + + + + default + + + + + + + + + true + + + false + + ' | sed -e 's|.*>\(.*\)<.*|\1|') + wget https://github.com/ClickHouse/clickhouse-jdbc-bridge/releases/download/v$PKG_VER/clickhouse-jdbc-bridge_$PKG_VER-1_all.deb + apt install --no-install-recommends -f ./clickhouse-jdbc-bridge_$PKG_VER-1_all.deb + clickhouse-jdbc-bridge & + + * [CentOS/RHEL] + export MVN_URL=https://repo1.maven.org/maven2/ru/yandex/clickhouse/clickhouse-jdbc-bridge + export PKG_VER=$(curl -sL $MVN_URL/maven-metadata.xml | grep '' | sed -e 's|.*>\(.*\)<.*|\1|') + wget https://github.com/ClickHouse/clickhouse-jdbc-bridge/releases/download/v$PKG_VER/clickhouse-jdbc-bridge-$PKG_VER-1.noarch.rpm + yum localinstall -y clickhouse-jdbc-bridge-$PKG_VER-1.noarch.rpm + clickhouse-jdbc-bridge & + + Please refer to https://github.com/ClickHouse/clickhouse-jdbc-bridge#usage for more information. + ]]> + + + + + + + + + + + + + + + + localhost + 9000 + + + + + + + + + localhost + 9000 + + + + + localhost + 9000 + + + + + + + 127.0.0.1 + 9000 + + + + + 127.0.0.2 + 9000 + + + + + + true + + 127.0.0.1 + 9000 + + + + true + + 127.0.0.2 + 9000 + + + + + + + localhost + 9440 + 1 + + + + + + + localhost + 9000 + + + + + localhost + 1 + + + + + + + + + + + + + + + + + + + + + + + + 3600 + + + + 3600 + + + 60 + + + + + + + + + + + + + system + query_log
+ + toYYYYMM(event_date) + + + + + + 7500 +
+ + + + system + trace_log
+ + toYYYYMM(event_date) + 7500 +
+ + + + system + query_thread_log
+ toYYYYMM(event_date) + 7500 +
+ + + + system + query_views_log
+ toYYYYMM(event_date) + 7500 +
+ + + + system + part_log
+ toYYYYMM(event_date) + 7500 +
+ + + + + + system + metric_log
+ 7500 + 1000 +
+ + + + system + asynchronous_metric_log
+ + 7000 +
+ + + + + + engine MergeTree + partition by toYYYYMM(finish_date) + order by (finish_date, finish_time_us, trace_id) + + system + opentelemetry_span_log
+ 7500 +
+ + + + + system + crash_log
+ + + 1000 +
+ + + + + + + + + + + + + + + + + + + *_dictionary.xml + + + + + + + + + + + + + + /clickhouse/task_queue/ddl + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + click_cost + any + + 0 + 3600 + + + 86400 + 60 + + + + max + + 0 + 60 + + + 3600 + 300 + + + 86400 + 3600 + + + + + + /var/lib/clickhouse/format_schemas/ + + + + + hide encrypt/decrypt arguments + ((?:aes_)?(?:encrypt|decrypt)(?:_mysql)?)\s*\(\s*(?:'(?:\\'|.)+'|.*?)\s*\) + + \1(???) + + + + + + + + + + false + + false + + + https://6f33034cfe684dd7a3ab9875e57b1c8d@o388870.ingest.sentry.io/5226277 + + + + + + + +
\ No newline at end of file diff --git a/clickhouse-native-jdbc/src/test/resources/clickhouse/config/users.xml b/clickhouse-native-jdbc/src/test/resources/clickhouse/config/users.xml new file mode 100644 index 00000000..c7cf0f5b --- /dev/null +++ b/clickhouse-native-jdbc/src/test/resources/clickhouse/config/users.xml @@ -0,0 +1,123 @@ + + + + + + + + + + 10000000000 + + + random + + + + + 1 + + + + + + + + + + + + + ::/0 + + + + default + + + default + + + + + + + + + + + + + + 3600 + + + 0 + 0 + 0 + 0 + 0 + + + + \ No newline at end of file diff --git a/clickhouse-native-jdbc/src/test/resources/clickhouse/server.crt b/clickhouse-native-jdbc/src/test/resources/clickhouse/server.crt new file mode 100644 index 00000000..ed279bd9 --- /dev/null +++ b/clickhouse-native-jdbc/src/test/resources/clickhouse/server.crt @@ -0,0 +1,19 @@ +-----BEGIN CERTIFICATE----- +MIIDCTCCAfGgAwIBAgIUGiof/tcvWR9ITSWwONatZC68ys0wDQYJKoZIhvcNAQEL +BQAwFDESMBAGA1UEAwwJbG9jYWxob3N0MB4XDTIzMDgyNjIxMTczN1oXDTI0MDgy +NTIxMTczN1owFDESMBAGA1UEAwwJbG9jYWxob3N0MIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEAmC1y+HO3QzDIk5DnK6ouUoxCIH6c/zeT/uYSCmvUQU1l +rEWQ5+U/iEAQkmIyK/7yvyHromp+ZfzoVlDANF/5d3OaRcXxLKjVBf1xxELlEzXR +Jw2Vx3KnrxO0P9RXwmuc+n8alYZwxIbt1IPlqGJzgUHd3cFcjXe7Z8dnhAO3zekr +UDRP028LdIrLPGpBanHNKiJv73o3QrNJKLw9l5kDPMlmrXb/9uot4xxYj6L3Kz84 +lACApL04tkH3+W6vadwdzWjPEvFwlLIoRBV1YXnzKUlgNwey6PLDo5jE+2AXR433 +6UPHZJ5XNTtJ1zSe+wiC8xqA5zgv2f/S6KNrGAZ4JQIDAQABo1MwUTAdBgNVHQ4E +FgQUucBNLF7S0DEqgJYTpD0Y6rKZx6kwHwYDVR0jBBgwFoAUucBNLF7S0DEqgJYT +pD0Y6rKZx6kwDwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQsFAAOCAQEAN9i6 +xLrh4DyJOV1KsIM1nrWq1P5wZjQny9i4TmU6doGXIiTIAipXyL8liX5/3qVGZkBb +WYWgQTdfjjZJENSawxUiIQnsvqO83dyzRaMg+yKRUPf6MZTQDxjgmK3BZ6qmMLbj +BhMYAA5r6b6oTW5pmqo+wQxP7doZOiX/Xcjw2iHBtL1jy4rEwsEoOYpH7u0ywWiQ +9WsaYNcm+b452MJBYWeRqxJx4gtvcBFAii2Win5AT/SUTtHQcQKrDxv+osGS5vZj +v+2LxCCNfTmJfIsGPSsyiqulvzzn4xcNE6ETzAcvudx+to9YfUogJYmhsQpc/CBa +7DYS2q7Uf7a7d7xZDw== +-----END CERTIFICATE----- diff --git a/clickhouse-native-jdbc/src/test/resources/clickhouse/server.jks b/clickhouse-native-jdbc/src/test/resources/clickhouse/server.jks new file mode 100644 index 0000000000000000000000000000000000000000..a83d56c291eb3b46ccbc7fcf4efcc7076930f015 GIT binary patch literal 2134 zcmZ`(c{J1u8=jwGFj;48Sz>6Ab*wYC7?Pzs8HBiYAw$NHC4JUJMqEoKJR+bD&9zihGv4oYUk!rmG{iL{u8S5+_>At4QtbJQni)E)q}=7U4OpWPWiI&8n=sYmZ>O{Ymd{f(=k z#XdGJ!rM!{qHrWOdo{GAjt}8Fa8=`_1u)cQex_PeSF(b&T8=J@?z6%yzAkBID!fab zabqGK#csk@O46c`X70zQAD@)@cwe-+OV;(gMFsPk22Qz$-IzG|qrp>nb>K1KL)uuS z`Va8J&W%&{igI_>yQ626OF6JyCNhGLxKB_a<1GiU8~6;!&NCwSf~P-zYtL)&N3^Em z1`Q@LHXairh{elS63E$#n$)T6vM`Yg(6EH8fZqgB2X80&7~db@QqL91bY{btcaDcz zcLq3i6E)XpwbYGQzt7D&4O?ua(XMAUzDU}Wa)>@5V!KyAuOFyydB#*~wL#rz@Z=xR zSlj-jTJhKh``SF`q(2okFQ`&UYbh1Y3U(CY8_8?F=n>cnhEZ$i9bK93`gF7x7kL(uIh?CU8J`w)q0zkYca!$XlZ=5`SJg zZFqKbAZXvZJrTqu7dY)k4@=vZ#rqC9AnVJe@sSG(*}T5NohvXk$Jh9Z?NOx_$lKy7 zvT&E05rOjrY`KVx%*;1_Xp(i>w#~IK%q=4Y~QnSJheK3L^c*!4O#3~WuqDE*l4_@|$FO%xIdJg?Wk$0bmp4b}U#^m^vGrfPyL{i|EE6Jpl{$*rg~Ibf6iB=@arZq?t($aPUe4`l!Xf%#F% zU|v)*uvP-*05~{ABvoV&#x-4Kt#QZ(%vjwe4O-s-iXXzOl4_mG<_CadTp*N)77Qf> z0XuPm`FKN!em)_Wi4j*(C&c-+bx;^>eQhl*v<}+si0U3uz5mkxGnEX;|8xCO7=x1m zLD11fP>y5(02Qi-|B7g{K=tNkFQ`^)INUaui!VMz=N`<%pusFG&cD_&d*Q3;Ei<7U zUv1Tcbvoil86n<(@0&CJm9E!zbi_T&*K2B3qg?x>Zu75jy5!e%$0&W{vRK@GsjS!DrCHET>umsY8iac>8 z7Hv+oQKp#`6oHNZ2&juX-1@FQCw(!ijIC;lxeH2s+=*$$vbRI)gFea(Tpon2h23pZ zJ|i0Gb8X|4jW?RR>Dzi&d13dix42a%d(ooj(nA+LBb#yEhr2w<8 zOF&|f9AE$hlslsAQ8Gu4%Ls6aaf&>Dg;Vo9PKm=Aw!BJsVcsOKq4_OG@ArvyqY z@qY^h{}R9f;EB#i>gy|<|1I&JRy;*`qd)?8u5n|oz5|u~rF1;+LO?{+VmdowR zQ}FB^t-C{l5;KK$jKJy&RO=iBE&&n){=5P9g)yE=(rG;UN-7 zjiA&)86#(Y%a6XC(Jhx5XORA{42X%UHo4{r-FRV6oF85a|C3wu`N#Oytc!8Ba>(@3 sMyUIqoZFHhuIPPb)yoXD^L0LEp+w*UYD literal 0 HcmV?d00001 diff --git a/clickhouse-native-jdbc/src/test/resources/clickhouse/server.key b/clickhouse-native-jdbc/src/test/resources/clickhouse/server.key new file mode 100644 index 00000000..357188fc --- /dev/null +++ b/clickhouse-native-jdbc/src/test/resources/clickhouse/server.key @@ -0,0 +1,28 @@ +-----BEGIN PRIVATE KEY----- +MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQCYLXL4c7dDMMiT +kOcrqi5SjEIgfpz/N5P+5hIKa9RBTWWsRZDn5T+IQBCSYjIr/vK/Ieuian5l/OhW +UMA0X/l3c5pFxfEsqNUF/XHEQuUTNdEnDZXHcqevE7Q/1FfCa5z6fxqVhnDEhu3U +g+WoYnOBQd3dwVyNd7tnx2eEA7fN6StQNE/Tbwt0iss8akFqcc0qIm/vejdCs0ko +vD2XmQM8yWatdv/26i3jHFiPovcrPziUAICkvTi2Qff5bq9p3B3NaM8S8XCUsihE +FXVhefMpSWA3B7Lo8sOjmMT7YBdHjffpQ8dknlc1O0nXNJ77CILzGoDnOC/Z/9Lo +o2sYBnglAgMBAAECggEAFJKXB48+jWb+brNOX+D5XdqCpA70iCzfepG9ivV0iUF+ +hxwT0MMgDs+OY05tdvTX+fk1eExfpcew3IkSeuImARKP9B0kPhky90TXSPo8KsKB +8dQh1V1NiFsoaTVP30OaF2Pwgu9dC7csAX4KoZ7G+7NHsbokGic/dB0JLwKA/4/v +vSAEpyZpoCEK9AjfqkFNYHTtuAmuIfBvHGcDdcDHsCh+c1MevqTlL5wBElr8RKJ7 +Vxb4eApwwWLB2aQnmcyCOpJQtb/XpuMNZ5/IsBNVmUDCRNYbKCFx4Ts/mwVbL1jz +e4YD1DKiEtZ9Wzy7saZFIM2L7k8JuUomGucuqUHaLwKBgQDWnFLtwB7Lcbmv3QWz +CDrNqFOTTrlLEbLgawXeCFyuL/QKSiI7VLGYo3FfCBMKE9bQf11AYKlP6dhW7f/G +z0iHuy4wKhPHPKDmsJT3lnJlshayxjyr5RfT29bfz0vw/UJ+U4bEs46rTkEi6ZyW +pCopD+az0BvyidkjQAMjbBW1HwKBgQC1hrOJ8eZkX5tCflRNVqmuX6QkINOLhErw +4I41i0oaJVD0KU3hLHtTD57bn36q8tWuaFrubUir9OSz9r1nLCc4uu2OUUn0t9sy +IvoG4JHWHkFdaOxGheWFdoCkTRnyU8mb4196h7C2MIQ6a6SwuaF9y9/p7l1/JjWu +PI6vq1kGOwKBgQCGWwWb7Iwa587NJ7z6sWtG91ujPETKl4D5+GaK84c6UbEhg/nc +VRB+M8y1JvPsejEhBKuXsywsaITVH1ji2UBaITgwVRdewzkkU2ZffmOOASkusOao +4trA+r+SDFBJxfQL7DTSDmuCGZKzzbcHpCz02gyfg+kLNXuoEtokIfWRFwKBgGFR +YOmgfTLsqrEgRxPbVUa90aLo0mDmwMKYsMT18vlHbjon9q+0iD1Ej5cQz/jYDUTe +f3l5r085EG+G5Y3tdu2MEZWN8Qc4llQvujl7pdPUDpkEij9Yw28k09zB1Ro8X0aq +xGJNYqiaJBmp4fY43uIxLc8dUpS7KGZL4vc89pJHAoGAET1i4vxlD6BMgwJCyCmc +afJ5Eh4WrrBYM+E4emGS0/pgeRkjRk5cCaKJ/IEO8x2uxr/EGmlZa+ki8ETc8/9m +LG9sX9za2lg9tiZW8A676hheVHe4IOIjkldey9ovxm8ar12PECwgkkJ6WXeG4uzJ +lqaPsbBiOzZvBiBBJLpydYY= +-----END PRIVATE KEY----- diff --git a/clickhouse-native-jdbc/src/test/resources/clickhouse/server.p12 b/clickhouse-native-jdbc/src/test/resources/clickhouse/server.p12 new file mode 100644 index 0000000000000000000000000000000000000000..eb7c886c044c856787dbdd0362b5f671e68d1ad9 GIT binary patch literal 2594 zcmai$S5Om*5{459LVyseLg*k!v4nD>^w5hKkS+*F7bQxs(jrw6Lkm6hjua_M6Of%zD4 zF9-vEdn$LpF(CFo)|q?^=yaO)ga!yWEeC%bAl&lbh7JNZfJ^>qnc;jOhSj?J#ljq) zt!QW%0C46r4FBIo1EvGO`Okpw#OMKCXhA?J5G%r0$gc3DbG=@=rdsR8jC%xz7F!I5 zDLOSa%2usfVR>C%^Aa1L;P@B|qZu5Kio(tS9jnoV;|Ut`7>~;?ftHu8P{3sFlSV&% z)S&g9Sf4k>N*>bOaNWim+KCMA3p%6d zFCD?f$uBgi|Aw>OqSkY&bb!kz^ zV=;64wh}TJ3KI(&dcirxzOI&*kLq zw6uKKAXO0^eCIftNbZVpQ!hXAm(X!lv&v5%H#!OUWetXCCv?v=?sHMM%9X_$h&zs) z;OTbh`Ly$1VS=g|_y;3w7k~BHs{;ypP3R1F^z1YCPqJ@dKkKes(JO2#;YIC<5g#r( z#rsFvp(4!}w0s~EL{cHWslJi~Aq;jD@-3&@o_*ds_1q8alEKtd*3YPNQXov}XVL}o zvE_8q!+K1@5-^wdyTlb{67=&4v+V{oFws@Cgx{uWVglv}C=U~#Qy%#awKG~AYh|AQ zOMy*6h0l#UM(b=x2udBa!sgeRar3c&a+yB!+Y8rS<=Ki=qgy8C<9X)1hF^i#@>(7V z7_Shzy$FFR-WHm>aATYME79vRp6NZhv0GHUYo%r6DCBFRTjljGZA|n%kD3<)ba}p6 z*=Cacpxm%*i%uwsZat|QT7JDne!E>PTAwI`lhUdgW`eo>pMbF9?rmG4)IzGY!phACH(Eg$(5T`)(lIY)K1IYU@>yp3 z!rfW1*Uvg&M#rgBp=~Er-)Nq?<(MIw@L-|Nu?!czNPB!w9@HJz&gsE%?~`Qbb#g1{ zQCn#8_ddh{MTNupYQ{`TzJi+JUfib>-j=7%N#=kbJ$qVT*UN@ohCE#tFZxA4`{@#D z-||KiH=e^3T5lqF#OL(@cAo7O8qPVMK_#eK@cf*hF zl}a0Gi5=}sjfGfRK9-XjQepC13vpX*8t+MMxg-B1wvWZXVeO#?rJ&k@nemhGZk1%C z0IOxm>~o7J+D}mgyCxH4)N$K5lFONdI-uQDOB-*slj_&yC?ig0ZYq9LHUm4eejAfC z8k=Lo>gOkv`pUA0T)r_yL<>_qTzu_NFDS(1 zwk9uft~UaP(`M<@vX>KD=qI~3>wF~`)Gz+6&~fds#4x+=c^+;tH-ej!d`|^c?}y;8 zu-NAekg7;ewsELj$VIfm_*~G-haSg|&#i&fp}HG~rucNpf)LAtQIA&hSX4Ie4!>Eh zobw#p_6hIcmpAMLJ~cj)+ChGEYUzY+z|QU$ZVWjGsF&7^M+^QkU?1}_QqTEVT1u9S zj%4S|eSIa-$?;3ME}i>Ozw!PHvOLe7otw69j<+a+W^Y5{Q^b*V88?%{D26X=t%Y~I zS459?VPWNb2=r~EkXt2v9`mEGI<6)Lj%n{~NsYAgiER(Fzhp$N4pZC&y% zUj}w9>|Ec9##64R)jr44s}=G}ikRR~^gE?G-soYG$>=(3C;knR@+NeRTO8oJ{M^sC zu$cclf1Jav-}Be?iMxxv8<9QR-0v)(3)1y;tf(UcK^oYzC%@PNWKsU|?z?_bk8j=Z zSQ=AytA(NfP$b{Gz%>uWH>UXXK4lTHI(gGNOMBHn%Z7IUcA_y5$?xQ2=%SrAI$6h0nc#Ds)yhEzi`z~h6#OrN`@a5bvLCe&dGFE1s~p053k6WLm;Di~hdQ#0^Tit;Q@Nbk=WJ90G4I-yskSbLnS7+ORmwEKASd`)ncEW(lm_9&y z;y>jP{>`^rCLUsZap5Dy1hgQd_4_OOhoWFk8CC%n02&YkZ~%A!+)uL)T=b94C36*8z#;#BS2RF607%G=Xy5If%Oko4CNz)iPqs!b gPWR~bnyS&NSk{`FXN`jxx*HxyT4~3p|0ePO00WM{nE(I) literal 0 HcmV?d00001 diff --git a/clickhouse-native-jdbc/src/test/resources/grpc_config.xml b/clickhouse-native-jdbc/src/test/resources/grpc_config.xml deleted file mode 100644 index a6416daf..00000000 --- a/clickhouse-native-jdbc/src/test/resources/grpc_config.xml +++ /dev/null @@ -1,32 +0,0 @@ - - - 9100 - - false - - - /path/to/ssl_cert_file - /path/to/ssl_key_file - - - false - - - /path/to/ssl_ca_cert_file - - - deflate - - - medium - - - -1 - -1 - - - true - - diff --git a/clickhouse-native-jdbc/src/test/resources/keymanagement/bin/generate.sh b/clickhouse-native-jdbc/src/test/resources/keymanagement/bin/generate.sh new file mode 100644 index 00000000..eb93e96a --- /dev/null +++ b/clickhouse-native-jdbc/src/test/resources/keymanagement/bin/generate.sh @@ -0,0 +1,42 @@ +#!/bin/sh + +# Versions: +# Windows 10 +# OpenSSL Version: OpenSSL 3.1.2 1 +# Keytool Version: openjdk-17.0.2 + +KEY_FILE=server.key +CRT_FILE=server.crt +PKCS12_FILE=server.p12 +JKS_FILE=server.jks +PASSWORD=mypassword +ALIAS=myalias + +echo "Generating the private key and certificate..." +openssl req -subj "//CN=localhost" -new -newkey rsa:2048 -days 365 -nodes -x509 -keyout ${KEY_FILE} -out ${CRT_FILE} +if [ $? -ne 0 ]; then + echo "Failed to generate the private key and certificate." + exit 1 +fi + +echo "Converting to PKCS12 format..." +openssl pkcs12 -export -in ${CRT_FILE} -inkey ${KEY_FILE} -out ${PKCS12_FILE} -name ${ALIAS} -password pass:${PASSWORD} +if [ $? -ne 0 ]; then + echo "Failed to convert to PKCS12 format." + exit 1 +fi + +echo "Importing keystore ${PKCS12_FILE} to ${JKS_FILE}..." +keytool -importkeystore\ + -srckeystore ${PKCS12_FILE}\ + -srcstoretype PKCS12\ + -srcstorepass ${PASSWORD}\ + -destkeystore ${JKS_FILE}\ + -deststoretype JKS\ + -deststorepass ${PASSWORD} +if [ $? -ne 0 ]; then + echo "Failed to import keystore." + exit 1 +fi + +echo "Done!" \ No newline at end of file