/*++ 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; HNETWORK Network; HNETINTERFACE NetInterface; 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, "GetClusterGroupKey returned error %d\n",GetLastError()); break; } CloseClusterGroup(Group); DumpKeyWorker(ClusterRoot, 4); break; case CLUSTER_ENUM_NETWORK: printf("NETWORK %ws\n",NameBuf); Network = OpenClusterNetwork(Cluster, NameBuf); if (Network == NULL) { fprintf(stderr, "OpenClusterNetwork returned error %d\n",GetLastError()); break; } ClusterRoot = GetClusterNetworkKey(Network, KEY_READ); if (ClusterRoot == NULL) { fprintf(stderr, "GetClusterNetworkKey returned error %d\n",GetLastError()); break; } CloseClusterNetwork(Network); DumpKeyWorker(ClusterRoot, 4); break; case CLUSTER_ENUM_NETINTERFACE: printf("NETINTERFACE %ws\n",NameBuf); NetInterface = OpenClusterNetInterface(Cluster, NameBuf); if (NetInterface == NULL) { fprintf(stderr, "OpenClusterNetInterface returned error %d\n",GetLastError()); break; } ClusterRoot = GetClusterNetInterfaceKey(NetInterface, KEY_READ); if (ClusterRoot == NULL) { fprintf(stderr, "GetClusterNetInterfaceKey returned error %d\n",GetLastError()); break; } CloseClusterNetInterface(NetInterface); 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 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