469 lines
13 KiB
C
469 lines
13 KiB
C
|
/*++
|
|||
|
|
|||
|
Copyright (c) 1996 Microsoft Corporation
|
|||
|
|
|||
|
Module Name:
|
|||
|
|
|||
|
treg.c
|
|||
|
|
|||
|
Abstract:
|
|||
|
|
|||
|
Test for cluster registry API
|
|||
|
|
|||
|
Author:
|
|||
|
|
|||
|
John Vert (jvert) 15-Mar-1996
|
|||
|
|
|||
|
Revision History:
|
|||
|
|
|||
|
--*/
|
|||
|
#include "windows.h"
|
|||
|
#include "cluster.h"
|
|||
|
#include "stdio.h"
|
|||
|
#include "stdlib.h"
|
|||
|
#include "conio.h"
|
|||
|
|
|||
|
#define INDENT_LEVEL 4
|
|||
|
|
|||
|
WCHAR Value1Data[] = L"This is data for value 1";
|
|||
|
WCHAR Value2Data[] = L"This is data for value 2";
|
|||
|
WCHAR Value3Data[] = L"This is data for value 3";
|
|||
|
|
|||
|
VOID
|
|||
|
DumpKeyWorker(
|
|||
|
IN HKEY Key,
|
|||
|
IN DWORD Indent
|
|||
|
);
|
|||
|
|
|||
|
VOID
|
|||
|
DumpValues(
|
|||
|
IN HKEY Key,
|
|||
|
IN DWORD Indent
|
|||
|
);
|
|||
|
|
|||
|
int
|
|||
|
_cdecl
|
|||
|
main (argc, argv)
|
|||
|
int argc;
|
|||
|
char *argv[];
|
|||
|
{
|
|||
|
HCLUSTER Cluster;
|
|||
|
HRESOURCE Resource;
|
|||
|
HGROUP Group;
|
|||
|
HNODE Node;
|
|||
|
HKEY ClusterRoot;
|
|||
|
HKEY TestKey;
|
|||
|
HCLUSENUM ResEnum;
|
|||
|
DWORD ClusterCountBefore, ClusterCountAfter;
|
|||
|
DWORD i;
|
|||
|
DWORD Status;
|
|||
|
WCHAR NameBuf[50];
|
|||
|
DWORD NameLen;
|
|||
|
DWORD Type;
|
|||
|
DWORD Disposition;
|
|||
|
|
|||
|
//
|
|||
|
// Dump out registry structure for current cluster.
|
|||
|
//
|
|||
|
Cluster = OpenCluster(NULL);
|
|||
|
if (Cluster == NULL) {
|
|||
|
fprintf(stderr, "OpenCluster(NULL) failed %d\n",GetLastError());
|
|||
|
return(0);
|
|||
|
}
|
|||
|
|
|||
|
ClusterRoot = GetClusterKey(Cluster, KEY_READ);
|
|||
|
if (ClusterRoot == NULL) {
|
|||
|
fprintf(stderr, "GetClusterKey failed %d\n", GetLastError());
|
|||
|
return(0);
|
|||
|
}
|
|||
|
|
|||
|
printf("CLUSTERROOT\n");
|
|||
|
DumpKeyWorker(ClusterRoot, 4);
|
|||
|
|
|||
|
//
|
|||
|
// Dump by object
|
|||
|
//
|
|||
|
printf("\n\nENUMERATING OBJECTS\n");
|
|||
|
ResEnum = ClusterOpenEnum(Cluster, CLUSTER_ENUM_ALL);
|
|||
|
if (ResEnum == NULL) {
|
|||
|
fprintf(stderr, "ClusterOpenEnum failed %d\n",GetLastError());
|
|||
|
return(0);
|
|||
|
}
|
|||
|
|
|||
|
ClusterCountBefore = ClusterGetEnumCount(ResEnum);
|
|||
|
for(i=0; ; i++) {
|
|||
|
NameLen = sizeof(NameBuf)/sizeof(WCHAR);
|
|||
|
Status = ClusterEnum(ResEnum,
|
|||
|
i,
|
|||
|
&Type,
|
|||
|
NameBuf,
|
|||
|
&NameLen);
|
|||
|
if (Status == ERROR_NO_MORE_ITEMS) {
|
|||
|
break;
|
|||
|
} else if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "ClusterEnum %d returned error %d\n",i,Status);
|
|||
|
return(0);
|
|||
|
}
|
|||
|
switch (Type) {
|
|||
|
case CLUSTER_ENUM_NODE:
|
|||
|
printf("NODE %ws\n",NameBuf);
|
|||
|
break;
|
|||
|
|
|||
|
case CLUSTER_ENUM_RESTYPE:
|
|||
|
printf("RESOURCETYPE %ws\n",NameBuf);
|
|||
|
break;
|
|||
|
|
|||
|
case CLUSTER_ENUM_RESOURCE:
|
|||
|
printf("RESOURCE %ws\n",NameBuf);
|
|||
|
Resource = OpenClusterResource(Cluster, NameBuf);
|
|||
|
if (Resource == NULL) {
|
|||
|
fprintf(stderr, "OpenClusterResource returned error %d\n",GetLastError());
|
|||
|
break;
|
|||
|
}
|
|||
|
ClusterRoot = GetClusterResourceKey(Resource,
|
|||
|
KEY_READ);
|
|||
|
if (ClusterRoot == NULL) {
|
|||
|
fprintf(stderr, "GetClusterResourceKey returned error %d\n",GetLastError());
|
|||
|
break;
|
|||
|
}
|
|||
|
CloseClusterResource(Resource);
|
|||
|
DumpKeyWorker(ClusterRoot, 4);
|
|||
|
break;
|
|||
|
|
|||
|
case CLUSTER_ENUM_GROUP:
|
|||
|
printf("GROUP %ws\n",NameBuf);
|
|||
|
Group = OpenClusterGroup(Cluster, NameBuf);
|
|||
|
if (Group == NULL) {
|
|||
|
fprintf(stderr, "OpenClusterGroup returned error %d\n",GetLastError());
|
|||
|
break;
|
|||
|
}
|
|||
|
ClusterRoot = GetClusterGroupKey(Group,
|
|||
|
KEY_READ);
|
|||
|
if (ClusterRoot == NULL) {
|
|||
|
fprintf(stderr, "GetClusterResourceKey returned error %d\n",GetLastError());
|
|||
|
break;
|
|||
|
}
|
|||
|
CloseClusterGroup(Group);
|
|||
|
DumpKeyWorker(ClusterRoot, 4);
|
|||
|
break;
|
|||
|
|
|||
|
default:
|
|||
|
fprintf(stderr, "ClusterEnum returned unknown type %d\n",Type);
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
if (Status == ERROR_NO_MORE_ITEMS) {
|
|||
|
printf("\nCluster count: %d\n", i);
|
|||
|
ClusterCountAfter = ClusterGetEnumCount(ResEnum);
|
|||
|
if (ClusterCountBefore != ClusterCountAfter)
|
|||
|
fprintf(stderr, "\nReported cluster count was %d before enumeration, and %d afterward\n", ClusterCountBefore, ClusterCountAfter);
|
|||
|
else if (i != ClusterCountBefore)
|
|||
|
fprintf(stderr, "\nReported cluster count: %d\n", ClusterCountBefore);
|
|||
|
}
|
|||
|
ClusterCloseEnum(ResEnum);
|
|||
|
|
|||
|
//
|
|||
|
// Test the create/delete apis
|
|||
|
//
|
|||
|
printf("\nTesting Creation APIs\n");
|
|||
|
ClusterRoot = GetClusterKey(Cluster, KEY_READ | KEY_WRITE);
|
|||
|
|
|||
|
if (ClusterRoot == NULL) {
|
|||
|
fprintf(stderr, "GetClusterKey failed %d\n", GetLastError());
|
|||
|
return(0);
|
|||
|
}
|
|||
|
Status = ClusterRegCreateKey(ClusterRoot,
|
|||
|
L"TestKey",
|
|||
|
0,
|
|||
|
KEY_READ | KEY_WRITE,
|
|||
|
NULL,
|
|||
|
&TestKey,
|
|||
|
&Disposition);
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "ClusterRegCreateKey failed %d\n", Status);
|
|||
|
return(0);
|
|||
|
}
|
|||
|
if (Disposition == REG_CREATED_NEW_KEY) {
|
|||
|
printf("TestKey successfully created\n");
|
|||
|
} else if (Disposition == REG_OPENED_EXISTING_KEY) {
|
|||
|
printf("TestKey successfully opened\n");
|
|||
|
} else {
|
|||
|
fprintf(stderr,"CreateKey of TestKey returned unknown Disposition %d\n", Disposition);
|
|||
|
}
|
|||
|
|
|||
|
Status = ClusterRegSetValue(TestKey,
|
|||
|
L"Value1",
|
|||
|
REG_SZ,
|
|||
|
(CONST BYTE*)Value1Data,
|
|||
|
(lstrlenW(Value1Data)+1)*sizeof(WCHAR));
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "SetValue for Value1 failed %d\n", Status);
|
|||
|
}
|
|||
|
|
|||
|
Status = ClusterRegSetValue(TestKey,
|
|||
|
L"Value2",
|
|||
|
REG_SZ,
|
|||
|
(CONST BYTE*)Value2Data,
|
|||
|
(lstrlenW(Value2Data)+1)*sizeof(WCHAR));
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "SetValue for Value2 failed %d\n", Status);
|
|||
|
}
|
|||
|
|
|||
|
Status = ClusterRegSetValue(TestKey,
|
|||
|
L"Value3",
|
|||
|
REG_SZ,
|
|||
|
(CONST BYTE*)Value3Data,
|
|||
|
(lstrlenW(Value3Data)+1)*sizeof(WCHAR));
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "SetValue for Value3 failed %d\n", Status);
|
|||
|
}
|
|||
|
|
|||
|
printf("Press a key to delete values\n");
|
|||
|
_getch();
|
|||
|
printf("Deleting values...\n");
|
|||
|
Status = ClusterRegDeleteValue(TestKey, L"Value1");
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DeleteValue for Value1 failed %d\n", Status);
|
|||
|
}
|
|||
|
Status = ClusterRegDeleteValue(TestKey, L"Value2");
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DeleteValue for Value2 failed %d\n", Status);
|
|||
|
}
|
|||
|
Status = ClusterRegDeleteValue(TestKey, L"Value3");
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DeleteValue for Value3 failed %d\n", Status);
|
|||
|
}
|
|||
|
|
|||
|
printf("Press a key to delete TestKey\n");
|
|||
|
_getch();
|
|||
|
printf("Deleting TestKey");
|
|||
|
ClusterRegCloseKey(TestKey);
|
|||
|
Status = ClusterRegDeleteKey(ClusterRoot, L"TestKey");
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DeleteKey failed %d\n", Status);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
ClusterRegCloseKey(ClusterRoot);
|
|||
|
|
|||
|
|
|||
|
CloseCluster(Cluster);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
VOID
|
|||
|
DumpKeyWorker(
|
|||
|
IN HKEY Key,
|
|||
|
IN DWORD Indent
|
|||
|
)
|
|||
|
|
|||
|
/*++
|
|||
|
|
|||
|
Routine Description:
|
|||
|
|
|||
|
Recursively dumps out the specified cluster registry key
|
|||
|
|
|||
|
Arguments:
|
|||
|
|
|||
|
Key - Supplies the root of the subtree to dump
|
|||
|
|
|||
|
Indent - Supplies the current indent level
|
|||
|
|
|||
|
Return Value:
|
|||
|
|
|||
|
None.
|
|||
|
|
|||
|
--*/
|
|||
|
|
|||
|
{
|
|||
|
DWORD i;
|
|||
|
DWORD j;
|
|||
|
HKEY Subkey;
|
|||
|
DWORD CurrentLength=80;
|
|||
|
DWORD Length;
|
|||
|
LPWSTR Buffer;
|
|||
|
FILETIME FileTime;
|
|||
|
LONG Status;
|
|||
|
|
|||
|
//
|
|||
|
// Enumerate our values
|
|||
|
//
|
|||
|
DumpValues(Key, Indent);
|
|||
|
|
|||
|
//
|
|||
|
// Enumerate the subkeys and dump each one.
|
|||
|
//
|
|||
|
Buffer = malloc(CurrentLength*sizeof(WCHAR));
|
|||
|
if (Buffer == NULL) {
|
|||
|
fprintf(stderr, "DumpKeyWorker: out of memory\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
for (i=0; ; i++) {
|
|||
|
retry:
|
|||
|
Length = CurrentLength;
|
|||
|
Status = ClusterRegEnumKey(Key,
|
|||
|
i,
|
|||
|
Buffer,
|
|||
|
&Length,
|
|||
|
&FileTime);
|
|||
|
if (Status == ERROR_MORE_DATA) {
|
|||
|
CurrentLength = Length+1;
|
|||
|
free(Buffer);
|
|||
|
Buffer = malloc(CurrentLength*sizeof(WCHAR));
|
|||
|
if (Buffer == NULL) {
|
|||
|
fprintf(stderr, "DumpKeyWorker: out of memory\n");
|
|||
|
}
|
|||
|
goto retry;
|
|||
|
} else if (Status == ERROR_NO_MORE_ITEMS) {
|
|||
|
break;
|
|||
|
} else if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DumpKeyWorker, ClusterRegEnumKey returned %d\n",Status);
|
|||
|
return;
|
|||
|
}
|
|||
|
//
|
|||
|
// print out name
|
|||
|
//
|
|||
|
for (j=0;j<Indent;j++) {
|
|||
|
printf(" ");
|
|||
|
}
|
|||
|
printf("%ws\n",Buffer);
|
|||
|
|
|||
|
//
|
|||
|
// Open the key and call ourself recursively
|
|||
|
//
|
|||
|
Status = ClusterRegOpenKey(Key,
|
|||
|
Buffer,
|
|||
|
KEY_READ,
|
|||
|
&Subkey);
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DumpKeyWorker, ClusterRegOpenKey returned %d\n",Status);
|
|||
|
return;
|
|||
|
}
|
|||
|
DumpKeyWorker(Subkey, Indent+INDENT_LEVEL);
|
|||
|
Status = ClusterRegCloseKey(Subkey);
|
|||
|
if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DumpKeyWorker, ClusterRegCloseKey returned %d\n",Status);
|
|||
|
}
|
|||
|
}
|
|||
|
free(Buffer);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
VOID
|
|||
|
DumpValues(
|
|||
|
IN HKEY Key,
|
|||
|
IN DWORD Indent
|
|||
|
)
|
|||
|
|
|||
|
/*++
|
|||
|
|
|||
|
Routine Description:
|
|||
|
|
|||
|
Dumps the values of the specified key.
|
|||
|
|
|||
|
Arguments:
|
|||
|
|
|||
|
Key - Supplies the key to dump.
|
|||
|
|
|||
|
Indent - Supplies the indentation level to use.
|
|||
|
|
|||
|
Return Value:
|
|||
|
|
|||
|
None.
|
|||
|
|
|||
|
--*/
|
|||
|
|
|||
|
{
|
|||
|
DWORD i;
|
|||
|
DWORD j;
|
|||
|
HKEY Subkey;
|
|||
|
DWORD CurrentNameLength=80;
|
|||
|
DWORD NameLength;
|
|||
|
LPWSTR Name;
|
|||
|
DWORD CurrentDataLength=80;
|
|||
|
DWORD DataLength;
|
|||
|
PUCHAR Data ;
|
|||
|
LONG Status;
|
|||
|
DWORD Type;
|
|||
|
|
|||
|
//
|
|||
|
// Enumerate the values and dump each one.
|
|||
|
//
|
|||
|
Name = malloc(CurrentNameLength*sizeof(WCHAR));
|
|||
|
if (Name==NULL) {
|
|||
|
fprintf(stderr, "DumpValues: out of memory\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
Data = malloc(CurrentDataLength);
|
|||
|
if (Name==NULL) {
|
|||
|
fprintf(stderr, "DumpValues: out of memory\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
for (i=0; ;i++) {
|
|||
|
retry:
|
|||
|
NameLength = CurrentNameLength;
|
|||
|
DataLength = CurrentDataLength;
|
|||
|
Status = ClusterRegEnumValue(Key,
|
|||
|
i,
|
|||
|
Name,
|
|||
|
&NameLength,
|
|||
|
&Type,
|
|||
|
Data,
|
|||
|
&DataLength);
|
|||
|
if (Status == ERROR_MORE_DATA) {
|
|||
|
if (NameLength+1 > CurrentNameLength) {
|
|||
|
CurrentNameLength = NameLength+1;
|
|||
|
free(Name);
|
|||
|
Name = malloc(CurrentNameLength);
|
|||
|
if (Name == NULL) {
|
|||
|
fprintf(stderr, "DumpValues: out of memory\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
if (DataLength > CurrentDataLength) {
|
|||
|
CurrentDataLength = DataLength;
|
|||
|
free(Data);
|
|||
|
Data = malloc(CurrentDataLength);
|
|||
|
if (Data == NULL) {
|
|||
|
fprintf(stderr, "DumpValues: out of memory\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
goto retry;
|
|||
|
} else if (Status == ERROR_NO_MORE_ITEMS) {
|
|||
|
return;
|
|||
|
} else if (Status != ERROR_SUCCESS) {
|
|||
|
fprintf(stderr, "DumpValues: out of memory\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
//
|
|||
|
// print out value
|
|||
|
//
|
|||
|
for (j=0;j<Indent;j++) {
|
|||
|
printf(" ");
|
|||
|
}
|
|||
|
printf("%ws = ",Name);
|
|||
|
switch (Type) {
|
|||
|
case REG_SZ:
|
|||
|
printf("REG_SZ %ws\n",Data);
|
|||
|
break;
|
|||
|
case REG_DWORD:
|
|||
|
printf("REG_DWORD 0x%08lx\n",Data);
|
|||
|
break;
|
|||
|
case REG_BINARY:
|
|||
|
printf("REG_BINARY 0x%08lx\n",Data);
|
|||
|
break;
|
|||
|
default:
|
|||
|
printf("UNKNOWN TYPE %d\n",Type);
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
free(Name);
|
|||
|
free(Data);
|
|||
|
|
|||
|
}
|