MySQL 9.1.0
Source Code Documentation
keyring_reader_service_definition.h
Go to the documentation of this file.
1/* Copyright (c) 2021, 2024, 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 designed to work 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 either included with
13the program or referenced in the documentation.
14
15This program is distributed in the hope that it will be useful,
16but WITHOUT ANY WARRANTY; without even the implied warranty of
17MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18GNU General Public License, version 2.0, for more details.
19
20You should have received a copy of the GNU General Public License
21along with this program; if not, write to the Free Software
22Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
23
24#ifndef KEYRING_READER_SERVICE_IMPL_INCLUDED
25#define KEYRING_READER_SERVICE_IMPL_INCLUDED
26
29
31
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 keyring_common::service_definition
101
102#define KEYRING_READER_IMPLEMENTOR(component_name) \
103 BEGIN_SERVICE_IMPLEMENTATION(component_name, keyring_reader_with_status) \
104 keyring_common::service_definition::Keyring_reader_service_impl::init, \
105 keyring_common::service_definition::Keyring_reader_service_impl::deinit, \
106 keyring_common::service_definition::Keyring_reader_service_impl:: \
107 fetch_length, \
108 keyring_common::service_definition::Keyring_reader_service_impl::fetch \
109 END_SERVICE_IMPLEMENTATION()
110
111#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:57
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:45
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:66
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:81
Specifies macros to define Components.
struct my_h_keyring_reader_object_imp * my_h_keyring_reader_object
Definition: keyring_reader_with_status.h:29
Definition: keyring_encryption_service_definition.h:32
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:88