Coverage Report

Created: 2024-02-25 07:20

/src/libfwsi/libfwsi/libfwsi_control_panel_item_values.c
Line
Count
Source (jump to first uncovered line)
1
/*
2
 * Control panel item (shell item) values functions
3
 *
4
 * Copyright (C) 2010-2024, Joachim Metz <joachim.metz@gmail.com>
5
 *
6
 * Refer to AUTHORS for acknowledgements.
7
 *
8
 * This program is free software: you can redistribute it and/or modify
9
 * it under the terms of the GNU Lesser General Public License as published by
10
 * the Free Software Foundation, either version 3 of the License, or
11
 * (at your option) any later version.
12
 *
13
 * This program is distributed in the hope that it will be useful,
14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16
 * GNU General Public License for more details.
17
 *
18
 * You should have received a copy of the GNU Lesser General Public License
19
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
20
 */
21
22
#include <common.h>
23
#include <byte_stream.h>
24
#include <memory.h>
25
#include <types.h>
26
27
#include "libfwsi_control_panel_identifier.h"
28
#include "libfwsi_control_panel_item_values.h"
29
#include "libfwsi_debug.h"
30
#include "libfwsi_libcerror.h"
31
#include "libfwsi_libcnotify.h"
32
#include "libfwsi_libfguid.h"
33
34
/* Creates control panel item values
35
 * Make sure the value control_panel_item_values is referencing, is set to NULL
36
 * Returns 1 if successful or -1 on error
37
 */
38
int libfwsi_control_panel_item_values_initialize(
39
     libfwsi_control_panel_item_values_t **control_panel_item_values,
40
     libcerror_error_t **error )
41
0
{
42
0
  static char *function = "libfwsi_control_panel_item_values_initialize";
43
44
0
  if( control_panel_item_values == NULL )
45
0
  {
46
0
    libcerror_error_set(
47
0
     error,
48
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
49
0
     LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE,
50
0
     "%s: invalid control panel item values.",
51
0
     function );
52
53
0
    return( -1 );
54
0
  }
55
0
  if( *control_panel_item_values != NULL )
56
0
  {
57
0
    libcerror_error_set(
58
0
     error,
59
0
     LIBCERROR_ERROR_DOMAIN_RUNTIME,
60
0
     LIBCERROR_RUNTIME_ERROR_VALUE_ALREADY_SET,
61
0
     "%s: invalid control panel item values value already set.",
62
0
     function );
63
64
0
    return( -1 );
65
0
  }
66
0
  *control_panel_item_values = memory_allocate_structure(
67
0
                                libfwsi_control_panel_item_values_t );
68
69
0
  if( *control_panel_item_values == NULL )
70
0
  {
71
0
    libcerror_error_set(
72
0
     error,
73
0
     LIBCERROR_ERROR_DOMAIN_MEMORY,
74
0
     LIBCERROR_MEMORY_ERROR_INSUFFICIENT,
75
0
     "%s: unable to create control panel item values.",
76
0
     function );
77
78
0
    goto on_error;
79
0
  }
80
0
  if( memory_set(
81
0
       *control_panel_item_values,
82
0
       0,
83
0
       sizeof( libfwsi_control_panel_item_values_t ) ) == NULL )
84
0
  {
85
0
    libcerror_error_set(
86
0
     error,
87
0
     LIBCERROR_ERROR_DOMAIN_MEMORY,
88
0
     LIBCERROR_MEMORY_ERROR_SET_FAILED,
89
0
     "%s: unable to clear control panel item values.",
90
0
     function );
91
92
0
    goto on_error;
93
0
  }
94
0
  return( 1 );
95
96
0
on_error:
97
0
  if( *control_panel_item_values != NULL )
98
0
  {
99
0
    memory_free(
100
0
     *control_panel_item_values );
101
102
0
    *control_panel_item_values = NULL;
103
0
  }
104
0
  return( -1 );
105
0
}
106
107
/* Frees control panel item values
108
 * Returns 1 if successful or -1 on error
109
 */
110
int libfwsi_control_panel_item_values_free(
111
     libfwsi_control_panel_item_values_t **control_panel_item_values,
112
     libcerror_error_t **error )
113
0
{
114
0
  static char *function = "libfwsi_control_panel_item_values_free";
115
116
0
  if( control_panel_item_values == NULL )
117
0
  {
118
0
    libcerror_error_set(
119
0
     error,
120
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
121
0
     LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE,
122
0
     "%s: invalid control panel item values.",
123
0
     function );
124
125
0
    return( -1 );
126
0
  }
127
0
  if( *control_panel_item_values != NULL )
128
0
  {
129
0
    memory_free(
130
0
     *control_panel_item_values );
131
132
0
    *control_panel_item_values = NULL;
133
0
  }
134
0
  return( 1 );
135
0
}
136
137
/* Reads the control panel item values
138
 * Returns 1 if successful, 0 if not supported or -1 on error
139
 */
140
int libfwsi_control_panel_item_values_read_data(
141
     libfwsi_control_panel_item_values_t *control_panel_item_values,
142
     const uint8_t *data,
143
     size_t data_size,
144
     libcerror_error_t **error )
145
0
{
146
0
  static char *function = "libfwsi_control_panel_item_values_read_data";
147
148
0
  if( control_panel_item_values == NULL )
149
0
  {
150
0
    libcerror_error_set(
151
0
     error,
152
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
153
0
     LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE,
154
0
     "%s: invalid control panel item values.",
155
0
     function );
156
157
0
    return( -1 );
158
0
  }
159
0
  if( data == NULL )
160
0
  {
161
0
    libcerror_error_set(
162
0
     error,
163
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
164
0
     LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE,
165
0
     "%s: invalid data.",
166
0
     function );
167
168
0
    return( -1 );
169
0
  }
170
0
  if( data_size > (size_t) SSIZE_MAX )
171
0
  {
172
0
    libcerror_error_set(
173
0
     error,
174
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
175
0
     LIBCERROR_ARGUMENT_ERROR_VALUE_EXCEEDS_MAXIMUM,
176
0
     "%s: data size exceeds maximum.",
177
0
     function );
178
179
0
    return( -1 );
180
0
  }
181
  /* Do not try to parse unsupported data sizes
182
   */
183
0
  if( data_size < 30 )
184
0
  {
185
0
    return( 0 );
186
0
  }
187
  /* Do not try to parse unknown class type indicators
188
   */
189
0
  if( data[ 2 ] != 0x71 )
190
0
  {
191
0
    return( 0 );
192
0
  }
193
0
  if( memory_copy(
194
0
       control_panel_item_values->identifier,
195
0
       &( data[ 14 ] ),
196
0
       16 ) == NULL )
197
0
  {
198
0
    libcerror_error_set(
199
0
     error,
200
0
     LIBCERROR_ERROR_DOMAIN_MEMORY,
201
0
     LIBCERROR_MEMORY_ERROR_COPY_FAILED,
202
0
     "%s: unable to copy control panel identifier.",
203
0
     function );
204
205
0
    return( -1 );
206
0
  }
207
#if defined( HAVE_DEBUG_OUTPUT )
208
  if( libcnotify_verbose != 0 )
209
  {
210
    libcnotify_printf(
211
     "%s: unknown1\t\t\t: 0x%02" PRIx8 "\n",
212
     function,
213
     data[ 3 ] );
214
215
    libcnotify_printf(
216
     "%s: unknown2:\n",
217
     function );
218
    libcnotify_print_data(
219
     &( data[ 4 ] ),
220
     10,
221
     0 );
222
223
    if( libfwsi_debug_print_guid_value(
224
         function,
225
         "control panel identifier\t",
226
         control_panel_item_values->identifier,
227
         16,
228
         LIBFGUID_ENDIAN_LITTLE,
229
         LIBFGUID_STRING_FORMAT_FLAG_USE_UPPER_CASE | LIBFGUID_STRING_FORMAT_FLAG_USE_SURROUNDING_BRACES,
230
         error ) != 1 )
231
    {
232
      libcerror_error_set(
233
       error,
234
       LIBCERROR_ERROR_DOMAIN_RUNTIME,
235
       LIBCERROR_RUNTIME_ERROR_PRINT_FAILED,
236
       "%s: unable to print GUID value.",
237
       function );
238
239
      return( -1 );
240
    }
241
    libcnotify_printf(
242
     "%s: control panel name\t\t: %s\n",
243
     function,
244
     libfwsi_control_panel_identifier_get_name(
245
      control_panel_item_values->identifier ) );
246
247
    libcnotify_printf(
248
     "\n" );
249
  }
250
#endif /* defined( HAVE_DEBUG_OUTPUT ) */
251
252
0
  return( 1 );
253
0
}
254
255
/* Retrieves the identifier
256
 * The identifier is a GUID and is 16 bytes of size
257
 * Returns 1 if successful or -1 on error
258
 */
259
int libfwsi_control_panel_item_values_get_identifier(
260
     libfwsi_control_panel_item_values_t *control_panel_item_values,
261
     uint8_t *guid_data,
262
     size_t guid_data_size,
263
     libcerror_error_t **error )
264
0
{
265
0
  static char *function = "libfwsi_control_panel_item_values_get_identifier";
266
267
0
  if( control_panel_item_values == NULL )
268
0
  {
269
0
    libcerror_error_set(
270
0
     error,
271
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
272
0
     LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE,
273
0
     "%s: invalid control panel item values.",
274
0
     function );
275
276
0
    return( -1 );
277
0
  }
278
0
  if( guid_data == NULL )
279
0
  {
280
0
    libcerror_error_set(
281
0
     error,
282
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
283
0
     LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE,
284
0
     "%s: invalid GUID data.",
285
0
     function );
286
287
0
    return( -1 );
288
0
  }
289
0
  if( guid_data_size < 16 )
290
0
  {
291
0
    libcerror_error_set(
292
0
     error,
293
0
     LIBCERROR_ERROR_DOMAIN_ARGUMENTS,
294
0
     LIBCERROR_ARGUMENT_ERROR_VALUE_TOO_SMALL,
295
0
     "%s: GUID data size too small.",
296
0
     function );
297
298
0
    return( -1 );
299
0
  }
300
0
  if( memory_copy(
301
0
       guid_data,
302
0
       control_panel_item_values->identifier,
303
0
       16 ) == NULL )
304
0
  {
305
0
    libcerror_error_set(
306
0
     error,
307
0
     LIBCERROR_ERROR_DOMAIN_MEMORY,
308
0
     LIBCERROR_MEMORY_ERROR_COPY_FAILED,
309
0
     "%s: unable to copy identifier.",
310
0
     function );
311
312
0
    return( -1 );
313
0
  }
314
0
  return( 1 );
315
0
}
316