Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8d7b85f98c | ||
|
|
513b9b52d9 | ||
|
|
e770ce2c84 |
2
.gitignore
vendored
2
.gitignore
vendored
@@ -10,3 +10,5 @@ build*/
|
|||||||
src/inc
|
src/inc
|
||||||
src/lib64
|
src/lib64
|
||||||
cmake-build-*/
|
cmake-build-*/
|
||||||
|
.cache/
|
||||||
|
.vscode/
|
||||||
|
|||||||
324
.gitlab-ci.yml
324
.gitlab-ci.yml
@@ -1,17 +1,70 @@
|
|||||||
variables:
|
variables:
|
||||||
GIT_STRATEGY: "clone"
|
GIT_STRATEGY: "clone"
|
||||||
BUILD_IMAGE_CENTOS7: "git.mesalab.cn:7443/mesa_platform/build-env:master"
|
BUILD_IMAGE_CENTOS8: "git.mesalab.cn:7443/mesa_platform/build-env:rocky8-for-sapp"
|
||||||
BUILD_IMAGE_CENTOS8: "git.mesalab.cn:7443/mesa_platform/build-env:rockylinux"
|
BUILD_IMAGE_AARCH64_ROCKY9: "git.mesalab.cn:7443/mesa_platform/build-env:rocky9-aarch64"
|
||||||
BUILD_PADDING_PREFIX: /tmp/padding_for_CPACK_RPM_BUILD_SOURCE_DIRS_PREFIX_PREFIX_PREFIX_PREFIX_PREFIX_PREFIX/
|
BUILD_PADDING_PREFIX: /tmp/padding_for_CPACK_RPM_BUILD_SOURCE_DIRS_PREFIX_PREFIX_PREFIX_PREFIX_PREFIX_PREFIX/
|
||||||
INSTALL_DEPENDENCY_PLATFORM: sapp-devel libasan systemd-devel libnsl glib2-devel
|
INSTALL_DEPENDENCY_PLATFORM: sapp-devel libasan systemd-devel libnsl glib2-devel libmnl-devel libnfnetlink-devel
|
||||||
INSTALL_DEPENDENCY_FRAMEWORK: libMESA_handle_logger-devel libcjson-devel libMESA_field_stat2-devel framework_env libMESA_prof_load-devel libbreakpad_mini-devel libMESA_htable-devel
|
INSTALL_DEPENDENCY_FRAMEWORK: libMESA_handle_logger-devel libcjson-devel libMESA_field_stat2-devel framework_env libMESA_prof_load-devel libbreakpad_mini-devel libMESA_htable-devel libfieldstat3 libfieldstat4
|
||||||
INSTALL_PREFIX: "/home/mesasoft/sapp_run/"
|
INSTALL_PREFIX: "/opt/tsg/sapp/"
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
|
- cppcheck
|
||||||
- build
|
- build
|
||||||
- test
|
- test
|
||||||
- package
|
- package
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# cppcheck
|
||||||
|
###############################################################################
|
||||||
|
.cppcheck_script:
|
||||||
|
variables:
|
||||||
|
BUILD_TYPE: Debug
|
||||||
|
stage: cppcheck
|
||||||
|
script:
|
||||||
|
- mkdir -p build; cd build; cmake3 -DCMAKE_EXPORT_COMPILE_COMMANDS=ON ..
|
||||||
|
- >
|
||||||
|
cppcheck --project=compile_commands.json
|
||||||
|
--enable=all
|
||||||
|
--error-exitcode=1
|
||||||
|
--suppress=unusedFunction
|
||||||
|
--suppress=missingInclude
|
||||||
|
--suppress=uselessAssignmentPtrArg
|
||||||
|
--suppress=unmatchedSuppression
|
||||||
|
--suppress=variableScope
|
||||||
|
--suppress=unreadVariable
|
||||||
|
--suppress=cstyleCast
|
||||||
|
--suppress=memleakOnRealloc
|
||||||
|
--suppress=constParameter
|
||||||
|
--suppress=uselessAssignmentArg
|
||||||
|
--suppress=uninitvar
|
||||||
|
--suppress=unusedStructMember
|
||||||
|
--suppress=preprocessorErrorDirective
|
||||||
|
--suppress=syntaxError
|
||||||
|
--suppress=alidscanf
|
||||||
|
--suppress=knownConditionTrueFalse
|
||||||
|
--suppress=invalidscanf
|
||||||
|
--suppress=nullPointerRedundantCheck
|
||||||
|
--suppress=shiftNegativeLHS
|
||||||
|
--suppress=unsignedLessThanZero
|
||||||
|
--suppress=arithOperationsOnVoidPointer
|
||||||
|
--suppress=invalidPrintfArgType_sint
|
||||||
|
|
||||||
|
run_cppcheck_for_x86_64_rocky8:
|
||||||
|
extends: .cppcheck_script
|
||||||
|
image: $BUILD_IMAGE_CENTOS8
|
||||||
|
tags:
|
||||||
|
- tsg-os-builder-el8
|
||||||
|
|
||||||
|
run_cppcheck_for_aarch64_rocky9:
|
||||||
|
extends: .cppcheck_script
|
||||||
|
image: $BUILD_IMAGE_AARCH64_ROCKY9
|
||||||
|
tags:
|
||||||
|
- tsg-os-builder-aarch64
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# build for rocky8
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
.build_before_script:
|
.build_before_script:
|
||||||
before_script:
|
before_script:
|
||||||
- mkdir -p $BUILD_PADDING_PREFIX/$CI_PROJECT_NAMESPACE/
|
- mkdir -p $BUILD_PADDING_PREFIX/$CI_PROJECT_NAMESPACE/
|
||||||
@@ -21,39 +74,15 @@ stages:
|
|||||||
- yum makecache
|
- yum makecache
|
||||||
- yum install -y elfutils-libelf-devel
|
- yum install -y elfutils-libelf-devel
|
||||||
|
|
||||||
|
|
||||||
.build_by_travis_for_centos7:
|
|
||||||
stage: build
|
|
||||||
image: $BUILD_IMAGE_CENTOS7
|
|
||||||
extends: .build_before_script
|
|
||||||
script:
|
|
||||||
- yum install -y libmnl-devel
|
|
||||||
- yum install -y libnfnetlink-devel
|
|
||||||
- ./ci/travis.sh
|
|
||||||
- cd build
|
|
||||||
tags:
|
|
||||||
- share
|
|
||||||
|
|
||||||
.build_by_travis_for_centos8:
|
.build_by_travis_for_centos8:
|
||||||
stage: build
|
stage: build
|
||||||
image: $BUILD_IMAGE_CENTOS8
|
image: $BUILD_IMAGE_CENTOS8
|
||||||
extends: .build_before_script
|
extends: .build_before_script
|
||||||
script:
|
script:
|
||||||
- dnf --enablerepo=powertools install -y libmnl-devel
|
|
||||||
- dnf --enablerepo=powertools install -y libnfnetlink-devel
|
|
||||||
- ./ci/travis.sh
|
- ./ci/travis.sh
|
||||||
tags:
|
tags:
|
||||||
- share
|
- share
|
||||||
|
|
||||||
run_test_for_centos7:
|
|
||||||
stage: test
|
|
||||||
extends: .build_by_travis_for_centos7
|
|
||||||
script:
|
|
||||||
- yum makecache
|
|
||||||
- ./ci/travis.sh
|
|
||||||
- cd build
|
|
||||||
- ctest --verbose
|
|
||||||
|
|
||||||
run_test_for_centos8:
|
run_test_for_centos8:
|
||||||
stage: test
|
stage: test
|
||||||
extends: .build_by_travis_for_centos8
|
extends: .build_by_travis_for_centos8
|
||||||
@@ -63,98 +92,6 @@ run_test_for_centos8:
|
|||||||
- cd build
|
- cd build
|
||||||
- ctest3 --verbose
|
- ctest3 --verbose
|
||||||
|
|
||||||
branch_build_debug_for_centos7:
|
|
||||||
stage: build
|
|
||||||
extends: .build_by_travis_for_centos7
|
|
||||||
variables:
|
|
||||||
BUILD_TYPE: Debug
|
|
||||||
except:
|
|
||||||
- /^develop.*$/i
|
|
||||||
- /^master.*$/i
|
|
||||||
- tags
|
|
||||||
|
|
||||||
branch_build_release_for_centos7:
|
|
||||||
stage: build
|
|
||||||
variables:
|
|
||||||
BUILD_TYPE: RelWithDebInfo
|
|
||||||
extends: .build_by_travis_for_centos7
|
|
||||||
except:
|
|
||||||
- /^develop.*$/i
|
|
||||||
- /^master.*$/i
|
|
||||||
- tags
|
|
||||||
|
|
||||||
develop_build_debug_for_centos7:
|
|
||||||
stage: build
|
|
||||||
extends: .build_by_travis_for_centos7
|
|
||||||
variables:
|
|
||||||
BUILD_TYPE: Debug
|
|
||||||
PACKAGE: 1
|
|
||||||
UPLOAD_RPM: 1
|
|
||||||
ASAN_OPTION: ADDRESS
|
|
||||||
TESTING_VERSION_BUILD: 1
|
|
||||||
PULP3_REPO_NAME: protocol-testing-x86_64.el7
|
|
||||||
PULP3_DIST_NAME: protocol-testing-x86_64.el7
|
|
||||||
artifacts:
|
|
||||||
name: "quic-$CI_COMMIT_REF_NAME-debug"
|
|
||||||
paths:
|
|
||||||
- build/*.rpm
|
|
||||||
only:
|
|
||||||
- /^develop.*$/i
|
|
||||||
- /^master.*$/i
|
|
||||||
|
|
||||||
develop_build_release_for_centos7:
|
|
||||||
stage: build
|
|
||||||
extends: .build_by_travis_for_centos7
|
|
||||||
variables:
|
|
||||||
BUILD_TYPE: RelWithDebInfo
|
|
||||||
PACKAGE: 1
|
|
||||||
UPLOAD_RPM: 1
|
|
||||||
TESTING_VERSION_BUILD: 1
|
|
||||||
PULP3_REPO_NAME: protocol-testing-x86_64.el7
|
|
||||||
PULP3_DIST_NAME: protocol-testing-x86_64.el7
|
|
||||||
artifacts:
|
|
||||||
name: "quic-$CI_COMMIT_REF_NAME-release"
|
|
||||||
paths:
|
|
||||||
- build/*.rpm
|
|
||||||
only:
|
|
||||||
- /^develop.*$/i
|
|
||||||
- /^master.*$/i
|
|
||||||
|
|
||||||
release_build_debug_for_centos7:
|
|
||||||
stage: package
|
|
||||||
variables:
|
|
||||||
BUILD_TYPE: Debug
|
|
||||||
PACKAGE: 1
|
|
||||||
UPLOAD_RPM: 1
|
|
||||||
ASAN_OPTION: ADDRESS
|
|
||||||
PULP3_REPO_NAME: protocol-stable-x86_64.el7
|
|
||||||
PULP3_DIST_NAME: protocol-stable-x86_64.el7
|
|
||||||
extends: .build_by_travis_for_centos7
|
|
||||||
artifacts:
|
|
||||||
name: "quic-$CI_COMMIT_REF_NAME-debug"
|
|
||||||
paths:
|
|
||||||
- build/*.rpm
|
|
||||||
only:
|
|
||||||
- tags
|
|
||||||
|
|
||||||
release_build_release_for_centos7:
|
|
||||||
stage: package
|
|
||||||
variables:
|
|
||||||
BUILD_TYPE: RelWithDebInfo
|
|
||||||
PACKAGE: 1
|
|
||||||
UPLOAD_RPM: 1
|
|
||||||
UPLOAD_SYMBOL_FILES: 1
|
|
||||||
SYMBOL_TARGET: quic
|
|
||||||
PULP3_REPO_NAME: protocol-stable-x86_64.el7
|
|
||||||
PULP3_DIST_NAME: protocol-stable-x86_64.el7
|
|
||||||
extends: .build_by_travis_for_centos7
|
|
||||||
artifacts:
|
|
||||||
name: "quic-$CI_COMMIT_REF_NAME-release"
|
|
||||||
paths:
|
|
||||||
- build/*.rpm
|
|
||||||
only:
|
|
||||||
- tags
|
|
||||||
|
|
||||||
branch_build_debug_for_centos8:
|
branch_build_debug_for_centos8:
|
||||||
stage: build
|
stage: build
|
||||||
extends: .build_by_travis_for_centos8
|
extends: .build_by_travis_for_centos8
|
||||||
@@ -246,3 +183,148 @@ release_build_release_for_centos8:
|
|||||||
- build/*.rpm
|
- build/*.rpm
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# build for rocky9
|
||||||
|
###############################################################################
|
||||||
|
.build_by_travis_for_rocky9:
|
||||||
|
stage: build
|
||||||
|
image: $BUILD_IMAGE_AARCH64_ROCKY9
|
||||||
|
extends: .build_before_script
|
||||||
|
script:
|
||||||
|
- yum install -y perl-FindBin
|
||||||
|
- ./ci/travis.sh
|
||||||
|
tags:
|
||||||
|
- tsg-os-builder-aarch64
|
||||||
|
|
||||||
|
branch_build_debug_for_rocky9:
|
||||||
|
stage: build
|
||||||
|
extends: .build_by_travis_for_rocky9
|
||||||
|
variables:
|
||||||
|
BUILD_TYPE: Debug
|
||||||
|
except:
|
||||||
|
- /^develop.*$/i
|
||||||
|
- /^master.*$/i
|
||||||
|
- tags
|
||||||
|
|
||||||
|
branch_build_release_for_rocky9:
|
||||||
|
stage: build
|
||||||
|
variables:
|
||||||
|
BUILD_TYPE: RelWithDebInfo
|
||||||
|
extends: .build_by_travis_for_rocky9
|
||||||
|
except:
|
||||||
|
- /^develop.*$/i
|
||||||
|
- /^master.*$/i
|
||||||
|
- tags
|
||||||
|
|
||||||
|
develop_build_debug_for_rocky9:
|
||||||
|
stage: build
|
||||||
|
extends: .build_by_travis_for_rocky9
|
||||||
|
variables:
|
||||||
|
BUILD_TYPE: Debug
|
||||||
|
PACKAGE: 1
|
||||||
|
UPLOAD_RPM: 1
|
||||||
|
ASAN_OPTION: ADDRESS
|
||||||
|
TESTING_VERSION_BUILD: 1
|
||||||
|
PULP3_REPO_NAME: protocol-testing-aarch64.el9
|
||||||
|
PULP3_DIST_NAME: protocol-testing-aarch64.el9
|
||||||
|
artifacts:
|
||||||
|
name: "quic-$CI_COMMIT_REF_NAME-debug"
|
||||||
|
paths:
|
||||||
|
- build/*.rpm
|
||||||
|
only:
|
||||||
|
- /^develop.*$/i
|
||||||
|
- /^master.*$/i
|
||||||
|
|
||||||
|
develop_build_release_for_rocky9:
|
||||||
|
stage: build
|
||||||
|
extends: .build_by_travis_for_rocky9
|
||||||
|
variables:
|
||||||
|
BUILD_TYPE: RelWithDebInfo
|
||||||
|
PACKAGE: 1
|
||||||
|
UPLOAD_RPM: 1
|
||||||
|
TESTING_VERSION_BUILD: 1
|
||||||
|
PULP3_REPO_NAME: protocol-testing-aarch64.el9
|
||||||
|
PULP3_DIST_NAME: protocol-testing-aarch64.el9
|
||||||
|
artifacts:
|
||||||
|
name: "quic-$CI_COMMIT_REF_NAME-release"
|
||||||
|
paths:
|
||||||
|
- build/*.rpm
|
||||||
|
only:
|
||||||
|
- /^develop.*$/i
|
||||||
|
- /^master.*$/i
|
||||||
|
|
||||||
|
release_build_debug_for_rocky9:
|
||||||
|
stage: package
|
||||||
|
variables:
|
||||||
|
BUILD_TYPE: Debug
|
||||||
|
PACKAGE: 1
|
||||||
|
UPLOAD_RPM: 1
|
||||||
|
ASAN_OPTION: ADDRESS
|
||||||
|
PULP3_REPO_NAME: protocol-stable-aarch64.el9
|
||||||
|
PULP3_DIST_NAME: protocol-stable-aarch64.el9
|
||||||
|
extends: .build_by_travis_for_rocky9
|
||||||
|
artifacts:
|
||||||
|
name: "quic-$CI_COMMIT_REF_NAME-debug"
|
||||||
|
paths:
|
||||||
|
- build/*.rpm
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
|
|
||||||
|
release_build_release_for_rocky9:
|
||||||
|
stage: package
|
||||||
|
variables:
|
||||||
|
BUILD_TYPE: RelWithDebInfo
|
||||||
|
PACKAGE: 1
|
||||||
|
UPLOAD_RPM: 1
|
||||||
|
UPLOAD_SYMBOL_FILES: 0
|
||||||
|
SYMBOL_TARGET: quic
|
||||||
|
PULP3_REPO_NAME: protocol-stable-aarch64.el9
|
||||||
|
PULP3_DIST_NAME: protocol-stable-aarch64.el9
|
||||||
|
extends: .build_by_travis_for_rocky9
|
||||||
|
artifacts:
|
||||||
|
name: "quic-$CI_COMMIT_REF_NAME-release"
|
||||||
|
paths:
|
||||||
|
- build/*.rpm
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
# test
|
||||||
|
###############################################################################
|
||||||
|
.download_rpm_package: &download_rpm_package
|
||||||
|
- yumdownloader sapp-4.3.69.6dd815e
|
||||||
|
- yumdownloader sapp-devel-4.3.69.6dd815e
|
||||||
|
- mv sapp-4.3.69.6dd815e*.rpm /tmp/sapp.rpm
|
||||||
|
- mv sapp-devel-4.3.69.6dd815e*.rpm /tmp/sapp-devel.rpm
|
||||||
|
|
||||||
|
.install_rpm_package: &install_rpm_package
|
||||||
|
- rpm -e sapp || true
|
||||||
|
- rpm -e sapp-devel || true
|
||||||
|
- rpm -ivh /tmp/sapp.rpm --prefix=${INSTALL_PREFIX} --force --nodeps
|
||||||
|
- rpm -ivh /tmp/sapp-devel.rpm --prefix=${INSTALL_PREFIX} --force --nodeps
|
||||||
|
- rpm -qa | grep sapp
|
||||||
|
- ls -l ${INSTALL_PREFIX}
|
||||||
|
- ldd ${INSTALL_PREFIX}/sapp
|
||||||
|
|
||||||
|
run_test_for_centos8:
|
||||||
|
stage: test
|
||||||
|
extends: .build_by_travis_for_centos8
|
||||||
|
script:
|
||||||
|
- yum makecache
|
||||||
|
- ./ci/travis.sh
|
||||||
|
- *download_rpm_package
|
||||||
|
- *install_rpm_package
|
||||||
|
- ctest3 --verbose
|
||||||
|
|
||||||
|
run_test_for_rocky9:
|
||||||
|
stage: test
|
||||||
|
extends: .build_by_travis_for_rocky9
|
||||||
|
script:
|
||||||
|
- yum makecache
|
||||||
|
- yum install -y perl-FindBin
|
||||||
|
- ./ci/travis.sh
|
||||||
|
- *download_rpm_package
|
||||||
|
- *install_rpm_package
|
||||||
|
- ctest3 --verbose
|
||||||
|
|
||||||
@@ -28,7 +28,10 @@ elseif(ASAN_OPTION MATCHES "THREAD")
|
|||||||
endif()
|
endif()
|
||||||
# end of for ASAN
|
# end of for ASAN
|
||||||
|
|
||||||
set(CMAKE_INSTALL_PREFIX /home/mesasoft/sapp_run)
|
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
|
||||||
|
set(CMAKE_INSTALL_PREFIX "/opt/tsg/sapp" CACHE PATH "default install path" FORCE)
|
||||||
|
message(STATUS "CMAKE_INSTALL_PREFIX='${CMAKE_INSTALL_PREFIX}'")
|
||||||
|
endif()
|
||||||
|
|
||||||
include_directories(include)
|
include_directories(include)
|
||||||
include_directories(/opt/MESA/include/MESA/)
|
include_directories(/opt/MESA/include/MESA/)
|
||||||
|
|||||||
@@ -149,7 +149,10 @@ void quic_free_context(const struct streaminfo *a_stream, int bridge_id, void *d
|
|||||||
{
|
{
|
||||||
struct quic_context *context = (struct quic_context *)data;
|
struct quic_context *context = (struct quic_context *)data;
|
||||||
quic_free_client_hello(context->quic_info.client_hello, a_stream->threadnum);
|
quic_free_client_hello(context->quic_info.client_hello, a_stream->threadnum);
|
||||||
|
if(context->quic_buf.buffer)
|
||||||
|
{
|
||||||
|
dictator_free(a_stream->threadnum, context->quic_buf.buffer);
|
||||||
|
}
|
||||||
dictator_free(a_stream->threadnum, data);
|
dictator_free(a_stream->threadnum, data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -208,7 +211,7 @@ extern "C" int QUIC_INIT(void)
|
|||||||
MESA_load_profile_int_def(g_quic_proto_conffile, "QUIC", "DECRYPTED_SWITCH", &g_quic_param.decrypted_switch, 2);
|
MESA_load_profile_int_def(g_quic_proto_conffile, "QUIC", "DECRYPTED_SWITCH", &g_quic_param.decrypted_switch, 2);
|
||||||
MESA_load_profile_int_def(g_quic_proto_conffile, "QUIC", "MAX_PARSE_PKT_NUM", &g_quic_param.max_parse_pkt_num, 3);
|
MESA_load_profile_int_def(g_quic_proto_conffile, "QUIC", "MAX_PARSE_PKT_NUM", &g_quic_param.max_parse_pkt_num, 3);
|
||||||
|
|
||||||
MESA_load_profile_string_def(g_quic_proto_conffile, "QUIC", "QUIC_PORT_LIST", buff, sizeof(buff), "443;8443;");
|
MESA_load_profile_string_def(g_quic_proto_conffile, "QUIC", "QUIC_PORT_LIST", buff, sizeof(buff), "");
|
||||||
g_quic_param.quic_port_num=parse_quic_port(buff, g_quic_param.quic_port_list, SUPPORT_QUIC_PORT_NUM);
|
g_quic_param.quic_port_num=parse_quic_port(buff, g_quic_param.quic_port_list, SUPPORT_QUIC_PORT_NUM);
|
||||||
|
|
||||||
g_quic_param.logger=MESA_create_runtime_log_handle(g_quic_param.log_path, g_quic_param.level);
|
g_quic_param.logger=MESA_create_runtime_log_handle(g_quic_param.log_path, g_quic_param.level);
|
||||||
@@ -229,7 +232,7 @@ extern "C" int QUIC_INIT(void)
|
|||||||
MESA_handle_runtime_log(g_quic_param.logger, RLOG_LV_FATAL, "QUIC_READCONF", "Read error, Please check %s, region_line: %s", g_quic_regionname_conffile, buff);
|
MESA_handle_runtime_log(g_quic_param.logger, RLOG_LV_FATAL, "QUIC_READCONF", "Read error, Please check %s, region_line: %s", g_quic_regionname_conffile, buff);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if(region_id>MAX_REGION_NUM)
|
if(region_id>=MAX_REGION_NUM)
|
||||||
{
|
{
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
MESA_handle_runtime_log(g_quic_param.logger, RLOG_LV_FATAL, "QUIC_READCONF", "Read error, Please check %s, bigger than MAX_REGION_NUM, region_line: %s", g_quic_regionname_conffile, buff);
|
MESA_handle_runtime_log(g_quic_param.logger, RLOG_LV_FATAL, "QUIC_READCONF", "Read error, Please check %s, bigger than MAX_REGION_NUM, region_line: %s", g_quic_regionname_conffile, buff);
|
||||||
|
|||||||
@@ -56,7 +56,7 @@ int check_port(unsigned short port)
|
|||||||
int is_quic_port(const struct streaminfo *pstream)
|
int is_quic_port(const struct streaminfo *pstream)
|
||||||
{
|
{
|
||||||
unsigned short source=0, dest=0;
|
unsigned short source=0, dest=0;
|
||||||
|
if(g_quic_param.quic_port_num==0)return 1;
|
||||||
switch(pstream->addr.addrtype)
|
switch(pstream->addr.addrtype)
|
||||||
{
|
{
|
||||||
case ADDR_TYPE_IPV4:
|
case ADDR_TYPE_IPV4:
|
||||||
@@ -520,7 +520,7 @@ int parse_tls_client_hello(struct quic_client_hello **client_hello, const char *
|
|||||||
|
|
||||||
int parse_quic_decrypted_payload(struct quic_info *quic_info, const char * payload, int payload_len, int thread_seq)
|
int parse_quic_decrypted_payload(struct quic_info *quic_info, const char * payload, int payload_len, int thread_seq)
|
||||||
{
|
{
|
||||||
char join_payload[2048]={0};
|
char join_payload[MAX_CLIENT_HELLO_CHUNK_SIZE]={};
|
||||||
int join_payload_len=sizeof(join_payload);
|
int join_payload_len=sizeof(join_payload);
|
||||||
unsigned int quic_version=quic_info->quic_version;
|
unsigned int quic_version=quic_info->quic_version;
|
||||||
|
|
||||||
@@ -767,9 +767,109 @@ enum QUIC_VERSION is_quic_protocol(const char *payload, int payload_len, int *pa
|
|||||||
return quic_version;
|
return quic_version;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char parse_quic_all_version(struct quic_info *quic_info, const char *payload, int payload_len, int thread_seq)
|
static void quic_chlo_chunk_assemble(struct quic_buffer *qbuf, unsigned char *new_payload, int new_len, int thread_seq)
|
||||||
{
|
{
|
||||||
int ret=0, payload_offset=0;
|
if(NULL == new_payload || new_len <= 0){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(NULL == qbuf->buffer){
|
||||||
|
qbuf->buffer = (unsigned char *)dictator_malloc(thread_seq, MAX_CLIENT_HELLO_CHUNK_SIZE);
|
||||||
|
qbuf->max_size = MAX_CLIENT_HELLO_CHUNK_SIZE;
|
||||||
|
}
|
||||||
|
int max_copy_len = MIN((int)(qbuf->max_size - qbuf->datalen), new_len);
|
||||||
|
memcpy(qbuf->buffer + qbuf->datalen, new_payload, max_copy_len);
|
||||||
|
qbuf->datalen += max_copy_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int get_chlo_total_length(const unsigned char *payload, int payload_len)
|
||||||
|
{
|
||||||
|
const struct quic_client_hello_msg_hdr *chlo_hdr=(const struct quic_client_hello_msg_hdr *)payload;
|
||||||
|
int chlo_len=0;
|
||||||
|
uint8_t *p = (uint8_t *)&chlo_len;
|
||||||
|
p[2] = chlo_hdr->client_hello_len[0];
|
||||||
|
p[1] = chlo_hdr->client_hello_len[1];
|
||||||
|
p[0] = chlo_hdr->client_hello_len[2];
|
||||||
|
return chlo_len;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
1: is chlo, and complete!
|
||||||
|
0: is chlo, but fragment;
|
||||||
|
-1: not support
|
||||||
|
*/
|
||||||
|
static int quic_chlo_is_complete(enum QUIC_VERSION quic_version, const unsigned char *payload, int payload_len)
|
||||||
|
{
|
||||||
|
if(!( (quic_version>=MVFST_VERSION_00 && quic_version<=MVFST_VERSION_0F) ||
|
||||||
|
(quic_version>=GQUIC_VERSION_T050 && quic_version<=GQUIC_VERSION_T059) ||
|
||||||
|
(quic_version>=IQUIC_VERSION_I022 && quic_version<=IQUIC_VERSION_I029) ||
|
||||||
|
(quic_version==IQUIC_VERSION_RFC9000)))
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if((payload[0] != 0x06) && (payload[0] != 0x08))
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
int payload_offset = 0;
|
||||||
|
long frame_offset, frame_length;
|
||||||
|
payload_offset = 1; //skip frame type
|
||||||
|
payload_offset+=msb2_varint_decode(payload+payload_offset, &frame_offset);
|
||||||
|
payload_offset+=msb2_varint_decode(payload+payload_offset, &frame_length);
|
||||||
|
|
||||||
|
if(payload[payload_offset] != QUIC_HANDSHAKE_TYPE_CLIENTHELLO)
|
||||||
|
{
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
int expect_len = get_chlo_total_length(payload + payload_offset, payload_len-payload_offset);
|
||||||
|
if(payload_len-payload_offset >= expect_len){
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static enum PARSE_RESULT quic_decrypting_payload(struct quic_context *qcontext, unsigned char *udp_payload, int udp_payload_len, int thread_seq)
|
||||||
|
{
|
||||||
|
struct quic_buffer *qbuf = &qcontext->quic_buf;
|
||||||
|
unsigned char *quic_decrypted_payload;
|
||||||
|
int ret, quic_decrypted_payload_len;
|
||||||
|
quic_dpt_t *dpt = quic_deprotection_new();
|
||||||
|
enum PARSE_RESULT parse_result = PARSE_RESULT_UNKNOWN;
|
||||||
|
|
||||||
|
if(quic_deprotection(dpt, (const u_char *)udp_payload, udp_payload_len) < 0){
|
||||||
|
goto err_exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(qbuf->datalen > 0){ //some fragment exist
|
||||||
|
quic_chlo_chunk_assemble(qbuf, dpt->payload.data, dpt->payload.len, thread_seq);
|
||||||
|
quic_decrypted_payload = qbuf->buffer;
|
||||||
|
quic_decrypted_payload_len = qbuf->datalen;
|
||||||
|
}else{
|
||||||
|
quic_decrypted_payload = dpt->payload.data;
|
||||||
|
quic_decrypted_payload_len = dpt->payload.len;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = quic_chlo_is_complete((enum QUIC_VERSION)qcontext->quic_info.quic_version, quic_decrypted_payload, quic_decrypted_payload_len);
|
||||||
|
if(0 == ret){
|
||||||
|
if(NULL == qbuf->buffer || 0 == qbuf->datalen){
|
||||||
|
quic_chlo_chunk_assemble(qbuf, dpt->payload.data, dpt->payload.len, thread_seq);
|
||||||
|
}
|
||||||
|
parse_result = PARSE_RESULT_VERSION;
|
||||||
|
goto fun_exit;
|
||||||
|
}
|
||||||
|
parse_result = (enum PARSE_RESULT)parse_quic_decrypted_payload(&qcontext->quic_info, (char *)quic_decrypted_payload, quic_decrypted_payload_len, thread_seq);
|
||||||
|
|
||||||
|
fun_exit:
|
||||||
|
quic_deprotection_free(dpt);
|
||||||
|
return parse_result;
|
||||||
|
|
||||||
|
err_exit:
|
||||||
|
quic_deprotection_free(dpt);
|
||||||
|
return PARSE_RESULT_VERSION;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned char parse_quic_all_version(struct quic_context *qcontext, const char *payload, int payload_len, int thread_seq)
|
||||||
|
{
|
||||||
|
int payload_offset=0;
|
||||||
enum QUIC_VERSION quic_version=QUIC_VERSION_UNKNOWN;
|
enum QUIC_VERSION quic_version=QUIC_VERSION_UNKNOWN;
|
||||||
|
|
||||||
if(payload==NULL || payload_len<=0)
|
if(payload==NULL || payload_len<=0)
|
||||||
@@ -783,25 +883,25 @@ unsigned char parse_quic_all_version(struct quic_info *quic_info, const char *pa
|
|||||||
return PARSE_RESULT_UNKNOWN;
|
return PARSE_RESULT_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
quic_info->quic_version=quic_version;
|
qcontext->quic_info.quic_version=quic_version;
|
||||||
|
|
||||||
if(quic_version>=GQUIC_VERSION_Q001 && quic_version<=GQUIC_VERSION_Q048)
|
if(quic_version>=GQUIC_VERSION_Q001 && quic_version<=GQUIC_VERSION_Q048)
|
||||||
{
|
{
|
||||||
if(payload_len > payload_offset)
|
if(payload_len > payload_offset)
|
||||||
{
|
{
|
||||||
return parse_quic_uncryption_payload(quic_info, payload+payload_offset, payload_len-payload_offset, thread_seq);
|
return parse_quic_uncryption_payload(&qcontext->quic_info, payload+payload_offset, payload_len-payload_offset, thread_seq);
|
||||||
}
|
}
|
||||||
return PARSE_RESULT_VERSION;
|
return PARSE_RESULT_VERSION;
|
||||||
}
|
}
|
||||||
else if(((quic_version>=MVFST_VERSION_00 && quic_version<=MVFST_VERSION_0F) ||
|
else if(((quic_version>=MVFST_VERSION_00 && quic_version<=MVFST_VERSION_0F) ||
|
||||||
(quic_version>=GQUIC_VERSION_Q049 && quic_version<=GQUIC_VERSION_Q059) ||
|
(quic_version>=GQUIC_VERSION_Q049 && quic_version<=GQUIC_VERSION_Q059) ||
|
||||||
(quic_version>=GQUIC_VERSION_T050 && quic_version<=GQUIC_VERSION_T059) ||
|
(quic_version>=GQUIC_VERSION_T050 && quic_version<=GQUIC_VERSION_T059) ||
|
||||||
(quic_version>=GQUIC_VERSION_T050 && quic_version<=GQUIC_VERSION_T059) ||
|
|
||||||
(quic_version>=IQUIC_VERSION_I022 && quic_version<=IQUIC_VERSION_I029) ||
|
(quic_version>=IQUIC_VERSION_I022 && quic_version<=IQUIC_VERSION_I029) ||
|
||||||
(quic_version==IQUIC_VERSION_RFC9000))
|
(quic_version==IQUIC_VERSION_RFC9000))
|
||||||
&& g_quic_param.decrypted_switch>0
|
&& g_quic_param.decrypted_switch>0
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
quic_dpt_t *dpt = quic_deprotection_new();
|
quic_dpt_t *dpt = quic_deprotection_new();
|
||||||
if (quic_deprotection(dpt, (const u_char *)payload, payload_len) != 0)
|
if (quic_deprotection(dpt, (const u_char *)payload, payload_len) != 0)
|
||||||
{
|
{
|
||||||
@@ -816,6 +916,9 @@ unsigned char parse_quic_all_version(struct quic_info *quic_info, const char *pa
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
quic_deprotection_free(dpt);
|
quic_deprotection_free(dpt);
|
||||||
|
#else
|
||||||
|
return quic_decrypting_payload(qcontext, (unsigned char *)payload, payload_len, thread_seq);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -844,7 +947,7 @@ unsigned char quic_analyze_entry(const struct streaminfo *pstream, struct quic_c
|
|||||||
parse_result=PARSE_RESULT_PAYLOAD;
|
parse_result=PARSE_RESULT_PAYLOAD;
|
||||||
break;
|
break;
|
||||||
case PARSE_RESULT_VERSION:
|
case PARSE_RESULT_VERSION:
|
||||||
parse_result=parse_quic_all_version(&(context->quic_info), (const char *)udp_detail->pdata, udp_detail->datalen, thread_seq);
|
parse_result=parse_quic_all_version(context, (const char *)udp_detail->pdata, udp_detail->datalen, thread_seq);
|
||||||
if(parse_result==PARSE_RESULT_VERSION || parse_result==PARSE_RESULT_UNKNOWN)
|
if(parse_result==PARSE_RESULT_VERSION || parse_result==PARSE_RESULT_UNKNOWN)
|
||||||
{
|
{
|
||||||
parse_result=PARSE_RESULT_PAYLOAD;
|
parse_result=PARSE_RESULT_PAYLOAD;
|
||||||
@@ -872,7 +975,7 @@ unsigned char quic_analyze_entry(const struct streaminfo *pstream, struct quic_c
|
|||||||
parse_result=PARSE_RESULT_PAYLOAD;
|
parse_result=PARSE_RESULT_PAYLOAD;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
parse_result=parse_quic_all_version(&(context->quic_info), (const char *)udp_detail->pdata, udp_detail->datalen, thread_seq);
|
parse_result=parse_quic_all_version(context, (const char *)udp_detail->pdata, udp_detail->datalen, thread_seq);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -904,15 +1007,15 @@ struct quic_info *quic_protocol_identify(const struct streaminfo *a_stream)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct quic_info tmp_quic_info={0, NULL};
|
struct quic_context tmp_qcontext = {};
|
||||||
unsigned char parse_result=APP_STATE_GIVEME;
|
unsigned char parse_result=APP_STATE_GIVEME;
|
||||||
|
|
||||||
parse_result=parse_quic_all_version(&tmp_quic_info, (const char *)a_stream->pudpdetail->pdata, a_stream->pudpdetail->datalen, a_stream->threadnum);
|
parse_result=parse_quic_all_version(&tmp_qcontext, (const char *)a_stream->pudpdetail->pdata, a_stream->pudpdetail->datalen, a_stream->threadnum);
|
||||||
if(parse_result!=PARSE_RESULT_UNKNOWN)
|
if(parse_result!=PARSE_RESULT_UNKNOWN)
|
||||||
{
|
{
|
||||||
struct quic_context *context=(struct quic_context *)dictator_malloc(a_stream->threadnum, sizeof(struct quic_context));
|
struct quic_context *context=(struct quic_context *)dictator_malloc(a_stream->threadnum, sizeof(struct quic_context));
|
||||||
memset(context, 0, sizeof(struct quic_context));
|
memset(context, 0, sizeof(struct quic_context));
|
||||||
context->quic_info=tmp_quic_info;
|
context->quic_info=tmp_qcontext.quic_info;
|
||||||
context->parse_first_pkt=1;
|
context->parse_first_pkt=1;
|
||||||
context->pre_parse_state=PARSE_RESULT_UNKNOWN;
|
context->pre_parse_state=PARSE_RESULT_UNKNOWN;
|
||||||
|
|
||||||
|
|||||||
@@ -279,6 +279,14 @@ enum QUIC_VERSION
|
|||||||
IQUIC_VERSION_I032=0xFF000020
|
IQUIC_VERSION_I032=0xFF000020
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define MAX_CLIENT_HELLO_CHUNK_SIZE (4096)
|
||||||
|
struct quic_buffer
|
||||||
|
{
|
||||||
|
unsigned char *buffer;
|
||||||
|
size_t max_size;
|
||||||
|
size_t datalen;
|
||||||
|
};
|
||||||
|
|
||||||
struct quic_context
|
struct quic_context
|
||||||
{
|
{
|
||||||
unsigned char link_state;
|
unsigned char link_state;
|
||||||
@@ -288,6 +296,7 @@ struct quic_context
|
|||||||
unsigned char padding[4];
|
unsigned char padding[4];
|
||||||
void *business_pme;
|
void *business_pme;
|
||||||
struct quic_info quic_info;
|
struct quic_info quic_info;
|
||||||
|
struct quic_buffer quic_buf; // for client hello fragment
|
||||||
};
|
};
|
||||||
|
|
||||||
unsigned char quic_analyze_entry(const struct streaminfo *pstream, struct quic_context* context, int thread_seq, const void* a_packet);
|
unsigned char quic_analyze_entry(const struct streaminfo *pstream, struct quic_context* context, int thread_seq, const void* a_packet);
|
||||||
|
|||||||
@@ -54,12 +54,6 @@ int quic_version_int2string(unsigned int version, char *buff, int buff_len)
|
|||||||
snprintf(buff, buff_len, "quic-go QGO %02d", (version&0x000000FF));
|
snprintf(buff, buff_len, "quic-go QGO %02d", (version&0x000000FF));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(version>=QUIC_GO_VERSION_00 && version<=QUIC_GO_VERSION_FF)
|
|
||||||
{
|
|
||||||
snprintf(buff, buff_len, "quicly qicly0 %02d", (version&0x000000FF));
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(version>=MSQUIC_VERSION_00 && version<=MSQUIC_VERSION_0F)
|
if(version>=MSQUIC_VERSION_00 && version<=MSQUIC_VERSION_0F)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ include(ExternalProject)
|
|||||||
ExternalProject_Add(OpenSSL PREFIX openssl
|
ExternalProject_Add(OpenSSL PREFIX openssl
|
||||||
URL ${CMAKE_CURRENT_SOURCE_DIR}/openssl-1.1.1l.tar.gz
|
URL ${CMAKE_CURRENT_SOURCE_DIR}/openssl-1.1.1l.tar.gz
|
||||||
URL_MD5 ac0d4387f3ba0ad741b0580dd45f6ff3
|
URL_MD5 ac0d4387f3ba0ad741b0580dd45f6ff3
|
||||||
CONFIGURE_COMMAND ./Configure linux-x86_64 --prefix=<INSTALL_DIR> --openssldir=<INSTALL_DIR>/lib/ssl enable-ec_nistp_64_gcc_128 no-shared
|
CONFIGURE_COMMAND ./config --prefix=<INSTALL_DIR> --openssldir=<INSTALL_DIR>/lib/ssl enable-ec_nistp_64_gcc_128 no-shared
|
||||||
BUILD_COMMAND ${MAKE_COMMAND}
|
BUILD_COMMAND ${MAKE_COMMAND}
|
||||||
INSTALL_COMMAND make install_sw
|
INSTALL_COMMAND make install_sw
|
||||||
BUILD_IN_SOURCE 1)
|
BUILD_IN_SOURCE 1)
|
||||||
|
|||||||
@@ -3,59 +3,56 @@ cmake_minimum_required (VERSION 2.8...3.10)
|
|||||||
set(lib_name quic)
|
set(lib_name quic)
|
||||||
project(${lib_name}_test)
|
project(${lib_name}_test)
|
||||||
|
|
||||||
include(ExternalProject)
|
if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
|
||||||
#### Protoco_test_run
|
set(CMAKE_INSTALL_PREFIX "/opt/tsg/sapp" CACHE PATH "default install path" FORCE)
|
||||||
|
message(STATUS "CMAKE_INSTALL_PREFIX='${CMAKE_INSTALL_PREFIX}'")
|
||||||
|
endif()
|
||||||
ExternalProject_Add(ProtoTest PREFIX ProtoTest
|
|
||||||
URL ${CMAKE_CURRENT_SOURCE_DIR}/test_protocol_run.zip
|
|
||||||
URL_MD5 71d8284b59af0286b5f31f0a3160bc44
|
|
||||||
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX=<INSTALL_DIR> -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}
|
|
||||||
CONFIGURE_COMMAND ""
|
|
||||||
BUILD_COMMAND ""
|
|
||||||
INSTALL_COMMAND ""
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E make_directory <SOURCE_DIR>/conf/${lib_name}/
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/bin/${lib_name}.conf <SOURCE_DIR>/conf/${lib_name}/
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_CURRENT_SOURCE_DIR}/conflist.inf <SOURCE_DIR>/plug/
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E make_directory <SOURCE_DIR>/plug/protocol/${lib_name}/
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/bin/${lib_name}.inf <SOURCE_DIR>/plug/protocol/${lib_name}/
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E make_directory <SOURCE_DIR>/plug/business/${lib_name}_test_plug/
|
|
||||||
COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_SOURCE_DIR}/test/${lib_name}_test_plug.inf <SOURCE_DIR>/plug/business/${lib_name}_test_plug/)
|
|
||||||
|
|
||||||
ExternalProject_Get_Property(ProtoTest INSTALL_DIR)
|
|
||||||
ExternalProject_Get_Property(ProtoTest SOURCE_DIR)
|
|
||||||
set(PROTO_TEST_RUN_DIR ${SOURCE_DIR})
|
|
||||||
|
|
||||||
add_executable(proto_test_main IMPORTED GLOBAL)
|
|
||||||
add_dependencies(proto_test_main ProtoTest)
|
|
||||||
set_property(TARGET proto_test_main PROPERTY IMPORTED_LOCATION ${SOURCE_DIR}/test_protocol_plug_main)
|
|
||||||
|
|
||||||
|
|
||||||
add_library(${lib_name}_test_plug SHARED ${lib_name}_test_plug.cpp)
|
add_library(${lib_name}_test_plug SHARED ${lib_name}_test_plug.cpp)
|
||||||
target_link_libraries(${lib_name}_test_plug MESA_prof_load cjson)
|
target_link_libraries(${lib_name}_test_plug MESA_prof_load cjson)
|
||||||
set_target_properties(${lib_name}_test_plug PROPERTIES PREFIX "")
|
set_target_properties(${lib_name}_test_plug PROPERTIES PREFIX "")
|
||||||
|
|
||||||
add_test(NAME COPY_QUIC_SO COMMAND sh -c "cp ${CMAKE_BINARY_DIR}/${lib_name}.so ${PROTO_TEST_RUN_DIR}/plug/protocol/${lib_name}/${lib_name}.so")
|
set(TEST_RUN_DIR ${CMAKE_INSTALL_PREFIX})
|
||||||
add_test(NAME COPY_TEST_SO COMMAND sh -c "cp ${CMAKE_CURRENT_BINARY_DIR}/${lib_name}_test_plug.so ${PROTO_TEST_RUN_DIR}/plug/business/${lib_name}_test_plug/${lib_name}_test_plug.so")
|
set(PLUGIN_TEST_MAIN ${CMAKE_INSTALL_PREFIX}/plugin_test_main)
|
||||||
add_test(NAME IQUIC_29_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/iquic/29//${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/iquic/29/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
message(STATUS "TEST_RUN_DIR='${TEST_RUN_DIR}'")
|
||||||
add_test(NAME GQUIC_23_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/23/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/23/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
|
||||||
add_test(NAME GQUIC_25_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/25/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/25/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
# build test env
|
||||||
add_test(NAME GQUIC_33_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/33/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/33/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME MKDIR COMMAND sh -c "mkdir -p ${TEST_RUN_DIR}/plug/protocol/${lib_name} && mkdir -p ${TEST_RUN_DIR}/plug/business/${lib_name}_test_plug && mkdir -p ${TEST_RUN_DIR}/conf/${lib_name}")
|
||||||
add_test(NAME GQUIC_34_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/34/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/34/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME COPY_PLUGIN_TEST_MAIN COMMAND sh -c "cp ${TEST_RUN_DIR}/tools/plugin_test_main ${TEST_RUN_DIR}/plugin_test_main")
|
||||||
add_test(NAME GQUIC_35_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/35/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/35/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME COPY_CONFLIST COMMAND sh -c "mkdir -p ${TEST_RUN_DIR}/plug/ && cp ${CMAKE_CURRENT_SOURCE_DIR}/conflist.inf ${TEST_RUN_DIR}/plug/conflist.inf")
|
||||||
add_test(NAME GQUIC_37_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/37/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/37/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME COPY_QUIC_DECODER_CONF COMMAND sh -c "cp ${CMAKE_SOURCE_DIR}/bin/${lib_name}.conf ${TEST_RUN_DIR}/conf/${lib_name}/")
|
||||||
add_test(NAME GQUIC_39_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/39/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/39/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME ADD_QUIC_TO_ENTRY_LIST COMMAND sh -c "echo 'QUIC' >> ${TEST_RUN_DIR}/etc/entrylist.conf")
|
||||||
add_test(NAME GQUIC_41_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/41/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/41/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
|
||||||
add_test(NAME GQUIC_43_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/43/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/43/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME COPY_QUIC_INF COMMAND sh -c "cp ${CMAKE_SOURCE_DIR}/bin/${lib_name}.inf ${TEST_RUN_DIR}/plug/protocol/${lib_name}/${lib_name}.inf")
|
||||||
add_test(NAME GQUIC_44_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/44/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/44/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME COPY_QUIC_SO COMMAND sh -c "cp ${CMAKE_BINARY_DIR}/${lib_name}.so ${TEST_RUN_DIR}/plug/protocol/${lib_name}/${lib_name}.so")
|
||||||
add_test(NAME GQUIC_46_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/46/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/46/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
|
||||||
add_test(NAME GQUIC_50_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/50/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/50/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME COPY_TEST_INF COMMAND sh -c "cp ${CMAKE_CURRENT_SOURCE_DIR}/${lib_name}_test_plug.inf ${TEST_RUN_DIR}/plug/business/${lib_name}_test_plug/${lib_name}_test_plug.inf")
|
||||||
add_test(NAME MVFST_01_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/01/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/01/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME COPY_TEST_SO COMMAND sh -c "cp ${CMAKE_CURRENT_BINARY_DIR}/${lib_name}_test_plug.so ${TEST_RUN_DIR}/plug/business/${lib_name}_test_plug/${lib_name}_test_plug.so")
|
||||||
add_test(NAME MVFST_02_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/02/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/02/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
|
||||||
add_test(NAME TQUIC_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/tquic/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/tquic/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
# update sapp config files
|
||||||
add_test(NAME IQUIC_PORT_8443_TEST COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/port-8443/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/port-8443/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME UPDATE_SAPP_LOG_LEVEL COMMAND bash -c "sed -i 's/sapp_log.fatal/sapp_log.info/' ${TEST_RUN_DIR}/etc/sapp_log.conf")
|
||||||
add_test(NAME QUIC_RFC9000 COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME ENABLE_SAPP_MONITOR COMMAND bash -c "sed -i 's/monitor_thread_enabled=0/monitor_thread_enabled=1/' ${TEST_RUN_DIR}/etc/sapp.toml")
|
||||||
add_test(NAME QUIC_RFC9000_FRAGMENT COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-fragment/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-fragment/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
|
||||||
add_test(NAME QUIC_RFC9000_SPECIAL COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-special/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-special/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME IQUIC_29_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/iquic/29/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/iquic/29/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
add_test(NAME QUIC_AIRPORT COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/airport/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/airport -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME GQUIC_23_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/23/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/23/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
add_test(NAME QUIC_SPECIAL COMMAND proto_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/special/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/special/ -name *.pcap|sort -V" WORKING_DIRECTORY ${PROTO_TEST_RUN_DIR})
|
add_test(NAME GQUIC_25_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/25/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/25/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_33_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/33/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/33/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_34_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/34/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/34/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_35_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/35/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/35/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_37_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/37/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/37/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_39_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/39/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/39/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_41_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/41/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/41/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_43_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/43/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/43/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_44_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/44/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/44/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_46_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/46/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/46/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME GQUIC_50_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/50/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/gquic/50/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME MVFST_01_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/01/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/01/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME MVFST_02_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/02/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/mvfst/02/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME TQUIC_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/tquic/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/tquic/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME IQUIC_PORT_8443_TEST COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/port-8443/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/port-8443/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME QUIC_RFC9000 COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME QUIC_RFC9000_FRAGMENT COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-fragment/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-fragment/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME QUIC_RFC9000_SPECIAL COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-special/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-special/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME QUIC_AIRPORT COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/airport/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/airport -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME QUIC_SPECIAL COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/special/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/special/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
add_test(NAME QUIC_CHLO_FRAGMENT COMMAND ./plugin_test_main ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-chlo-fragment/${lib_name}_result.json -f "find ${CMAKE_CURRENT_SOURCE_DIR}/pcap/rfc9000-chlo-fragment/ -name *.pcap|sort -V" WORKING_DIRECTORY ${TEST_RUN_DIR})
|
||||||
|
|||||||
BIN
test/pcap/rfc9000-chlo-fragment/1-google-chlo-fragment-2.pcap
Normal file
BIN
test/pcap/rfc9000-chlo-fragment/1-google-chlo-fragment-2.pcap
Normal file
Binary file not shown.
BIN
test/pcap/rfc9000-chlo-fragment/2-google-chlo-fragment-3.pcap
Normal file
BIN
test/pcap/rfc9000-chlo-fragment/2-google-chlo-fragment-3.pcap
Normal file
Binary file not shown.
BIN
test/pcap/rfc9000-chlo-fragment/3-facebook-chlo-fragment-2.pcap
Normal file
BIN
test/pcap/rfc9000-chlo-fragment/3-facebook-chlo-fragment-2.pcap
Normal file
Binary file not shown.
Binary file not shown.
BIN
test/pcap/rfc9000-chlo-fragment/5-google_quic-2.pcap
Normal file
BIN
test/pcap/rfc9000-chlo-fragment/5-google_quic-2.pcap
Normal file
Binary file not shown.
32
test/pcap/rfc9000-chlo-fragment/quic_result.json
Normal file
32
test/pcap/rfc9000-chlo-fragment/quic_result.json
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
[
|
||||||
|
{
|
||||||
|
"Tuple4": "2607:5d00:2:2::38:2.53977>2404:6800:4005:807::2004.443",
|
||||||
|
"VERSION": "IETF QUIC RFC9000",
|
||||||
|
"SNI": "www.google.com",
|
||||||
|
"name": "QUIC_RESULT_1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Tuple4": "2607:5d00:2:2::38:2.50835>2404:6800:4005:80d::2003.443",
|
||||||
|
"VERSION": "IETF QUIC RFC9000",
|
||||||
|
"SNI": "www.google.com.hk",
|
||||||
|
"name": "QUIC_RESULT_2"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Tuple4": "192.168.64.25.61166>157.240.245.35.443",
|
||||||
|
"VERSION": "IETF QUIC RFC9000",
|
||||||
|
"SNI": "www.facebook.com",
|
||||||
|
"name": "QUIC_RESULT_3"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Tuple4": "2607:5d00:2:2::38:2.54817>2404:6800:4005:80c::200a.443",
|
||||||
|
"VERSION": "IETF QUIC RFC9000",
|
||||||
|
"SNI": "optimizationguide-pa.googleapis.com",
|
||||||
|
"name": "QUIC_RESULT_4"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Tuple4": "192.168.54.157.60388>142.250.71.164.443",
|
||||||
|
"VERSION": "IETF QUIC RFC9000",
|
||||||
|
"SNI": "www.google.com",
|
||||||
|
"name": "QUIC_RESULT_5"
|
||||||
|
}
|
||||||
|
]
|
||||||
@@ -19,7 +19,7 @@ extern "C" int commit_test_result_json(cJSON *node, const char *name);
|
|||||||
static int g_result_count = 1;
|
static int g_result_count = 1;
|
||||||
|
|
||||||
extern "C" unsigned char QUIC_TEST_PLUG_ENTRY(stSessionInfo *session_info, void **pme,
|
extern "C" unsigned char QUIC_TEST_PLUG_ENTRY(stSessionInfo *session_info, void **pme,
|
||||||
int thread_seq, struct streaminfo *a_tcp, void *a_packet)
|
int thread_seq, struct streaminfo *a_udp, void *a_packet)
|
||||||
{
|
{
|
||||||
assert(NULL != session_info || pme != NULL);
|
assert(NULL != session_info || pme != NULL);
|
||||||
|
|
||||||
@@ -34,7 +34,7 @@ extern "C" unsigned char QUIC_TEST_PLUG_ENTRY(stSessionInfo *session_info, void
|
|||||||
{
|
{
|
||||||
ctx = cJSON_CreateObject();
|
ctx = cJSON_CreateObject();
|
||||||
*pme = (void *)ctx;
|
*pme = (void *)ctx;
|
||||||
cJSON_AddStringToObject(ctx, "Tuple4", printaddr(&a_tcp->addr, a_tcp->threadnum));
|
cJSON_AddStringToObject(ctx, "Tuple4", printaddr(&a_udp->addr, a_udp->threadnum));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
Reference in New Issue
Block a user