Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
46089d76
Commit
46089d76
authored
Mar 13, 2016
by
Vladislav Vaintroub
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MDEV-9659 : AWS KMS encryption plugin
parent
517584dd
Changes
3
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
740 additions
and
2 deletions
+740
-2
plugin/aws_key_management/CMakeLists.txt
plugin/aws_key_management/CMakeLists.txt
+151
-0
plugin/aws_key_management/aws_key_management_plugin.cc
plugin/aws_key_management/aws_key_management_plugin.cc
+587
-0
win/packaging/CPackWixConfig.cmake
win/packaging/CPackWixConfig.cmake
+2
-2
No files found.
plugin/aws_key_management/CMakeLists.txt
0 → 100644
View file @
46089d76
# We build parts of AWS C++ SDK as CMake external project
# The restrictions of the SDK (https://github.com/awslabs/aws-sdk-cpp/blob/master/README.md)
# are
# - OS : Windows,Linux or OSX
# - C++11 compiler : VS2013+, gcc 4.7+, clang 3.3+
# - libcurl development package needs to be present on Unixes
#
# If we build SDK outselves, we'll need require GIT to be present on the build machine
# Give message why the building this plugin is skipped (only if -DVERBOSE is defined)
# or if plugin is explicitely requested to build. Then bail out.
MACRO
(
SKIP_AWS_PLUGIN msg
)
IF
(
VERBOSE OR
"
${
PLUGIN_AWS_KEY_MANAGEMENT
}
"
MATCHES
"^(STATIC|DYNAMIC)$"
)
MESSAGE
(
STATUS
"Skip aws_key_management -
${
msg
}
"
)
ENDIF
()
RETURN
()
ENDMACRO
()
# This plugin needs recent C++ compilers (AWS C++ SDK header files are using C++11 features)
SET
(
CXX11_FLAGS
)
SET
(
OLD_COMPILER_MSG
"AWS SDK requires c++11 -capable compiler (minimal supported versions are g++ 4.7, clang 3.3, VS2103)"
)
IF
(
CMAKE_CXX_COMPILER_ID MATCHES
"GNU"
)
EXECUTE_PROCESS
(
COMMAND
${
CMAKE_CXX_COMPILER
}
-dumpversion OUTPUT_VARIABLE GCC_VERSION
)
IF
(
GCC_VERSION VERSION_LESS 4.8
)
SKIP_AWS_PLUGIN
(
"
${
OLD_COMPILER_MSG
}
"
)
ENDIF
()
SET
(
CXX11_FLAGS
"-std=c++11"
)
ELSEIF
(
CMAKE_CXX_COMPILER_ID MATCHES
"Clang"
)
IF
((
CMAKE_CXX_COMPILER_VERSION AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 3.3
)
OR
(
CLANG_VERSION_STRING AND CLANG_VERSION_STRING VERSION_LESS 3.3
))
SKIP_AWS_PLUGIN
(
"
${
OLD_COMPILER_MSG
}
"
)
ENDIF
()
SET
(
CXX11_FLAGS
"-stdlib=libc++"
)
ELSEIF
(
MSVC
)
IF
(
MSVC_VERSION LESS 1800
)
SKIP_AWS_PLUGIN
(
"
${
OLD_COMPILER_MSG
}
"
)
ENDIF
()
ELSE
()
SKIP_AWS_PLUGIN
(
"Compiler not supported by AWS C++ SDK"
)
ENDIF
()
IF
(
NOT
(
WIN32 OR APPLE
OR
(
CMAKE_SYSTEM_NAME MATCHES
"Linux"
)))
SKIP_AWS_PLUGIN
(
"OS unsupported by AWS SDK"
)
ENDIF
()
# Figure out where AWS installs SDK libraries
# The below is defined in AWS SDK's CMakeLists.txt
# (and their handling is weird, every OS has special install directory)
IF
(
WIN32
)
SET
(
SDK_INSTALL_BINARY_PREFIX
"windows"
)
ELSEIF
(
APPLE
)
SET
(
SDK_INSTALL_BINARY_PREFIX
"mac"
)
ELSEIF
(
UNIX
)
SET
(
SDK_INSTALL_BINARY_PREFIX
"linux"
)
ENDIF
()
IF
(
NOT APPLE
)
IF
(
CMAKE_SIZEOF_VOID_P EQUAL 8
)
SET
(
SDK_INSTALL_BINARY_PREFIX
"
${
SDK_INSTALL_BINARY_PREFIX
}
/intel64"
)
ELSE
()
SET
(
SDK_INSTALL_BINARY_PREFIX
"
${
SDK_INSTALL_BINARY_PREFIX
}
/ia32"
)
ENDIF
()
ENDIF
()
IF
(
CMAKE_CONFIGURATION_TYPES
)
SET
(
SDK_INSTALL_BINARY_PREFIX
"
${
SDK_INSTALL_BINARY_PREFIX
}
/
${
CMAKE_CFG_INTDIR
}
"
)
ENDIF
()
FIND_LIBRARY
(
AWS_CPP_SDK_CORE NAMES aws-cpp-sdk-core PATH_SUFFIXES
"
${
SDK_INSTALL_BINARY_PREFIX
}
"
)
FIND_LIBRARY
(
AWS_CPP_SDK_KMS NAMES aws-cpp-sdk-core PATH_SUFFIXES
"
${
SDK_INSTALL_BINARY_PREFIX
}
"
)
SET
(
CMAKE_REQUIRED_FLAGS
${
CXX11_FLAGS
}
)
CHECK_INCLUDE_FILE_CXX
(
aws/kms/KMSClient.h HAVE_AWS_HEADERS
)
IF
(
AWS_CPP_SDK_CORE AND AWS_CPP_SDK_KMS AND HAVE_AWS_HEADERS
)
# AWS C++ SDK installed
SET
(
AWS_SDK_LIBS
${
AWS_CPP_SDK_CORE
}
${
AWS_CPP_SDK_KMS
}
)
ELSE
()
# Build from source, using ExternalProject_Add
IF
(
CMAKE_VERSION VERSION_LESS
"2.8.8"
)
SKIP_AWS_PLUGIN
(
"CMake is too old"
)
ENDIF
()
FIND_PACKAGE
(
Git
)
IF
(
NOT GIT_FOUND
)
SKIP_AWS_PLUGIN
(
"no GIT"
)
ENDIF
()
INCLUDE
(
ExternalProject
)
IF
(
UNIX
)
FIND_PACKAGE
(
CURL
)
IF
(
NOT CURL_FOUND
)
SKIP_AWS_PLUGIN
(
"AWS C++ SDK requires libcurl development package"
)
ENDIF
()
SET
(
PIC_FLAG -fPIC
)
ENDIF
()
IF
(
MSVC
)
SET
(
EXTRA_SDK_CMAKE_FLAGS -DCMAKE_CXX_FLAGS_DEBUGOPT=
""
-DCMAKE_EXE_LINKER_FLAGS_DEBUGOPT=
""
-DCMAKE_CXX_FLAGS=/wd4592
)
ENDIF
()
IF
(
CMAKE_CXX_COMPILER
)
SET
(
EXTRA_SDK_CMAKE_FLAGS
${
EXTRA_SDK_CMAKE_FLAGS
}
-DCMAKE_CXX_COMPILER=
${
CMAKE_CXX_COMPILER
}
)
ENDIF
()
# Relax AWS C++ SDK unreasonably high requirements for CMake version. Use replace utility (from MariaDB build)
# to patch their CMakeLists.txt
SET
(
AWS_SDK_PATCH_COMMAND
)
ExternalProject_Add
(
aws_sdk_cpp
GIT_REPOSITORY
"https://github.com/awslabs/aws-sdk-cpp.git"
GIT_TAG
"0.9.6"
# single tag
UPDATE_COMMAND
""
PATCH_COMMAND replace 3.1.2 2.8 --
${
CMAKE_BINARY_DIR
}
/aws-sdk-cpp/CMakeLists.txt
SOURCE_DIR
"
${
CMAKE_BINARY_DIR
}
/aws-sdk-cpp"
CMAKE_ARGS
-DBUILD_ONLY=aws-cpp-sdk-kms -DSTATIC_LINKING=1
"-DCMAKE_CXX_FLAGS_DEBUG=
${
CMAKE_CXX_FLAGS_DEBUG
}
${
PIC_FLAG
}
"
"-DCMAKE_CXX_FLAGS_RELWITHDEBINFO=
${
CMAKE_CXX_FLAGS_RELWITHDEBINFO
}
${
PIC_FLAG
}
"
"-DCMAKE_CXX_FLAGS_RELEASE=
${
CMAKE_CXX_FLAGS_RELEASE
}
${
PIC_FLAG
}
"
"-DCMAKE_CXX_FLAGS_MINSIZEREL=
${
CMAKE_CXX_FLAGS_MINSIZEREL
}
${
PIC_FLAG
}
"
${
EXTRA_SDK_CMAKE_FLAGS
}
-DCMAKE_INSTALL_PREFIX=
${
CMAKE_BINARY_DIR
}
/aws_sdk_cpp
TEST_COMMAND
""
)
# We do not need to build the whole SDK , just 2 of its libs
set
(
AWS_SDK_LIBS aws-cpp-sdk-core aws-cpp-sdk-kms
)
FOREACH
(
lib
${
AWS_SDK_LIBS
}
)
ADD_LIBRARY
(
${
lib
}
STATIC IMPORTED GLOBAL
)
ADD_DEPENDENCIES
(
${
lib
}
aws_sdk_cpp
)
SET
(
loc
"
${
CMAKE_BINARY_DIR
}
/aws_sdk_cpp/lib/
${
SDK_INSTALL_BINARY_PREFIX
}
/
${
CMAKE_STATIC_LIBRARY_PREFIX
}${
lib
}${
CMAKE_STATIC_LIBRARY_SUFFIX
}
"
)
SET_TARGET_PROPERTIES
(
${
lib
}
PROPERTIES IMPORTED_LOCATION
${
loc
}
)
IF
(
WIN32
)
SET_TARGET_PROPERTIES
(
${
lib
}
PROPERTIES IMPORTED_LINK_INTERFACE_LIBRARIES
"bcrypt;winhttp;wininet;userenv"
)
ELSE
()
SET_TARGET_PROPERTIES
(
${
lib
}
PROPERTIES IMPORTED_LINK_INTERFACE_LIBRARIES
"
${
SSL_LIBRARIES
}
;
${
CURL_LIBRARIES
}
"
)
ENDIF
()
ENDFOREACH
()
IF
(
CMAKE_SYSTEM_NAME MATCHES
"Linux"
)
# Need whole-archive , otherwise static libraries are not linked
SET
(
AWS_SDK_LIBS -Wl,--whole-archive
${
AWS_SDK_LIBS
}
-Wl,--no-whole-archive
)
ENDIF
()
SET_TARGET_PROPERTIES
(
aws_sdk_cpp PROPERTIES EXCLUDE_FROM_ALL TRUE
)
INCLUDE_DIRECTORIES
(
${
CMAKE_BINARY_DIR
}
/aws_sdk_cpp/include
)
ENDIF
()
SET
(
CMAKE_CXX_FLAGS
"
${
CMAKE_CXX_FLAGS
}
${
CXX11_FLAGS
}
"
)
MYSQL_ADD_PLUGIN
(
aws_key_management aws_key_management_plugin.cc
COMPONENT aws-key-management
LINK_LIBRARIES
${
AWS_SDK_LIBS
}
DISABLED
)
plugin/aws_key_management/aws_key_management_plugin.cc
0 → 100644
View file @
46089d76
This diff is collapsed.
Click to expand it.
win/packaging/CPackWixConfig.cmake
View file @
46089d76
...
@@ -9,7 +9,7 @@ IF(ESSENTIALS)
...
@@ -9,7 +9,7 @@ IF(ESSENTIALS)
ENDIF
()
ENDIF
()
ELSE
()
ELSE
()
SET
(
CPACK_COMPONENTS_USED
SET
(
CPACK_COMPONENTS_USED
"Server;Client;Development;SharedLibraries;Embedded;Documentation;IniFiles;Readme;Debuginfo;Common;connect-engine;ClientPlugins;gssapi-server;gssapi-client"
)
"Server;Client;Development;SharedLibraries;Embedded;Documentation;IniFiles;Readme;Debuginfo;Common;connect-engine;ClientPlugins;gssapi-server;gssapi-client
;aws-key-management
"
)
ENDIF
()
ENDIF
()
SET
(
WIX_FEATURE_MySQLServer_EXTRA_FEATURES
"DBInstance;SharedClientServerComponents"
)
SET
(
WIX_FEATURE_MySQLServer_EXTRA_FEATURES
"DBInstance;SharedClientServerComponents"
)
...
@@ -57,7 +57,7 @@ SET(CPACK_COMPONENT_GROUP_MYSQLSERVER_DESCRIPTION "Install server")
...
@@ -57,7 +57,7 @@ SET(CPACK_COMPONENT_GROUP_MYSQLSERVER_DESCRIPTION "Install server")
#Miscellaneous (hidden) components, part of server / or client programs
#Miscellaneous (hidden) components, part of server / or client programs
FOREACH
(
comp connect-engine ClientPlugins gssapi-server gssapi-client
)
FOREACH
(
comp connect-engine ClientPlugins gssapi-server gssapi-client
aws-key-management
)
STRING
(
TOUPPER
"
${
comp
}
"
comp
)
STRING
(
TOUPPER
"
${
comp
}
"
comp
)
SET
(
CPACK_COMPONENT_
${
comp
}
_GROUP
"MySQLServer"
)
SET
(
CPACK_COMPONENT_
${
comp
}
_GROUP
"MySQLServer"
)
SET
(
CPACK_COMPONENT_
${
comp
}
_HIDDEN 1
)
SET
(
CPACK_COMPONENT_
${
comp
}
_HIDDEN 1
)
...
...
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