MySQL 8.4.1
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
32namespace keyring_common {
33namespace service_definition {
34
36 public:
37 /**
38 Initialize reader
39
40 @param [in] data_id Data Identifier
41 @param [in] auth_id Authorization ID
42 @param [out] reader_object Reader object
43
44 @returns status of the operation
45 @retval false Success
46 @retval true Failure
47 */
48 static DEFINE_BOOL_METHOD(init, (const char *data_id, const char *auth_id,
49 my_h_keyring_reader_object *reader_object));
50
51 /**
52 Deinitialize reader
53
54 @param [in] reader_object Reader object
55
56 @returns status of the operation
57 @retval false Success
58 @retval true Failure
59 */
61
62 /**
63 Fetch length of the data
64
65 @param [in] reader_object Reader object
66 @param [out] data_size Size of fetched data
67 @param [out] data_type_size Size of data type
68
69 @returns status of the operation
70 @retval false Success
71 @retval true Failure
72 */
74 (my_h_keyring_reader_object reader_object,
75 size_t *data_size, size_t *data_type_size));
76
77 /**
78 Fetches data from keyring
79
80 @param [in] reader_object Reader object
81 @param [out] data_buffer Out buffer for data
82 @param [in] data_buffer_length Length of out buffer
83 @param [out] data_size Size of fetched data
84 @param [out] data_type Type of data
85 @param [in] data_type_buffer_length Length of data type buffer
86 @param [out] data_type_size Size of data type
87
88 @returns status of the operation
89 @retval false Success
90 @retval true Failure
91 */
92
94 (my_h_keyring_reader_object reader_object,
95 unsigned char *data_buffer,
96 size_t data_buffer_length, size_t *data_size,
97 char *data_type, size_t data_type_buffer_length,
98 size_t *data_type_size));
99};
100
101} // namespace service_definition
102} // namespace keyring_common
103
104#define KEYRING_READER_IMPLEMENTOR(component_name) \
105 BEGIN_SERVICE_IMPLEMENTATION(component_name, keyring_reader_with_status) \
106 keyring_common::service_definition::Keyring_reader_service_impl::init, \
107 keyring_common::service_definition::Keyring_reader_service_impl::deinit, \
108 keyring_common::service_definition::Keyring_reader_service_impl:: \
109 fetch_length, \
110 keyring_common::service_definition::Keyring_reader_service_impl::fetch \
111 END_SERVICE_IMPLEMENTATION()
112
113#endif // KEYRING_READER_SERVICE_IMPL_INCLUDED
Definition: keyring_reader_service_definition.h:35
static mysql_service_status_t deinit(my_h_keyring_reader_object reader_object) noexcept
Deinitialize reader.
Definition: keyring_reader_service_definition.cc:55
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:44
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:64
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:79
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