Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
B
brpc
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
brpc
Commits
f7aab8c9
Unverified
Commit
f7aab8c9
authored
Jan 31, 2019
by
old-bear
Committed by
GitHub
Jan 31, 2019
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #629 from mesalock-linux/mesalink-tls-backend
tls: MesaLink TLS backend for RPC over TLS
parents
4409f452
d0589fbb
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
178 additions
and
57 deletions
+178
-57
.travis.yml
.travis.yml
+3
-0
build_in_travis_ci.sh
build_in_travis_ci.sh
+6
-1
config_brpc.sh
config_brpc.sh
+17
-1
controller.h
src/brpc/controller.h
+5
-0
mesalink_ssl_helper.cpp
src/brpc/details/mesalink_ssl_helper.cpp
+0
-0
ssl_helper.cpp
src/brpc/details/ssl_helper.cpp
+5
-0
ssl_helper.h
src/brpc/details/ssl_helper.h
+6
-0
global.cpp
src/brpc/global.cpp
+5
-0
socket.cpp
src/brpc/socket.cpp
+6
-1
iobuf.cpp
src/butil/iobuf.cpp
+13
-0
iobuf.h
src/butil/iobuf.h
+4
-0
brpc_ssl_unittest.cpp
test/brpc_ssl_unittest.cpp
+6
-0
cert1.crt
test/cert1.crt
+23
-12
cert1.key
test/cert1.key
+28
-15
cert2.crt
test/cert2.crt
+23
-12
cert2.key
test/cert2.key
+28
-15
No files found.
.travis.yml
View file @
f7aab8c9
...
@@ -10,6 +10,8 @@ env:
...
@@ -10,6 +10,8 @@ env:
-
PURPOSE=compile
-
PURPOSE=compile
-
PURPOSE=unittest
-
PURPOSE=unittest
-
PURPOSE=compile-with-bazel
-
PURPOSE=compile-with-bazel
-
PURPOSE=compile USE_MESALINK=yes
-
PURPOSE=unittest USE_MESALINK=yes
before_script
:
before_script
:
-
ulimit -c unlimited -S
# enable core dumps
-
ulimit -c unlimited -S
# enable core dumps
...
@@ -23,6 +25,7 @@ install:
...
@@ -23,6 +25,7 @@ install:
-
sudo apt-get install -qq realpath libgflags-dev libprotobuf-dev libprotoc-dev protobuf-compiler libleveldb-dev libgoogle-perftools-dev libboost-dev libssl-dev libevent-dev libboost-test-dev
-
sudo apt-get install -qq realpath libgflags-dev libprotobuf-dev libprotoc-dev protobuf-compiler libleveldb-dev libgoogle-perftools-dev libboost-dev libssl-dev libevent-dev libboost-test-dev
-
sudo apt-get install libgtest-dev && cd /usr/src/gtest && sudo env "PATH=$PATH" cmake . && sudo make && sudo mv libgtest* /usr/lib/ && cd -
-
sudo apt-get install libgtest-dev && cd /usr/src/gtest && sudo env "PATH=$PATH" cmake . && sudo make && sudo mv libgtest* /usr/lib/ && cd -
-
sudo apt-get install -y gdb
# install gdb
-
sudo apt-get install -y gdb
# install gdb
-
if [[ "$USE_MESALINK" == "yes" ]]; then curl https://sh.rustup.rs -sSf | sh -s -- -y && source $HOME/.cargo/env && wget https://github.com/mesalock-linux/mesalink/archive/v0.8.0.tar.gz && tar -xf v0.8.0.tar.gz && cd mesalink-0.8.0 && ./autogen.sh --prefix=/usr/ && make && sudo make install && cd - ; fi
script
:
script
:
-
if [[ "$PURPOSE" == "compile-with-bazel" ]]; then bazel build -j 12 -c opt --copt -DHAVE_ZLIB=1 //... ; fi
-
if [[ "$PURPOSE" == "compile-with-bazel" ]]; then bazel build -j 12 -c opt --copt -DHAVE_ZLIB=1 //... ; fi
...
...
build_in_travis_ci.sh
View file @
f7aab8c9
...
@@ -21,8 +21,13 @@ runcmd(){
...
@@ -21,8 +21,13 @@ runcmd(){
echo
"build combination: PURPOSE=
$PURPOSE
CXX=
$CXX
CC=
$CC
"
echo
"build combination: PURPOSE=
$PURPOSE
CXX=
$CXX
CC=
$CC
"
EXTRA_BUILD_OPTS
=
""
if
[
"
$USE_MESALINK
"
=
"yes"
]
;
then
EXTRA_BUILD_OPTS
=
"
$EXTRA_BUILD_OPTS
--with-mesalink"
fi
# The default env in travis-ci is Ubuntu.
# The default env in travis-ci is Ubuntu.
if
!
sh config_brpc.sh
--headers
=
/usr/include
--libs
=
/usr/lib
--nodebugsymbols
--cxx
=
$CXX
--cc
=
$CC
;
then
if
!
sh config_brpc.sh
--headers
=
/usr/include
--libs
=
/usr/lib
--nodebugsymbols
--cxx
=
$CXX
--cc
=
$CC
$EXTRA_BUILD_OPTS
;
then
echo
"Fail to configure brpc"
echo
"Fail to configure brpc"
exit
1
exit
1
fi
fi
...
...
config_brpc.sh
View file @
f7aab8c9
...
@@ -21,9 +21,10 @@ else
...
@@ -21,9 +21,10 @@ else
LDD
=
ldd
LDD
=
ldd
fi
fi
TEMP
=
`
getopt
-o
v:
--long
headers:,libs:,cc:,cxx:,with-glog,with-thrift,nodebugsymbols
-n
'config_brpc'
--
"
$@
"
`
TEMP
=
`
getopt
-o
v:
--long
headers:,libs:,cc:,cxx:,with-glog,with-thrift,
with-mesalink,
nodebugsymbols
-n
'config_brpc'
--
"
$@
"
`
WITH_GLOG
=
0
WITH_GLOG
=
0
WITH_THRIFT
=
0
WITH_THRIFT
=
0
WITH_MESALINK
=
0
DEBUGSYMBOLS
=
-g
DEBUGSYMBOLS
=
-g
if
[
$?
!=
0
]
;
then
>
&2
$ECHO
"Terminating..."
;
exit
1
;
fi
if
[
$?
!=
0
]
;
then
>
&2
$ECHO
"Terminating..."
;
exit
1
;
fi
...
@@ -46,6 +47,7 @@ while true; do
...
@@ -46,6 +47,7 @@ while true; do
--cxx
)
CXX
=
$2
;
shift
2
;;
--cxx
)
CXX
=
$2
;
shift
2
;;
--with-glog
)
WITH_GLOG
=
1
;
shift
1
;;
--with-glog
)
WITH_GLOG
=
1
;
shift
1
;;
--with-thrift
)
WITH_THRIFT
=
1
;
shift
1
;;
--with-thrift
)
WITH_THRIFT
=
1
;
shift
1
;;
--with-mesalink
)
WITH_MESALINK
=
1
;
shift
1
;;
--nodebugsymbols
)
DEBUGSYMBOLS
=
;
shift
1
;;
--nodebugsymbols
)
DEBUGSYMBOLS
=
;
shift
1
;;
--
)
shift
;
break
;;
--
)
shift
;
break
;;
*
)
break
;;
*
)
break
;;
...
@@ -137,8 +139,18 @@ find_dir_of_header_or_die() {
...
@@ -137,8 +139,18 @@ find_dir_of_header_or_die() {
#PTHREAD_HDR=$(find_dir_of_header_or_die pthread.h)
#PTHREAD_HDR=$(find_dir_of_header_or_die pthread.h)
OPENSSL_HDR
=
$(
find_dir_of_header_or_die openssl/ssl.h
)
OPENSSL_HDR
=
$(
find_dir_of_header_or_die openssl/ssl.h
)
if
[
$WITH_MESALINK
!=
0
]
;
then
MESALINK_HDR
=
$(
find_dir_of_header_or_die mesalink/openssl/ssl.h
)
OPENSSL_HDR
=
"
$OPENSSL_HDR
\n
$MESALINK_HDR
"
fi
STATIC_LINKINGS
=
STATIC_LINKINGS
=
DYNAMIC_LINKINGS
=
"-lpthread -lssl -lcrypto -ldl -lz"
DYNAMIC_LINKINGS
=
"-lpthread -lssl -lcrypto -ldl -lz"
if
[
$WITH_MESALINK
!=
0
]
;
then
DYNAMIC_LINKINGS
=
"
$DYNAMIC_LINKINGS
-lmesalink"
fi
if
[
"
$SYSTEM
"
=
"Linux"
]
;
then
if
[
"
$SYSTEM
"
=
"Linux"
]
;
then
DYNAMIC_LINKINGS
=
"
$DYNAMIC_LINKINGS
-lrt"
DYNAMIC_LINKINGS
=
"
$DYNAMIC_LINKINGS
-lrt"
fi
fi
...
@@ -304,6 +316,10 @@ if [ $WITH_THRIFT != 0 ]; then
...
@@ -304,6 +316,10 @@ if [ $WITH_THRIFT != 0 ]; then
fi
fi
fi
fi
if
[
$WITH_MESALINK
!=
0
]
;
then
CPPFLAGS
=
"
${
CPPFLAGS
}
-DUSE_MESALINK"
fi
append_to_output
"CPPFLAGS=
${
CPPFLAGS
}
"
append_to_output
"CPPFLAGS=
${
CPPFLAGS
}
"
append_to_output
"ifeq (
\$
(NEED_LIBPROTOC), 1)"
append_to_output
"ifeq (
\$
(NEED_LIBPROTOC), 1)"
...
...
src/brpc/controller.h
View file @
f7aab8c9
...
@@ -48,7 +48,12 @@
...
@@ -48,7 +48,12 @@
#endif
#endif
extern
"C"
{
extern
"C"
{
#ifndef USE_MESALINK
struct
x509_st
;
struct
x509_st
;
#else
#include <mesalink/openssl/x509.h>
#define x509_st X509
#endif
}
}
namespace
brpc
{
namespace
brpc
{
...
...
src/brpc/details/mesalink_ssl_helper.cpp
0 → 100644
View file @
f7aab8c9
This diff is collapsed.
Click to expand it.
src/brpc/details/ssl_helper.cpp
View file @
f7aab8c9
...
@@ -14,6 +14,9 @@
...
@@ -14,6 +14,9 @@
// Authors: Rujie Jiang (jiangrujie@baidu.com)
// Authors: Rujie Jiang (jiangrujie@baidu.com)
#ifndef USE_MESALINK
#include <sys/socket.h> // recv
#include <sys/socket.h> // recv
#include <openssl/ssl.h>
#include <openssl/ssl.h>
#include <openssl/err.h>
#include <openssl/err.h>
...
@@ -829,3 +832,5 @@ void Print(std::ostream& os, X509* cert, const char* sep) {
...
@@ -829,3 +832,5 @@ void Print(std::ostream& os, X509* cert, const char* sep) {
}
}
}
// namespace brpc
}
// namespace brpc
#endif // USE_MESALINK
src/brpc/details/ssl_helper.h
View file @
f7aab8c9
...
@@ -18,9 +18,15 @@
...
@@ -18,9 +18,15 @@
#define BRPC_SSL_HELPER_H
#define BRPC_SSL_HELPER_H
#include <string.h>
#include <string.h>
#ifndef USE_MESALINK
#include <openssl/ssl.h>
#include <openssl/ssl.h>
// For some versions of openssl, SSL_* are defined inside this header
// For some versions of openssl, SSL_* are defined inside this header
#include <openssl/ossl_typ.h>
#include <openssl/ossl_typ.h>
#else
#include <mesalink/openssl/ssl.h>
#include <mesalink/openssl/err.h>
#include <mesalink/openssl/x509.h>
#endif
#include "brpc/socket_id.h" // SocketId
#include "brpc/socket_id.h" // SocketId
#include "brpc/ssl_options.h" // ServerSSLOptions
#include "brpc/ssl_options.h" // ServerSSLOptions
...
...
src/brpc/global.cpp
View file @
f7aab8c9
...
@@ -14,8 +14,13 @@
...
@@ -14,8 +14,13 @@
// Authors: Ge,Jun (gejun@baidu.com)
// Authors: Ge,Jun (gejun@baidu.com)
#ifndef USE_MESALINK
#include <openssl/ssl.h>
#include <openssl/ssl.h>
#include <openssl/conf.h>
#include <openssl/conf.h>
#else
#include <mesalink/openssl/ssl.h>
#endif
#include <gflags/gflags.h>
#include <gflags/gflags.h>
#include <fcntl.h> // O_RDONLY
#include <fcntl.h> // O_RDONLY
#include <signal.h>
#include <signal.h>
...
...
src/brpc/socket.cpp
View file @
f7aab8c9
...
@@ -19,6 +19,11 @@
...
@@ -19,6 +19,11 @@
#include "butil/compat.h" // OS_MACOSX
#include "butil/compat.h" // OS_MACOSX
#include <openssl/ssl.h>
#include <openssl/ssl.h>
#include <openssl/err.h>
#include <openssl/err.h>
#ifdef USE_MESALINK
#include <mesalink/openssl/ssl.h>
#include <mesalink/openssl/err.h>
#include <mesalink/openssl/x509.h>
#endif
#include <netinet/tcp.h> // getsockopt
#include <netinet/tcp.h> // getsockopt
#include <gflags/gflags.h>
#include <gflags/gflags.h>
#include "bthread/unstable.h" // bthread_timer_del
#include "bthread/unstable.h" // bthread_timer_del
...
@@ -1834,7 +1839,7 @@ int Socket::SSLHandshake(int fd, bool server_mode) {
...
@@ -1834,7 +1839,7 @@ int Socket::SSLHandshake(int fd, bool server_mode) {
LOG
(
ERROR
)
<<
"Fail to CreateSSLSession"
;
LOG
(
ERROR
)
<<
"Fail to CreateSSLSession"
;
return
-
1
;
return
-
1
;
}
}
#if
def SSL_CTRL_SET_TLSEXT_HOSTNAME
#if
defined(SSL_CTRL_SET_TLSEXT_HOSTNAME) || defined(USE_MESALINK)
if
(
!
_ssl_ctx
->
sni_name
.
empty
())
{
if
(
!
_ssl_ctx
->
sni_name
.
empty
())
{
SSL_set_tlsext_host_name
(
_ssl_session
,
_ssl_ctx
->
sni_name
.
c_str
());
SSL_set_tlsext_host_name
(
_ssl_session
,
_ssl_ctx
->
sni_name
.
c_str
());
}
}
...
...
src/butil/iobuf.cpp
View file @
f7aab8c9
...
@@ -17,6 +17,10 @@
...
@@ -17,6 +17,10 @@
// Date: Thu Nov 22 13:57:56 CST 2012
// Date: Thu Nov 22 13:57:56 CST 2012
#include <openssl/ssl.h> // SSL_*
#include <openssl/ssl.h> // SSL_*
#ifdef USE_MESALINK
#include <mesalink/openssl/ssl.h>
#include <mesalink/openssl/err.h>
#endif
#include <sys/syscall.h> // syscall
#include <sys/syscall.h> // syscall
#include <fcntl.h> // O_RDONLY
#include <fcntl.h> // O_RDONLY
#include <errno.h> // errno
#include <errno.h> // errno
...
@@ -1033,6 +1037,7 @@ ssize_t IOBuf::cut_multiple_into_SSL_channel(SSL* ssl, IOBuf* const* pieces,
...
@@ -1033,6 +1037,7 @@ ssize_t IOBuf::cut_multiple_into_SSL_channel(SSL* ssl, IOBuf* const* pieces,
}
}
}
}
#ifndef USE_MESALINK
// Flush remaining data inside the BIO buffer layer
// Flush remaining data inside the BIO buffer layer
BIO
*
wbio
=
SSL_get_wbio
(
ssl
);
BIO
*
wbio
=
SSL_get_wbio
(
ssl
);
if
(
BIO_wpending
(
wbio
)
>
0
)
{
if
(
BIO_wpending
(
wbio
)
>
0
)
{
...
@@ -1043,6 +1048,14 @@ ssize_t IOBuf::cut_multiple_into_SSL_channel(SSL* ssl, IOBuf* const* pieces,
...
@@ -1043,6 +1048,14 @@ ssize_t IOBuf::cut_multiple_into_SSL_channel(SSL* ssl, IOBuf* const* pieces,
return
rc
;
return
rc
;
}
}
}
}
#else
int
rc
=
SSL_flush
(
ssl
);
if
(
rc
<=
0
)
{
*
ssl_error
=
SSL_ERROR_SYSCALL
;
return
rc
;
}
#endif
return
nw
;
return
nw
;
}
}
...
...
src/butil/iobuf.h
View file @
f7aab8c9
...
@@ -39,7 +39,11 @@ struct const_iovec {
...
@@ -39,7 +39,11 @@ struct const_iovec {
const
void
*
iov_base
;
const
void
*
iov_base
;
size_t
iov_len
;
size_t
iov_len
;
};
};
#ifndef USE_MESALINK
struct
ssl_st
;
struct
ssl_st
;
#else
#define ssl_st MESALINK_SSL
#endif
}
}
namespace
butil
{
namespace
butil
{
...
...
test/brpc_ssl_unittest.cpp
View file @
f7aab8c9
...
@@ -109,6 +109,7 @@ TEST_F(SSLTest, sanity) {
...
@@ -109,6 +109,7 @@ TEST_F(SSLTest, sanity) {
brpc
::
Channel
channel
;
brpc
::
Channel
channel
;
brpc
::
ChannelOptions
coptions
;
brpc
::
ChannelOptions
coptions
;
coptions
.
mutable_ssl_options
();
coptions
.
mutable_ssl_options
();
coptions
.
mutable_ssl_options
()
->
sni_name
=
"localhost"
;
ASSERT_EQ
(
0
,
channel
.
Init
(
"localhost"
,
port
,
&
coptions
));
ASSERT_EQ
(
0
,
channel
.
Init
(
"localhost"
,
port
,
&
coptions
));
brpc
::
Controller
cntl
;
brpc
::
Controller
cntl
;
...
@@ -125,6 +126,7 @@ TEST_F(SSLTest, sanity) {
...
@@ -125,6 +126,7 @@ TEST_F(SSLTest, sanity) {
brpc
::
Channel
channel
;
brpc
::
Channel
channel
;
brpc
::
ChannelOptions
coptions
;
brpc
::
ChannelOptions
coptions
;
coptions
.
mutable_ssl_options
();
coptions
.
mutable_ssl_options
();
coptions
.
mutable_ssl_options
()
->
sni_name
=
"localhost"
;
ASSERT_EQ
(
0
,
channel
.
Init
(
"127.0.0.1"
,
port
,
&
coptions
));
ASSERT_EQ
(
0
,
channel
.
Init
(
"127.0.0.1"
,
port
,
&
coptions
));
for
(
int
i
=
0
;
i
<
NUM
;
++
i
)
{
for
(
int
i
=
0
;
i
<
NUM
;
++
i
)
{
google
::
protobuf
::
Closure
*
thrd_func
=
google
::
protobuf
::
Closure
*
thrd_func
=
...
@@ -141,6 +143,7 @@ TEST_F(SSLTest, sanity) {
...
@@ -141,6 +143,7 @@ TEST_F(SSLTest, sanity) {
brpc
::
ChannelOptions
coptions
;
brpc
::
ChannelOptions
coptions
;
coptions
.
protocol
=
"http"
;
coptions
.
protocol
=
"http"
;
coptions
.
mutable_ssl_options
();
coptions
.
mutable_ssl_options
();
coptions
.
mutable_ssl_options
()
->
sni_name
=
"localhost"
;
ASSERT_EQ
(
0
,
channel
.
Init
(
"127.0.0.1"
,
port
,
&
coptions
));
ASSERT_EQ
(
0
,
channel
.
Init
(
"127.0.0.1"
,
port
,
&
coptions
));
for
(
int
i
=
0
;
i
<
NUM
;
++
i
)
{
for
(
int
i
=
0
;
i
<
NUM
;
++
i
)
{
google
::
protobuf
::
Closure
*
thrd_func
=
google
::
protobuf
::
Closure
*
thrd_func
=
...
@@ -322,6 +325,9 @@ TEST_F(SSLTest, ssl_perf) {
...
@@ -322,6 +325,9 @@ TEST_F(SSLTest, ssl_perf) {
brpc
::
CreateServerSSLContext
(
"cert1.crt"
,
"cert1.key"
,
brpc
::
CreateServerSSLContext
(
"cert1.crt"
,
"cert1.key"
,
brpc
::
SSLOptions
(),
NULL
);
brpc
::
SSLOptions
(),
NULL
);
SSL
*
cli_ssl
=
brpc
::
CreateSSLSession
(
cli_ctx
,
0
,
clifd
,
false
);
SSL
*
cli_ssl
=
brpc
::
CreateSSLSession
(
cli_ctx
,
0
,
clifd
,
false
);
#if defined(SSL_CTRL_SET_TLSEXT_HOSTNAME) || defined(USE_MESALINK)
SSL_set_tlsext_host_name
(
cli_ssl
,
"localhost"
);
#endif
SSL
*
serv_ssl
=
brpc
::
CreateSSLSession
(
serv_ctx
,
0
,
servfd
,
true
);
SSL
*
serv_ssl
=
brpc
::
CreateSSLSession
(
serv_ctx
,
0
,
servfd
,
true
);
pthread_t
cpid
;
pthread_t
cpid
;
pthread_t
spid
;
pthread_t
spid
;
...
...
test/cert1.crt
View file @
f7aab8c9
-----BEGIN CERTIFICATE-----
-----BEGIN CERTIFICATE-----
MIICOTCCAaICCQD6TiOx55+OsDANBgkqhkiG9w0BAQUFADBhMQswCQYDVQQGEwJD
MIIENjCCAx6gAwIBAgIJAPpOI7Hnn46wMA0GCSqGSIb3DQEBCwUAMGExCzAJBgNV
TjERMA8GA1UECAwIU2hhbmdoYWkxETAPBgNVBAcMCFNoYW5naGFpMQ4wDAYDVQQK
BAYTAkNOMREwDwYDVQQIDAhTaGFuZ2hhaTERMA8GA1UEBwwIU2hhbmdoYWkxDjAM
DAVCYWlkdTEMMAoGA1UECwwDQ0JVMQ4wDAYDVQQDDAVjZXJ0MTAeFw0xNjExMjgw
BgNVBAoMBUJhaWR1MQwwCgYDVQQLDANDQlUxDjAMBgNVBAMMBWNlcnQxMB4XDTE5
OTEzMzRaFw0yNjExMjYwOTEzMzRaMGExCzAJBgNVBAYTAkNOMREwDwYDVQQIDAhT
MDEyMzIyMTU0MVoXDTI5MDEyMDIyMTU0MVowYTELMAkGA1UEBhMCQ04xETAPBgNV
aGFuZ2hhaTERMA8GA1UEBwwIU2hhbmdoYWkxDjAMBgNVBAoMBUJhaWR1MQwwCgYD
BAgMCFNoYW5naGFpMREwDwYDVQQHDAhTaGFuZ2hhaTEOMAwGA1UECgwFQmFpZHUx
VQQLDANDQlUxDjAMBgNVBAMMBWNlcnQxMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB
DDAKBgNVBAsMA0NCVTEOMAwGA1UEAwwFY2VydDEwggEiMA0GCSqGSIb3DQEBAQUA
iQKBgQC8r8469OdZ+MeZiWBsV/7XlusjjnwKP2asmEepzkZXmxX1YEuXRuKkH7zJ
A4IBDwAwggEKAoIBAQC0ypYQmHvVlMaxe5phlUpvKNZrwQSrg/CGN6jrDkV8u7d4
VTg1DCwgTnpCvd0Y1kJ9WOonB5433gnDR32fJ2lswmpFmh+yaZmcTn5MZmE1b4AM
5pI6zcbA1g2fq1Q5EuwexeuWRPt/zSL6PYcOQjZcHIrQwXrilfjw6gOPhFUg54jN
QJ/BEXJcIiKWYMgqh6nw/N+eWymQzmZSC9R/JWgmee/kRRoaiQIDAQABMA0GCSqG
Xzj8XqdZkZp/0qNksPROoeJMnNH+RMjWZox9WLdLAaC7t2R90OMzpBN675XMWGrj
SIb3DQEBBQUAA4GBAGs1o7SkRa9YcDjcbZziNPLOdoZueACxtCLPn4/DZWOiFPku
XJo3ZgWkrv0AtiE7AGGed/gL+iybDwKhN9qftywt6TRqYUOsk2/j6PtWEKg9EfRk
PitB9UaGkiivKYKwmC1nnE2VyYcCIIGqIQ6GtagNPE6DAcd8TFviIHs6jnGhC7Y/
rkdh0jQkpXeh+tk1nUtlnohFqhxz4XPN5+wHtmZinliSMWEXh6XaXyk6ojXdjPMy
ZEePLNpEx9HFkJiQzmH+mMfGftZFBwu9cF4Qa7DzCjMSb+s5qrT/WUXobEch
vpWCxmHz9R9sNP7T/gHkN02pEXbZScGnoPmr635bAgMBAAGjgfAwge0wDAYDVR0T
AQH/BAIwADALBgNVHQ8EBAMCBsAwHQYDVR0OBBYEFAktYxDf0c02h0XkYdeGBtLd
pkuDMIGTBgNVHSMEgYswgYiAFAktYxDf0c02h0XkYdeGBtLdpkuDoWWkYzBhMQsw
CQYDVQQGEwJDTjERMA8GA1UECAwIU2hhbmdoYWkxETAPBgNVBAcMCFNoYW5naGFp
MQ4wDAYDVQQKDAVCYWlkdTEMMAoGA1UECwwDQ0JVMQ4wDAYDVQQDDAVjZXJ0MYIJ
APpOI7Hnn46wMBsGA1UdEQQUMBKCBWNlcnQxgglsb2NhbGhvc3QwDQYJKoZIhvcN
AQELBQADggEBAAN0NWqqAGpqmxBd5VcnCX26pt6WeY5i0XjTVpmrf18qz4JN4Zwo
yHELON9qCNradCNFOUD0kGNGokOSPw4HakQx6mRPwzAxkctI12nj/ArBhTYC+QEQ
WsYCu9rIr3TzT5mz2LpTC1RA+HVkvC7uB1ROc+rl88n1Tuyy2mwj5PbteE3Lpnif
dYgPrU3PM6AVs+1wV1tMUc+DH5UYEaVR7VbN54yiMe4mjwCmsrrC/Y22WgxTBqwG
Z7+YjHT6p2MvRlJ2a0kwb15X492iC1KeBsb/NomWO40WTFTxL0zxk8XEnjwcRPs0
rT3UGBMRPbGDV6fnbf5r3cuOcv7qlHf+7xM=
-----END CERTIFICATE-----
-----END CERTIFICATE-----
test/cert1.key
View file @
f7aab8c9
-----BEGIN RSA PRIVATE KEY-----
-----BEGIN PRIVATE KEY-----
MIICXAIBAAKBgQC8r8469OdZ+MeZiWBsV/7XlusjjnwKP2asmEepzkZXmxX1YEuX
MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQC0ypYQmHvVlMax
RuKkH7zJVTg1DCwgTnpCvd0Y1kJ9WOonB5433gnDR32fJ2lswmpFmh+yaZmcTn5M
e5phlUpvKNZrwQSrg/CGN6jrDkV8u7d45pI6zcbA1g2fq1Q5EuwexeuWRPt/zSL6
ZmE1b4AMQJ/BEXJcIiKWYMgqh6nw/N+eWymQzmZSC9R/JWgmee/kRRoaiQIDAQAB
PYcOQjZcHIrQwXrilfjw6gOPhFUg54jNXzj8XqdZkZp/0qNksPROoeJMnNH+RMjW
AoGAEaGr975iz/l7TVGU/QrL+YFUv6HU3XBHO+GO8MMht5X6W0+AQMaS7xs4HOgl
Zox9WLdLAaC7t2R90OMzpBN675XMWGrjXJo3ZgWkrv0AtiE7AGGed/gL+iybDwKh
tG9KwEoVCp+LRYLf+66PUs5Xbl/qSYnrGz4r+H/Fv1xf1PjUFwlHyLW8dkh4kibq
N9qftywt6TRqYUOsk2/j6PtWEKg9EfRkrkdh0jQkpXeh+tk1nUtlnohFqhxz4XPN
jQ2W9zrEjkZi+MhkYBAMvczAjmunI+ZehIDyQJ3SJnN5qrECQQDkYYyPGGmrqMWY
5+wHtmZinliSMWEXh6XaXyk6ojXdjPMyvpWCxmHz9R9sNP7T/gHkN02pEXbZScGn
B6dZdB78JN03ip9PLljV9MqoAR2NUlFhLLlwSkLN8lrAwQ2XxvfhbDdaRnx8z6x/
oPmr635bAgMBAAECggEAC5d5q7K7LeSOIM8WBO+3iA0MQnhrvjuFbnWfJQMTPX4j
E0sG3lfbAkEA04FcKr2db2lspwfb3WFx9S/cdiTrkGCtPXVovrbit0p6tm9hv8gD
s2LFOXP8LF0NHpGzor0t2oNCKa5emcEjXvwW7rkcFyfVVrExGdoXzgqTE96ePq/Z
rSC+WQNmZXs2QzFNdm2eWrowEdI4XCjGawJAQ/MOKgkeb5eAatJkJUZabbTeKMdS
u6FBXB0NidamG0/8Hfaik3AZvGPJqw3p+qU0mMzZY7vE/IQzs0Vza9o3TYiTCDj/
zPFCNy5lGYVzcHe8hMgUyGcf5zyjadRGohDt8aEL+w0bvtrfPNPVr855nwJBAM2g
WBMEaNLRMymK8Ejyoj7Dm90Tr0TN9PRNBl24KAVOuxYhqajFJV8SkVITXD8ujOt8
D14SOJRPV23QSyYgja0FGf3WiRo1k1eT5QC9Rw9RnpntEYhlSYWwtr5NeuigcDHF
JnpeLnteYsi2Du9cOmu90hc0kRvwQGn4j++T25FvESITz490/7ZEfMG59jTzF0be
Jf1EN1cXepJo4Zhfn/8CQDgRvF9tesalPfRMQTP+OitLQw60ngMaOCXgr9cevWU0
+TJjhqMJ6AcUp5/DtKWhcBYvxhVrOowO3dV0DFLU0QKBgQDtoR+Hut8ZPWZynTSQ
iPiToCki18hVQtM5pWt/83K0B2NLYbluoOXNKBkEQvA=
m7k8lvmLFa+l0nIMSEEciInQSKgZLWeDRrIR9F7GyFhmBRf2u2V4uK0P/g8bhj73
-----END RSA PRIVATE KEY-----
D91KdYXImPqGapCkvTBed0UzSVE236i4rnBO3/e+2Oux806a9sqXvSqENj/OjSVE
de5wrV1y0IH4s9ukwsqZhPnBxwKBgQDCxJeyW+tS4LglY2Qk1kR5ELZhfMe11Mg4
Gqeh1oJcuXV0cVfj2MS8li/gGBrIuzQL62plk7o6j6ybPxraXNObNMF3ZnisEbWj
cykgcQyD+HRuPT1xwH/+dHs7mLtuk/p19e4ZPy1wn41PAC2fDHbEKdYWDAdujUl5
BEEe2xoezQKBgQDGyQq/WKxZSOvy5V+buSl0bjfDChkt9qZBcBBH9lCTVLSKm1kE
kJdWPb8rO133ujsZxBpWqubbggTRWbRCqZrNNxL7hD3PREZMCZf07oGNLcAqz18t
X3/D+8gcdwp0ir0vFVTVKwHuKBOojpqmcqFM0TpjWdngW1VatzkUxBDK8QKBgQCm
jY0Xlekvr0Fpn4vkwGI/kR4VUapKgNJSv+B30cMa3fFmCQLaseTTTC9Wl+ZXn1aL
lt4eTOzk5TX6cEVbVCQURlHm8/bfVimYw4L43hOQyydtmerwWmhZxWwYc6xcjCiT
NSJN7qvB8n7ZftKEfxkU+J29rr2wORwKY6v4Ye79RQKBgBMxrOmLnCfXgt/Mzm3Q
LGwXjmsC7O4wgmQBhkpimXOOVwRW4KFpkODfAk6vb/rMeKkhg1h18oFlxHduN/kw
5BNDnDDdZgOV8dUTjFAJEJsuOi3B8rLsC2TEmIwZN1wmqDPcHCwPP4+ttqDsalzL
wV+3rZ8xTyFAVZmTokIPMlqE
-----END PRIVATE KEY-----
test/cert2.crt
View file @
f7aab8c9
-----BEGIN CERTIFICATE-----
-----BEGIN CERTIFICATE-----
MIICOTCCAaICCQDwZoNAUJYKizANBgkqhkiG9w0BAQUFADBhMQswCQYDVQQGEwJD
MIIENjCCAx6gAwIBAgIJAPBmg0BQlgqLMA0GCSqGSIb3DQEBCwUAMGExCzAJBgNV
TjERMA8GA1UECAwIU2hhbmdoYWkxETAPBgNVBAcMCFNoYW5naGFpMQ4wDAYDVQQK
BAYTAkNOMREwDwYDVQQIDAhTaGFuZ2hhaTERMA8GA1UEBwwIU2hhbmdoYWkxDjAM
DAVCYWlkdTEMMAoGA1UECwwDQ0JVMQ4wDAYDVQQDDAVjZXJ0MjAeFw0xNjExMjgw
BgNVBAoMBUJhaWR1MQwwCgYDVQQLDANDQlUxDjAMBgNVBAMMBWNlcnQyMB4XDTE5
OTE2MDRaFw0yNjExMjYwOTE2MDRaMGExCzAJBgNVBAYTAkNOMREwDwYDVQQIDAhT
MDEyMzIyMTU0MVoXDTI5MDEyMDIyMTU0MVowYTELMAkGA1UEBhMCQ04xETAPBgNV
aGFuZ2hhaTERMA8GA1UEBwwIU2hhbmdoYWkxDjAMBgNVBAoMBUJhaWR1MQwwCgYD
BAgMCFNoYW5naGFpMREwDwYDVQQHDAhTaGFuZ2hhaTEOMAwGA1UECgwFQmFpZHUx
VQQLDANDQlUxDjAMBgNVBAMMBWNlcnQyMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB
DDAKBgNVBAsMA0NCVTEOMAwGA1UEAwwFY2VydDIwggEiMA0GCSqGSIb3DQEBAQUA
iQKBgQDB37VXm4I4apWHysL77GX6ohqLaGxhZ6fnl7qGVqpCe4c5+jMLDKRagNmV
A4IBDwAwggEKAoIBAQCcbPV5j9eex7cnAsUMMreZ9H76yUgp1Y54gR3TqSELYjtu
dDFObjDFnchZ5qM0lbW21jp5v1gxz9C/j6X7Hsl/HO6hS09B1I/Q3UhTjKKsnZSY
XwudIKVQGawPcoFIysvapDBXSj6LgEWVXSqs8bVSUW7lmraSKGJ+wIXmZFHvweaY
WRcUF/t9YVWtzEDKtKgTcLBQrotxzh9qP/GliHbTLsojvmsVgQIDAQABMA0GCSqG
7rXpSma357i0do5VLvIZS9ZRN40SAS6EaSqgpvD3ISeT4xHaiQ/XtKLc/dCSmNSd
SIb3DQEBBQUAA4GBAA1Y17J13GE7gvfGPz5fKkD1eQUFtiR0JGltaU64neuzYG4C
tXsH/CHvcGxEH78i+n2lNjHnabZ+aLTnEQ59R2wDPqymHb2j9gz3QMlM50m7vK83
R+tlnngtzpJf1bcNqITcSwCiEqrkccIbYTCXfHpV1G2w/7Ce13dTOZwsViI2tJWt
v42lhObPQ/JZBs/0taWv6GbFIMYVLwUiCmIb7ecJk1/k3gBo6VYQ5tnnyhcUdTvv
8dWCAHcRvQXRqWm9G8TWwx8hDJJT8U2O71FNkIvqEBSkY0mLgfHXj5cnh0WQ
sWv94KuUU8OmPzJLSo6nKXSE63cIgTOGDR1YmqhNAgMBAAGjgfAwge0wDAYDVR0T
AQH/BAIwADALBgNVHQ8EBAMCBsAwHQYDVR0OBBYEFOuA5h9dbBrkxeUiH7cSNxV5
ygP0MIGTBgNVHSMEgYswgYiAFOuA5h9dbBrkxeUiH7cSNxV5ygP0oWWkYzBhMQsw
CQYDVQQGEwJDTjERMA8GA1UECAwIU2hhbmdoYWkxETAPBgNVBAcMCFNoYW5naGFp
MQ4wDAYDVQQKDAVCYWlkdTEMMAoGA1UECwwDQ0JVMQ4wDAYDVQQDDAVjZXJ0MoIJ
APBmg0BQlgqLMBsGA1UdEQQUMBKCBWNlcnQygglsb2NhbGhvc3QwDQYJKoZIhvcN
AQELBQADggEBAGlEgAyI0R/phfGbdbMdF2WtcbflZrs1wsX4y2zUcmKJt7CkAED/
tj33gHh0qg3eWADUQ3AZ5iCalY86NcKsDoIT2mJn7oO6ejovGOnjQbF53HhY7MIy
1xqGu3MYWc8XuuqnvSqS//sokEVqIm9bAnZaY32cjsrHqZcYCPZbMqSOwqSnz3Ia
fDMw21GOVtgWIXrRFVykTZ9nzey16EB21ry9gci89+1sy5bz0fhXUG1XFguXj8zH
clAzL1mzjYQ1SWMzMmCX7GiiwjkNkiTr6grGQCDBTaIg5E1firkJm3GFJRXmZKSZ
FYR32SX4H3vj6cHf2iu7ilN5t9EQ60KPQ+k=
-----END CERTIFICATE-----
-----END CERTIFICATE-----
test/cert2.key
View file @
f7aab8c9
-----BEGIN RSA PRIVATE KEY-----
-----BEGIN PRIVATE KEY-----
MIICXgIBAAKBgQDB37VXm4I4apWHysL77GX6ohqLaGxhZ6fnl7qGVqpCe4c5+jML
MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQCcbPV5j9eex7cn
DKRagNmVdDFObjDFnchZ5qM0lbW21jp5v1gxz9C/j6X7Hsl/HO6hS09B1I/Q3UhT
AsUMMreZ9H76yUgp1Y54gR3TqSELYjtuXwudIKVQGawPcoFIysvapDBXSj6LgEWV
jKKsnZSYWRcUF/t9YVWtzEDKtKgTcLBQrotxzh9qP/GliHbTLsojvmsVgQIDAQAB
XSqs8bVSUW7lmraSKGJ+wIXmZFHvweaY7rXpSma357i0do5VLvIZS9ZRN40SAS6E
AoGBAKodxB+lYrRiQecvcbxgiHNN/oDJFiC6NciviIoMTcWcYuHquxM8+pI3cbUE
aSqgpvD3ISeT4xHaiQ/XtKLc/dCSmNSdtXsH/CHvcGxEH78i+n2lNjHnabZ+aLTn
iadKZR1h/8Vy7U5c92ABxrnBvn4epy1hKm9N1oidb+wSGLcaV+9YGzuNIQeqXmM5
EQ59R2wDPqymHb2j9gz3QMlM50m7vK83v42lhObPQ/JZBs/0taWv6GbFIMYVLwUi
26IUjzQsObULM2cp/AianzrlkBL2j7kH/A3a4shdrtj4P1OBAkEA8UiCwAEMPIGY
CmIb7ecJk1/k3gBo6VYQ5tnnyhcUdTvvsWv94KuUU8OmPzJLSo6nKXSE63cIgTOG
nDMr6JeNBHkkBQcoY5kuuW902qTCI5M8g6canNsjYEA0Im8YvHsz+9K2YhdIj8F7
DR1YmqhNAgMBAAECggEAHPp+e1evfUXIY1y6/miC5O2LfJA/Yyih7ScWTHjfm0lG
KZtM5mkWCQJBAM2y7eYJhZmKaCwhLGLrO+QLoJ7DOzPg/JAUKWDEhEs1uSUPqTwg
c0r+TsyWc4FeA7qVwtN28nlKT1F8xsErouEQn9tjWO2nGrgPrIH4xTyLUcQx/bWx
ghAOynyP6wHxXLIaD9BC88zWoM26IVxLIbkCQQCcHMFUP5lOML+wGL/JHv1Drqmq
L5HBd4eGAfnWmPABrDw3M4J+IKum4bgAUx1cfUiQCWhF+bquOwr7OV3IciI/Onj1
gyYTwxHjMwUVTlK6N9KIj/79DCBIb2IMAXusv74zqfMNZmkxcgshMXVBAy8ZAkBM
fXBOn98EamJD5SoQwV0WOqWE2grj3bXQd04sHYfYjCb0C3uDqKa3YGyCIB5axK8s
1NuVQ9M6IX99lDp/DDxHlqw9ANE5NH1B17YI5f5AFWX9WNculTnfg5bQZfUyuZOV
SBMnQ0tEKlgF7GY4i9OXXq//wLIEMM23rby5k5oJxPlFvN1MCnQOShHSrK2cprtl
FrT3ZjqoNTbFARP65DlJAkEAtlBLITLqHdq2C4jzHLjXm9vRe2Fsz759ywDy1RCk
1KhZxkL/xXJr8NhMumfDgTEKmpQyPpssWRiYKA1GwQKBgQDIzrLPI1NlYxgRUjGN
2f54B9uUFjzaHl5Z8WVpO6loVBcOu685ROCwfMVW1HRWzA==
PsILc6c3jj73wW7NEPUyLAGkmA4GRhkXusC+pNlO1baEUPm7wWVEo7qndG8rsWjC
-----END RSA PRIVATE KEY-----
nDjCxiVY/5rGYBchwXZUKEh9nowMmDcfwhXb+zJf45aj+jA72pOrMTYGHQ/X/xzj
aVFyABhcUStcM3ts0CvmQnWZkQKBgQDHa3LYbBQI9DLGXfPjwqfUJEen7xypbdlI
UkoXqJa5kMZqpspoIHHMxOa9Rcbhu/E2qCXLypkQ9CPyWzNBPHu499F3kHob5xFt
A6qxnHG+ilGYSd4qej/HIPvAU4TVP6yfwyyBALCB5/wYSRDxT6Zfv3OGvaIaj+qT
qBdLW3Gk/QKBgEGrFt6WdtdZKK3Ba2L9ewezsqOAaScsosd9HDJkIcVp1GxI0Dvq
Xs35qvcU/LMYqBK2lB92S7wnX5OyWMgLvqQzmFMag8sL8YSgd8ndwpcSGkqkHKLO
HcfqxfaFvuWxE8T/HfuGBFzLdDr2usPD1VaqoUzPXpawX1SeXzzVzw+BAoGAQktz
K4WKh4t/EbkMKkx89KZ299oi4iR1lnhcz06phNkfTTdTlJgsnNFcj9GRk1uijfQK
VJxulFdFV/1/pZFQ5CXmieQK5BnGDkKozVDf82MSSxlLdT2c1Dsf1kktoKMBZT9C
HUS4aQdRJFWt/zrmaXBBHKsQJ9puNlYsIE4vEpUCgYEAvN1sBXbt/8R8ELvOrhQv
HO136LtI/KRPpxXRRdBFj//ijwfMchUfChGVk4P0fYXyUA8tF19DJ3GbqtmObYV4
TFYli0z1xDN3Pwo+55Kxwx42Ir7GHmevvNa+RitQYePZVsdLGxY+azh11/5bOZ14
ZkVDf9Glu7bDIwn1wz4HpFw=
-----END PRIVATE KEY-----
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment