1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-04 05:18:06 +03:00
samba-mirror/source4/lib/registry
Jelmer Vernooij d64ccc0176 r14599: Pass ACLs down the registry layer.
(This used to be commit 6cdefd8945)
2007-10-10 13:58:59 -05:00
..
common r14599: Pass ACLs down the registry layer. 2007-10-10 13:58:59 -05:00
man r12209: Fix some issues with XML entities. 2007-10-10 13:47:18 -05:00
tools r14599: Pass ACLs down the registry layer. 2007-10-10 13:58:59 -05:00
config.m4 r11382: Require number of required M4 macros 2007-10-10 13:45:29 -05:00
config.mk r14572: Give libraries saner names, remove some .pc files, make some things 2007-10-10 13:58:49 -05:00
Doxyfile r14108: Make the Doxyfiles a bit shorter... 2007-10-10 13:56:51 -05:00
patchfile.c r13855: Docs for the registry library as well 2007-10-10 13:52:16 -05:00
README r9381: Line wrapping. 2007-10-10 13:33:30 -05:00
reg_backend_dir.c r10207: Add some const 2007-10-10 13:38:08 -05:00
reg_backend_gconf.c r5303: fixed build of gconf registry backend 2007-10-10 13:09:39 -05:00
reg_backend_ldb.c r14599: Pass ACLs down the registry layer. 2007-10-10 13:58:59 -05:00
reg_backend_nt4.c r14554: Write out header dependencies. This means all C files affected will be 2007-10-10 13:58:45 -05:00
reg_backend_rpc.c r14599: Pass ACLs down the registry layer. 2007-10-10 13:58:59 -05:00
reg_backend_w95.c r10207: Add some const 2007-10-10 13:38:08 -05:00
reg_backend_wine.c r4132: - Bunch of rather large fixes in the registry 2007-10-10 13:06:29 -05:00
reg_samba.c r14599: Pass ACLs down the registry layer. 2007-10-10 13:58:59 -05:00
regf.idl r14599: Pass ACLs down the registry layer. 2007-10-10 13:58:59 -05:00
registry.h r14599: Pass ACLs down the registry layer. 2007-10-10 13:58:59 -05:00
TODO r10604: Put in the new registry "patchfile" code (similar to ldif 2007-10-10 13:39:11 -05:00

This is the registry library. The registry is basically a bunch of
hives that can be loaded from different places.

The various registry backends provide support for loading/saving
specific types of hives:

 - ldb 
 - w95 (USER.DAT-style files)
 - nt4 (NTUSER.DAT-style files)
 - gconf (GNOME configuration)
 - rpc (Remote individual hives)

Instead of opening individual hives, one can also open a 'complete'
registry by using one of these three functions:
 
 - reg_open_local() - load local registry, see below
 - reg_open_remote() - connect to remote registry over RPC
 - reg_open_wine() (not working yet)

reg_open_local() loads a set of hives based on smb.conf settings.
Lines in smb.conf should have the following syntax:

registry:<hivename> = <backend>:<location>

So an example usage could be:

registry:HKEY_CURRENT_USER = nt4:NTUSER.DAT
registry:HKEY_LOCAL_MACHINE = ldb:tdb://registry.tdb

WERR_NOT_SUPPORTED will be returned for all hives that haven't been set.

On Windows the various registry hives are loaded from:

HKEY_CURRENT_CONFIG: %SystemRoot%\System32\Config\System
HKEY_CURRENT_USER: %Profile%\NTUser.dat
HKEY_LOCAL_MACHINE\SAM: %SystemRoot%\System32\Config\Sam
HKEY_LOCAL_MACHINE\Security: %SystemRoot%\System32\Config\Security
HKEY_LOCAL_MACHINE\Software: %SystemRoot%\System32\Config\Software
HKEY_LOCAL_MACHINE\System: %SystemRoot%\System32\Config\System
HKEY_USERS\.DEFAULT: %SystemRoot%\System32\Config\Default
HKEY_LOCAL_MACHINE\HARDWARE: is autogenerated