Submit
Path:
~
/
/
proc
/
self
/
root
/
usr
/
include
/
mysql
/
server
/
mysql
/
File Content:
plugin_encryption.h
#ifndef MYSQL_PLUGIN_ENCRYPTION_INCLUDED /* Copyright (C) 2014, 2015 Sergei Golubchik and MariaDB This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; version 2 of the License. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1335 USA */ /** @file Encryption Plugin API. This file defines the API for server plugins that manage encryption keys for MariaDB on-disk data encryption. */ #define MYSQL_PLUGIN_ENCRYPTION_INCLUDED #include <mysql/plugin.h> #ifdef __cplusplus extern "C" { #endif #define MariaDB_ENCRYPTION_INTERFACE_VERSION 0x0300 /** Encryption plugin descriptor */ struct st_mariadb_encryption { int interface_version; /**< version plugin uses */ /*********** KEY MANAGEMENT ********************************************/ /** function returning latest key version for a given key id @return a version or ENCRYPTION_KEY_VERSION_INVALID to indicate an error. */ unsigned int (*get_latest_key_version)(unsigned int key_id); /** function returning a key for a key version @param version the requested key version @param key the key will be stored there. Can be NULL - in which case no key will be returned @param key_length in: key buffer size out: the actual length of the key This method can be used to query the key length - the required buffer size - by passing key==NULL. If the buffer size is less than the key length the content of the key buffer is undefined (the plugin is free to partially fill it with the key data or leave it untouched). @return 0 on success, or ENCRYPTION_KEY_VERSION_INVALID, ENCRYPTION_KEY_BUFFER_TOO_SMALL or any other non-zero number for errors */ unsigned int (*get_key)(unsigned int key_id, unsigned int version, unsigned char *key, unsigned int *key_length); /*********** ENCRYPTION ************************************************/ /* the caller uses encryption as follows: 1. create the encryption context object of the crypt_ctx_size() bytes. 2. initialize it with crypt_ctx_init(). 3. repeat crypt_ctx_update() until there are no more data to encrypt. 4. write the remaining output bytes and destroy the context object with crypt_ctx_finish(). */ /** returns the size of the encryption context object in bytes */ unsigned int (*crypt_ctx_size)(unsigned int key_id, unsigned int key_version); /** initializes the encryption context object. */ int (*crypt_ctx_init)(void *ctx, const unsigned char* key, unsigned int klen, const unsigned char* iv, unsigned int ivlen, int flags, unsigned int key_id, unsigned int key_version); /** processes (encrypts or decrypts) a chunk of data writes the output to the dst buffer. note that it might write more bytes that were in the input. or less. or none at all. dlen points to the starting lenght of the output buffer. Upon return, it should be set to the number of bytes written. */ int (*crypt_ctx_update)(void *ctx, const unsigned char* src, unsigned int slen, unsigned char* dst, unsigned int* dlen); /** writes the remaining output bytes and destroys the encryption context crypt_ctx_update might've cached part of the output in the context, this method will flush these data out. */ int (*crypt_ctx_finish)(void *ctx, unsigned char* dst, unsigned int* dlen); /** returns the length of the encrypted data it returns the exact length, given only the source length. which means, this API only supports encryption algorithms where the length of the encrypted data only depends on the length of the input (a.k.a. compression is not supported). */ unsigned int (*encrypted_length)(unsigned int slen, unsigned int key_id, unsigned int key_version); }; #ifdef __cplusplus } #endif #endif
Submit
FILE
FOLDER
Name
Size
Permission
Action
psi
---
0755
auth_dialog_client.h
2061 bytes
0644
client_plugin.h
6421 bytes
0644
plugin.h
29894 bytes
0644
plugin_audit.h
5575 bytes
0644
plugin_auth.h
5400 bytes
0644
plugin_auth_common.h
4557 bytes
0644
plugin_data_type.h
1300 bytes
0644
plugin_encryption.h
4561 bytes
0644
plugin_ftparser.h
7832 bytes
0644
plugin_function.h
1437 bytes
0644
plugin_password_validation.h
1620 bytes
0644
service_base64.h
2932 bytes
0644
service_debug_sync.h
13580 bytes
0644
service_encryption.h
6173 bytes
0644
service_encryption_scheme.h
5646 bytes
0644
service_json.h
4551 bytes
0644
service_kill_statement.h
2070 bytes
0644
service_log_warnings.h
1377 bytes
0644
service_logger.h
3551 bytes
0644
service_md5.h
2119 bytes
0644
service_my_crypt.h
4167 bytes
0644
service_my_print_error.h
2328 bytes
0644
service_my_snprintf.h
3722 bytes
0644
service_print_check_msg.h
1552 bytes
0644
service_progress_report.h
3356 bytes
0644
service_sha1.h
2162 bytes
0644
service_sha2.h
5299 bytes
0644
service_sql.h
5134 bytes
0644
service_thd_alloc.h
4739 bytes
0644
service_thd_autoinc.h
1692 bytes
0644
service_thd_error_context.h
3424 bytes
0644
service_thd_mdl.h
1282 bytes
0644
service_thd_rnd.h
1902 bytes
0644
service_thd_specifics.h
3686 bytes
0644
service_thd_timezone.h
2291 bytes
0644
service_thd_wait.h
3695 bytes
0644
service_wsrep.h
14158 bytes
0644
services.h
1762 bytes
0644
N4ST4R_ID | Naxtarrr