MySQL 8.3.0
Source Code Documentation
keyring_reader_service_definition.h
Go to the documentation of this file.
1/* Copyright (c) 2021, 2023, Oracle and/or its affiliates.
2
3This program is free software; you can redistribute it and/or modify
4it under the terms of the GNU General Public License, version 2.0,
5as published by the Free Software Foundation.
6
7This program is also distributed with certain software (including
8but not limited to OpenSSL) that is licensed under separate terms,
9as designated in a particular file or component or in included license
10documentation. The authors of MySQL hereby grant you an additional
11permission to link the program and your derivative works with the
12separately licensed software that they have included with MySQL.
13
14This program is distributed in the hope that it will be useful,
15but WITHOUT ANY WARRANTY; without even the implied warranty of
16MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17GNU General Public License, version 2.0, for more details.
18
19You should have received a copy of the GNU General Public License
20along with this program; if not, write to the Free Software
21Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
22
23#ifndef KEYRING_READER_SERVICE_IMPL_INCLUDED
24#define KEYRING_READER_SERVICE_IMPL_INCLUDED
25
28
30
31namespace keyring_common {
32namespace service_definition {
33
35 public:
36 /**
37 Initialize reader
38
39 @param [in] data_id Data Identifier
40 @param [in] auth_id Authorization ID
41 @param [out] reader_object Reader object
42
43 @returns status of the operation
44 @retval false Success
45 @retval true Failure
46 */
47 static DEFINE_BOOL_METHOD(init, (const char *data_id, const char *auth_id,
48 my_h_keyring_reader_object *reader_object));
49
50 /**
51 Deinitialize reader
52
53 @param [in] reader_object Reader object
54
55 @returns status of the operation
56 @retval false Success
57 @retval true Failure
58 */
60
61 /**
62 Fetch length of the data
63
64 @param [in] reader_object Reader object
65 @param [out] data_size Size of fetched data
66 @param [out] data_type_size Size of data type
67
68 @returns status of the operation
69 @retval false Success
70 @retval true Failure
71 */
73 (my_h_keyring_reader_object reader_object,
74 size_t *data_size, size_t *data_type_size));
75
76 /**
77 Fetches data from keyring
78
79 @param [in] reader_object Reader object
80 @param [out] data_buffer Out buffer for data
81 @param [in] data_buffer_length Length of out buffer
82 @param [out] data_size Size of fetched data
83 @param [out] data_type Type of data
84 @param [in] data_type_buffer_length Length of data type buffer
85 @param [out] data_type_size Size of data type
86
87 @returns status of the operation
88 @retval false Success
89 @retval true Failure
90 */
91
93 (my_h_keyring_reader_object reader_object,
94 unsigned char *data_buffer,
95 size_t data_buffer_length, size_t *data_size,
96 char *data_type, size_t data_type_buffer_length,
97 size_t *data_type_size));
98};
99
100} // namespace service_definition
101} // namespace keyring_common
102
103#define KEYRING_READER_IMPLEMENTOR(component_name) \
104 BEGIN_SERVICE_IMPLEMENTATION(component_name, keyring_reader_with_status) \
105 keyring_common::service_definition::Keyring_reader_service_impl::init, \
106 keyring_common::service_definition::Keyring_reader_service_impl::deinit, \
107 keyring_common::service_definition::Keyring_reader_service_impl:: \
108 fetch_length, \
109 keyring_common::service_definition::Keyring_reader_service_impl::fetch \
110 END_SERVICE_IMPLEMENTATION()
111
112#endif // KEYRING_READER_SERVICE_IMPL_INCLUDED
Definition: keyring_reader_service_definition.h:34
static mysql_service_status_t deinit(my_h_keyring_reader_object reader_object) noexcept
Deinitialize reader.
Definition: keyring_reader_service_definition.cc:54
static mysql_service_status_t init(const char *data_id, const char *auth_id, my_h_keyring_reader_object *reader_object) noexcept
Initialize reader.
Definition: keyring_reader_service_definition.cc:43
static mysql_service_status_t fetch_length(my_h_keyring_reader_object reader_object, size_t *data_size, size_t *data_type_size) noexcept
Fetch length of the data.
Definition: keyring_reader_service_definition.cc:63
static mysql_service_status_t fetch(my_h_keyring_reader_object reader_object, unsigned char *data_buffer, size_t data_buffer_length, size_t *data_size, char *data_type, size_t data_type_buffer_length, size_t *data_type_size) noexcept
Fetches data from keyring.
Definition: keyring_reader_service_definition.cc:78
Specifies macros to define Components.
struct my_h_keyring_reader_object_imp * my_h_keyring_reader_object
Definition: keyring_reader_with_status.h:28
Definition: keyring_encryption_service_definition.h:31
Specifies macros to define Service Implementations.
#define DEFINE_BOOL_METHOD(name, args)
A short macro to define method that returns bool, which is the most common case.
Definition: service_implementation.h:87