1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
|
/*
* Windows NT Security Identifier (SID) functions
*
* Copyright (C) 2009-2020, Joachim Metz <joachim.metz@gmail.com>
*
* Refer to AUTHORS for acknowledgements.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* 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 Lesser General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
#if !defined( _LIBFWNT_INTERNAL_SECURITY_IDENTIFIER_H )
#define _LIBFWNT_INTERNAL_SECURITY_IDENTIFIER_H
#include <common.h>
#include <types.h>
#include "libfwnt_extern.h"
#include "libfwnt_libcerror.h"
#include "libfwnt_types.h"
#if defined( __cplusplus )
extern "C" {
#endif
/* The Windows NT Security Identifier (SID) is formatted as following:
* S-1-5-21-7623811015-3361044348-030300820-1013
*
* S - The string is a SID.
* 1 - The revision number (the version of the SID specification).
* 5 - The identifier authority value.
* 21-7623811015-3361044348-030300820 - domain or local computer identifier
* 1013 – a Relative ID (RID). Any group or user that is not created by default will have a Relative ID of 1000 or greater.
*
* The SID is stored as
* 01 - 05 - 00 00 00 00 00 05 - aa aa aa aa - bb bb bb bb - cc cc cc cc - dd dd dd dd - ee ee ee ee
* uint8_t - uint8_t - uint48_t - uint32_t - uin32_t - uin32_t - uin32_t - uin32_t
* - (big endian) - (little endian)
* revision - number - authority - sub authorities
*
* The second value contains the number of sub authorities in the SID
*
* The maximum number of sub authorities seems to be 15.
*/
typedef struct libfwnt_internal_security_identifier libfwnt_internal_security_identifier_t;
struct libfwnt_internal_security_identifier
{
/* The revision number
*/
uint8_t revision_number;
/* The authority value
*/
uint64_t authority;
/* The number of sub authoritties
*/
uint8_t number_of_sub_authorities;
/* The sub autoritites
*/
uint32_t sub_authority[ 15 ];
/* Value to indicate if the identifier is managed by the descriptor
*/
uint8_t is_managed;
};
LIBFWNT_EXTERN \
int libfwnt_security_identifier_initialize(
libfwnt_security_identifier_t **security_identifier,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_free(
libfwnt_security_identifier_t **security_identifier,
libcerror_error_t **error );
int libfwnt_internal_security_identifier_free(
libfwnt_internal_security_identifier_t **internal_security_identifier,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_copy_from_byte_stream(
libfwnt_security_identifier_t *security_identifier,
const uint8_t *byte_stream,
size_t byte_stream_size,
int byte_order,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_get_string_size(
libfwnt_security_identifier_t *security_identifier,
size_t *string_size,
uint32_t string_format_flags,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_copy_to_utf8_string(
libfwnt_security_identifier_t *security_identifier,
uint8_t *utf8_string,
size_t utf8_string_size,
uint32_t string_format_flags,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_copy_to_utf8_string_with_index(
libfwnt_security_identifier_t *security_identifier,
uint8_t *utf8_string,
size_t utf8_string_size,
size_t *utf8_string_index,
uint32_t string_format_flags,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_copy_to_utf16_string(
libfwnt_security_identifier_t *security_identifier,
uint16_t *utf16_string,
size_t utf16_string_size,
uint32_t string_format_flags,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_copy_to_utf16_string_with_index(
libfwnt_security_identifier_t *security_identifier,
uint16_t *utf16_string,
size_t utf16_string_size,
size_t *utf16_string_index,
uint32_t string_format_flags,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_copy_to_utf32_string(
libfwnt_security_identifier_t *security_identifier,
uint32_t *utf32_string,
size_t utf32_string_size,
uint32_t string_format_flags,
libcerror_error_t **error );
LIBFWNT_EXTERN \
int libfwnt_security_identifier_copy_to_utf32_string_with_index(
libfwnt_security_identifier_t *security_identifier,
uint32_t *utf32_string,
size_t utf32_string_size,
size_t *utf32_string_index,
uint32_t string_format_flags,
libcerror_error_t **error );
#if defined( __cplusplus )
}
#endif
#endif /* !defined( _LIBFWNT_INTERNAL_SECURITY_IDENTIFIER_H ) */
|