source: trunk/include/regfi.h @ 79

Last change on this file since 79 was 79, checked in by tim, 17 years ago

renamed regfio to regfi, since we aren't doing any output to the registry.

  • Property svn:keywords set to Id
File size: 8.6 KB
RevLine 
[30]1/*
2 * Branched from Samba project, Subversion repository version #6903:
3 *   http://websvn.samba.org/cgi-bin/viewcvs.cgi/trunk/source/include/regfio.h
4 *
5 * Unix SMB/CIFS implementation.
6 * Windows NT registry I/O library
7 *
[61]8 * Copyright (C) 2005-2006 Timothy D. Morgan
[30]9 * Copyright (C) 2005 Gerald (Jerry) Carter
10 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; version 2 of the License.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 *
24 * $Id: regfi.h 79 2007-01-15 15:24:53Z tim $
25 */
26
27/************************************************************
28 * Most of this information was obtained from
29 * http://www.wednesday.demon.co.uk/dosreg.html
30 * Thanks Nigel!
31 ***********************************************************/
32
[78]33#ifndef _REGFI_H
34#define _REGFI_H
[30]35
[31]36#include <stdlib.h>
37#include <stdio.h>
[30]38#include <stdbool.h>
[31]39#include <string.h>
[30]40#include <errno.h>
[31]41#include <time.h>
[30]42#include <fcntl.h>
43#include <sys/stat.h>
44#include <sys/types.h>
45#include <unistd.h>
46#include <assert.h>
47
48#include "smb_deps.h"
[78]49#include "void_stack.h"
[30]50
51/******************************************************************************/
52/* Macros */
53 
[32]54/* Registry data types */
55#define REG_NONE                       0
56#define REG_SZ                         1
57#define REG_EXPAND_SZ                  2
58#define REG_BINARY                     3
59#define REG_DWORD                      4
[54]60#define REG_DWORD_LE                   4  /* DWORD, little endian */
61#define REG_DWORD_BE                   5  /* DWORD, big endian */
[32]62#define REG_LINK                       6
63#define REG_MULTI_SZ                   7
64#define REG_RESOURCE_LIST              8
65#define REG_FULL_RESOURCE_DESCRIPTOR   9
66#define REG_RESOURCE_REQUIREMENTS_LIST 10
[72]67#define REG_QWORD                      11 /* 64-bit little endian */
68/* XXX: Has MS defined a REG_QWORD_BE? */
[32]69/* Not a real type in the registry */
70#define REG_KEY                        255
71
72
[30]73#define REGF_BLOCKSIZE          0x1000
74#define REGF_ALLOC_BLOCK        0x1000
[78]75#define REGF_MAX_DEPTH          512
[30]76
77/* header sizes for various records */
78
79#define REGF_HDR_SIZE           4
80#define HBIN_HDR_SIZE           4
81#define HBIN_HEADER_REC_SIZE    0x24
82#define REC_HDR_SIZE            2
83
84#define REGF_OFFSET_NONE        0xffffffff
85
86/* Flags for the vk records */
87
88#define VK_FLAG_NAME_PRESENT    0x0001
89#define VK_DATA_IN_OFFSET       0x80000000
[77]90#define VK_MAX_DATA_LENGTH      1024*1024
[30]91
92/* NK record macros */
93
94#define NK_TYPE_LINKKEY         0x0010
95#define NK_TYPE_NORMALKEY       0x0020
96#define NK_TYPE_ROOTKEY         0x002c
97
[54]98#define HBIN_STORE_REF(x, y) { x->hbin = y; y->ref_count++ };
99/* if the count == 0; we can clean up */
100#define HBIN_REMOVE_REF(x, y){ x->hbin = NULL; y->ref_count-- };
[30]101
102
103/* HBIN block */
104struct regf_hbin;
105typedef struct regf_hbin {
[53]106  struct regf_hbin* prev;
107  struct regf_hbin* next;
108  uint32 file_off;       /* my offset in the registry file */
109  uint32 free_off;       /* offset to free space within the hbin record */
110  uint32 free_size;      /* amount of data left in the block */
[54]111  int    ref_count;      /* how many active records are pointing to this
112                          * block (not used currently)
113                          */
[30]114       
[53]115  uint8  header[HBIN_HDR_SIZE]; /* "hbin" */
116  uint32 first_hbin_off; /* offset from first hbin block */
[54]117  uint32 block_size;     /* block size of this block is
118                          * usually a multiple of 4096Kb
119                          */
120  prs_struct ps;         /* data */
[53]121  bool dirty;            /* has this hbin block been modified? */
[30]122} REGF_HBIN;
123
124/* ??? List -- list of key offsets and hashed names for consistency */
125typedef struct {
[53]126  uint32 nk_off;
127  uint8 keycheck[sizeof(uint32)];
[30]128} REGF_HASH_REC;
129
130typedef struct {
[54]131  REGF_HBIN *hbin;       /* pointer to HBIN record (in memory) containing
132                          * this nk record
133                          */
134  uint32 hbin_off;       /* offset from beginning of this hbin block */
135  uint32 rec_size;       /* ((start_offset - end_offset) & 0xfffffff8) */
[53]136 
137  uint8 header[REC_HDR_SIZE];
138  uint16 num_keys;
139  REGF_HASH_REC *hashes;
[30]140} REGF_LF_REC;
141
142/* Key Value */
143
144typedef struct {
[54]145  REGF_HBIN *hbin;      /* pointer to HBIN record (in memory) containing
146                         * this nk record
147                         */
[53]148  uint32 hbin_off;      /* offset from beginning of this hbin block */
149  uint32 rec_size;      /* ((start_offset - end_offset) & 0xfffffff8) */
[54]150  uint32 rec_off;       /* offset stored in the value list */
[53]151 
152  uint8  header[REC_HDR_SIZE];
153  char*  valuename;
154  uint32 data_size;
155  uint32 data_off;
156  uint8* data;
157  uint32 type;
158  uint16 flag;
[30]159} REGF_VK_REC;
160
161
162/* Key Security */
163struct _regf_sk_rec;
164
165typedef struct _regf_sk_rec {
[53]166  struct _regf_sk_rec *next, *prev;
[54]167  REGF_HBIN *hbin;      /* pointer to HBIN record (in memory) containing
168                         * this nk record
169                         */
[53]170  uint32 hbin_off;      /* offset from beginning of this hbin block */
171  uint32 rec_size;      /* ((start_offset - end_offset) & 0xfffffff8) */
172 
[54]173  uint32 sk_off;        /* offset parsed from NK record used as a key
174                         * to lookup reference to this SK record
175                         */
[53]176 
177  uint8  header[REC_HDR_SIZE];
178  uint32 prev_sk_off;
179  uint32 next_sk_off;
180  uint32 ref_count;
181  uint32 size;
182  SEC_DESC *sec_desc;
[30]183} REGF_SK_REC;
184
185/* Key Name */ 
186
187typedef struct {
[54]188  REGF_HBIN *hbin;      /* pointer to HBIN record (in memory) containing
189                         * this nk record
190                         */
[53]191  uint32 hbin_off;      /* offset from beginning of this hbin block */
[78]192  /*uint32 subkey_index;*/      /* index to next subkey record to return */
[53]193  uint32 rec_size;      /* ((start_offset - end_offset) & 0xfffffff8) */
194 
195  /* header information */
196  uint8  header[REC_HDR_SIZE];
197  uint16 key_type;
198  NTTIME mtime;
199  uint32 parent_off;    /* back pointer in registry hive */
200  uint32 classname_off; 
201  char *classname;
202  char *keyname;
203 
204  /* max lengths */
[54]205  uint32 max_bytes_subkeyname;      /* max subkey name * 2 */
206  uint32 max_bytes_subkeyclassname; /* max subkey classname length (as if) */
207  uint32 max_bytes_valuename;       /* max valuename * 2 */
208  uint32 max_bytes_value;           /* max value data size */
[53]209 
210  /* unknowns */
[54]211  uint32 unk_index;                 /* nigel says run time index ? */
[53]212 
213  /* children */
214  uint32 num_subkeys;
215  uint32 subkeys_off;   /* hash records that point to NK records */     
216  uint32 num_values;
217  uint32 values_off;    /* value lists which point to VK records */
[54]218  uint32 sk_off;        /* offset to SK record */
[53]219 
220  /* link in the other records here */
221  REGF_LF_REC subkeys;
222  REGF_VK_REC *values;
223  REGF_SK_REC *sec_desc;
[30]224       
225} REGF_NK_REC;
226
227/* REGF block */
228 
229typedef struct {
[53]230  /* run time information */
[54]231  int fd;         /* file descriptor */
232  int open_flags; /* flags passed to the open() call */
233  void *mem_ctx;  /* memory context for run-time file access information */
234  REGF_HBIN *block_list; /* list of open hbin blocks */
[53]235 
236  /* file format information */
237 
238  uint8  header[REGF_HDR_SIZE]; /* "regf" */
[54]239  uint32 data_offset;           /* offset to record in the first (or any?)
240                                 * hbin block
241                                 */
[53]242  uint32 last_block;            /* offset to last hbin block in file */
243  uint32 checksum;              /* XOR of bytes 0x0000 - 0x01FB */
244  NTTIME mtime;
245 
[54]246  REGF_SK_REC *sec_desc_list;   /* list of security descriptors referenced
247                                 * by NK records
248                                 */
[53]249 
[78]250  /* unknowns */
[53]251  uint32 unknown1;
252  uint32 unknown2;
253  uint32 unknown3;
254  uint32 unknown4;
255  uint32 unknown5;
256  uint32 unknown6;
257} REGF_FILE;
[30]258
259
[78]260
261typedef struct {
262  REGF_FILE* f;
263  void_stack* keys;
264  uint32 cur_subkey;
265  uint32 cur_value;
266} REGFI_ITERATOR;
267
[54]268/******************************************************************************/
[30]269/* Function Declarations */
[54]270
[78]271const char*   regfi_type_val2str(unsigned int val);
272int           regfi_type_str2val(const char* str);
[32]273
[78]274char*         regfi_get_sacl(SEC_DESC *sec_desc);
275char*         regfi_get_dacl(SEC_DESC *sec_desc);
276char*         regfi_get_owner(SEC_DESC *sec_desc);
277char*         regfi_get_group(SEC_DESC *sec_desc);
[53]278
[78]279REGF_FILE*    regfi_open( const char *filename );
280int           regfi_close( REGF_FILE *r );
[30]281
[78]282REGF_NK_REC*  regfi_rootkey( REGF_FILE *file );
283/* REGF_NK_REC*  regfi_fetch_subkey( REGF_FILE *file, REGF_NK_REC *nk ); */
[30]284
[78]285REGFI_ITERATOR* regfi_iterator_create(REGF_FILE* fh);
286bool            regfi_iterator_down(REGFI_ITERATOR* i, const char* subkey_name);
287bool            regfi_iterator_up(REGFI_ITERATOR* i);
288REGF_NK_REC*    regfi_iterator_next_subkey(REGFI_ITERATOR* i);
289REGF_VK_REC*    regfi_iterator_next_value(REGFI_ITERATOR* i);
290REGF_VK_REC*    regfi_iterator_fetch_value(REGFI_ITERATOR* i, const char* value_name);
291char*           regfi_iterator_curpath(REGFI_ITERATOR* i);
292
293#endif  /* _REGFI_H */
Note: See TracBrowser for help on using the repository browser.