394 lines
18 KiB
C
394 lines
18 KiB
C
/*******************************************************************************
|
|
*
|
|
* Copyright 1999 American Power Conversion, All Rights Reserved
|
|
*
|
|
* TITLE: UPSREG.H
|
|
*
|
|
* VERSION: 1.0
|
|
*
|
|
* AUTHOR: SteveT
|
|
*
|
|
* DATE: 07 June, 1999
|
|
*
|
|
********************************************************************************/
|
|
|
|
// This file contains declarations that support accessing
|
|
// registry data passed between the UPS service and the
|
|
// UPS UI.
|
|
|
|
|
|
#ifndef _UPSREG_H_
|
|
#define _UPSREG_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
LONG getStringValue(struct _reg_entry *aRegEntry, LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG getDwordValue(struct _reg_entry *aRegEntry, LPDWORD aValue);
|
|
|
|
/*
|
|
* Public Config function declarations
|
|
*/
|
|
LONG GetUPSConfigVendor(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigModel(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigPort(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigOptions( LPDWORD aValue);
|
|
LONG GetUPSConfigShutdownWait( LPDWORD aValue);
|
|
LONG GetUPSConfigFirstMessageDelay( LPDWORD aValue);
|
|
LONG GetUPSConfigMessageInterval( LPDWORD aValue);
|
|
LONG GetUPSConfigServiceDLL(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigNotifyEnable( LPDWORD aValue);
|
|
LONG GetUPSConfigShutdownOnBatteryEnable( LPDWORD aValue);
|
|
LONG GetUPSConfigShutdownOnBatteryWait( LPDWORD aValue);
|
|
LONG GetUPSConfigRunTaskEnable( LPDWORD aValue);
|
|
LONG GetUPSConfigTaskName(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigTurnOffEnable( LPDWORD aValue);
|
|
LONG GetUPSConfigAPCLinkURL(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigUpgrade( LPDWORD aValue);
|
|
LONG GetUPSConfigCustomOptions( LPDWORD aValue);
|
|
LONG GetUPSConfigCriticalPowerAction( LPDWORD aValue);
|
|
LONG GetUPSConfigTurnOffWait( LPDWORD aValue);
|
|
LONG GetUPSConfigImagePath(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigObjectName(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSConfigShowUPSTab( LPDWORD aValue);
|
|
LONG GetUPSConfigErrorControl( LPDWORD aValue);
|
|
LONG GetUPSConfigStart( LPDWORD aValue);
|
|
LONG GetUPSConfigType( LPDWORD aValue);
|
|
|
|
LONG SetUPSConfigVendor( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigModel( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigPort( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigOptions( DWORD aValue);
|
|
LONG SetUPSConfigShutdownWait( DWORD aValue);
|
|
LONG SetUPSConfigFirstMessageDelay( DWORD aValue);
|
|
LONG SetUPSConfigMessageInterval( DWORD aValue);
|
|
LONG SetUPSConfigServiceDLL( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigNotifyEnable( DWORD aValue);
|
|
LONG SetUPSConfigShutdownOnBatteryEnable( DWORD aValue);
|
|
LONG SetUPSConfigShutdownOnBatteryWait( DWORD aValue);
|
|
LONG SetUPSConfigRunTaskEnable( DWORD aValue);
|
|
LONG SetUPSConfigTaskName( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigTurnOffEnable( DWORD aValue);
|
|
LONG SetUPSConfigAPCLinkURL( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigUpgrade( DWORD aValue);
|
|
LONG SetUPSConfigCustomOptions( DWORD aValue);
|
|
LONG SetUPSConfigCriticalPowerAction( DWORD aValue);
|
|
LONG SetUPSConfigTurnOffWait( DWORD aValue);
|
|
LONG SetUPSConfigImagePath( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigObjectName( LPCTSTR aBuffer);
|
|
LONG SetUPSConfigShowUPSTab( DWORD aValue);
|
|
LONG SetUPSConfigErrorControl( DWORD aValue);
|
|
LONG SetUPSConfigStart( DWORD aValue);
|
|
LONG SetUPSConfigType( DWORD aValue);
|
|
|
|
/*
|
|
* Public Status function declarations
|
|
*/
|
|
LONG GetUPSStatusSerialNum(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSStatusFirmRev(LPTSTR aBuffer, size_t aBufferLen);
|
|
LONG GetUPSStatusUtilityStatus( LPDWORD aValue);
|
|
LONG GetUPSStatusRuntime( LPDWORD aValue);
|
|
LONG GetUPSStatusBatteryStatus( LPDWORD aValue);
|
|
LONG GetUPSStatusCommStatus( LPDWORD aValue);
|
|
LONG GetUPSStatusBatteryCapacity( LPDWORD aValue);
|
|
|
|
LONG SetUPSStatusSerialNum( LPCTSTR aBuffer);
|
|
LONG SetUPSStatusFirmRev( LPCTSTR aBuffer);
|
|
LONG SetUPSStatusUtilityStatus( DWORD aValue);
|
|
LONG SetUPSStatusRuntime( DWORD aValue);
|
|
LONG SetUPSStatusBatteryStatus( DWORD aValue);
|
|
LONG SetUPSStatusCommStatus( DWORD aValue);
|
|
LONG SetUPSStatusBatteryCapacity( DWORD aValue);
|
|
|
|
/*
|
|
* Public Reg Entry function declarations
|
|
*/
|
|
void InitUPSConfigBlock();
|
|
void InitUPSStatusBlock();
|
|
void RestoreUPSConfigBlock();
|
|
void RestoreUPSStatusBlock();
|
|
void SaveUPSConfigBlock(BOOL forceAll);
|
|
void SaveUPSStatusBlock(BOOL forceAll);
|
|
void FreeUPSConfigBlock();
|
|
void FreeUPSStatusBlock();
|
|
|
|
/*
|
|
* Reg entry path string declarations
|
|
*/
|
|
#define UPS_DEFAULT_ROOT _T("SYSTEM\\CurrentControlSet\\Services\\UPS")
|
|
#define UPS_STATUS_ROOT _T("SYSTEM\\CurrentControlSet\\Services\\UPS\\Status")
|
|
#define UPS_CONFIG_ROOT _T("SYSTEM\\CurrentControlSet\\Services\\UPS\\Config")
|
|
#define UPS_SERVICE_ROOT _T("SYSTEM\\CurrentControlSet\\Services\\UPS\\ServiceProviders")
|
|
#define UPS_PORT_ROOT _T("HARDWARE\\DEVICEMAP\\SERIALCOMM")
|
|
|
|
#define UPS_UTILITYPOWER_UNKNOWN 0
|
|
#define UPS_UTILITYPOWER_ON 1
|
|
#define UPS_UTILITYPOWER_OFF 2
|
|
|
|
#define UPS_BATTERYSTATUS_UNKNOWN 0
|
|
#define UPS_BATTERYSTATUS_GOOD 1
|
|
#define UPS_BATTERYSTATUS_REPLACE 2
|
|
|
|
#define UPS_COMMSTATUS_UNKNOWN 0
|
|
#define UPS_COMMSTATUS_OK 1
|
|
#define UPS_COMMSTATUS_LOST 2
|
|
|
|
// Defines the values for the 'Options' bitmask registry key
|
|
#define UPS_INSTALLED 0x00000001
|
|
#define UPS_POWERFAILSIGNAL 0x00000002
|
|
#define UPS_LOWBATTERYSIGNAL 0x00000004
|
|
#define UPS_SHUTOFFSIGNAL 0x00000008
|
|
#define UPS_POSSIGONPOWERFAIL 0x00000010
|
|
#define UPS_POSSIGONLOWBATTERY 0x00000020
|
|
#define UPS_POSSIGSHUTOFF 0x00000040
|
|
#define UPS_RUNCMDFILE 0x00000080
|
|
|
|
#define UPS_DEFAULT_SIGMASK 0x0000007f
|
|
#define DEFAULT_CONFIG_IMAGEPATH TEXT("%SystemRoot%\\System32\\ups.exe")
|
|
|
|
// Min / Max / Default values for FirstMessageDelay (seconds)
|
|
#define WAITSECONDSFIRSTVAL 0
|
|
#define WAITSECONDSLASTVAL 120
|
|
#define WAITSECONDSDEFAULT 5
|
|
|
|
// Min / Max / Default values for MessageInterval (seconds)
|
|
#define REPEATSECONDSFIRSTVAL 5
|
|
#define REPEATSECONDSLASTVAL 300
|
|
#define REPEATSECONDSDEFAULT 120
|
|
|
|
// Min / Max / Default values for ShutdownOnBatteryWait (minutes)
|
|
#define SHUTDOWNTIMERMINUTESFIRSTVAL 2
|
|
#define SHUTDOWNTIMERMINUTESLASTVAL 720
|
|
#define SHUTDOWNTIMERMINUTESDEFAULT 2
|
|
|
|
// Shutdown behavior values
|
|
#define UPS_SHUTDOWN_SHUTDOWN 0
|
|
#define UPS_SHUTDOWN_HIBERNATE 1
|
|
|
|
/** ServiceProvider structure. The structure defines the entries in the
|
|
* ServiceProviders registry key.
|
|
*/
|
|
typedef struct {
|
|
LPTSTR theVendorKey; // Vendor registry subkey
|
|
LPTSTR theModelName; // UPS model name
|
|
LPTSTR theValue; // UPS value data
|
|
} ServiceProviderStructure;
|
|
|
|
|
|
/**
|
|
* InitializeRegistry
|
|
*
|
|
* Description:
|
|
* This function initiates the registry for the UPS service and the
|
|
* configuration application. When called, this function examines
|
|
* the registry to determine if it needs to be initalized. If the key
|
|
* HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\UPS\Config\ServiceProviderDLL
|
|
* is present, the registry is assumed to be initialized and no initialization
|
|
* is done. If the key is not present the following Keys are updated:
|
|
* Status
|
|
* Config
|
|
* ServiceProviders
|
|
*
|
|
* The values for the ServiceProviders key is supplied in the regdefs.h
|
|
* header file.
|
|
*
|
|
* Parameters:
|
|
* none
|
|
*
|
|
* Returns:
|
|
* TRUE if able to open registry keys with write access.
|
|
*/
|
|
BOOL InitializeRegistry();
|
|
|
|
|
|
///////////////
|
|
// upsdefines.h
|
|
#ifndef _ASSERT
|
|
#define _ASSERT(x)
|
|
#endif
|
|
|
|
#define DIMENSION_OF(array) (sizeof(array)/sizeof(array[0]))
|
|
|
|
//This value is used in most of the text buffers in various places throughout
|
|
//the application.
|
|
#define MAX_MESSAGE_LENGTH 1024
|
|
|
|
//The following three strings are the registry value names where all
|
|
//the UPS data is stored. These values are used in the RegField array
|
|
//in datacces.c
|
|
#define UPS_KEY_NAME TEXT("SYSTEM\\CurrentControlSet\\Services\\UPS")
|
|
#define STATUS_KEY_NAME TEXT("SYSTEM\\CurrentControlSet\\Services\\UPS\\Status")
|
|
#define CONFIG_KEY_NAME TEXT("SYSTEM\\CurrentControlSet\\Services\\UPS\\Config")
|
|
|
|
//The following values are used in the DialogAssociations arrays in updatdlg.c
|
|
//and upsinfo.c
|
|
#define RESOURCE_FIXED 0
|
|
#define RESOURCE_INCREMENT 1
|
|
#define REG_ANY_DWORD_TYPE (REG_DWORD | REG_DWORD_BIG_ENDIAN | REG_DWORD_LITTLE_ENDIAN)
|
|
|
|
//This is a helper macro to help form a DialogAssociations array members.
|
|
#define MAKE_ARRAY(stub, insertID, indexID, stringType, indexMax, regAccessType, shallowAccessPtr, regEntryPtr)\
|
|
{ eREG_##stub, IDC_##stub##_LHS, IDC_##stub, insertID, indexID, stringType, indexMax, regAccessType, shallowAccessPtr, regEntryPtr }
|
|
|
|
//The following are all the registry values supported by the application.
|
|
//The amount and values to these enums correspond to the size of the array
|
|
//g_upsRegFields
|
|
typedef enum _tUPSDataItemID { eREG_VENDOR_NAME = 0,
|
|
eREG_MODEL_TYPE,
|
|
eREG_SERIAL_NUMBER,
|
|
eREG_FIRMWARE_REVISION,
|
|
eREG_POWER_SOURCE,
|
|
eREG_RUNTIME_REMAINING,
|
|
eREG_BATTERY_CAPACITY,
|
|
eREG_BATTERY_STATUS,
|
|
eREG_UPS_OPTIONS,
|
|
eREG_SERVICE_PROVIDER_DLL,
|
|
eREG_SHUTDOWN_ON_BATTERY_ENABLE,
|
|
eREG_SHUTDOWN_ON_BATTERY_WAIT,
|
|
eREG_TURN_UPS_OFF_ENABLE,
|
|
eREG_APC_LINKURL,
|
|
eREG_UPGRADE_ENABLE,
|
|
eREG_COMM_STATUS,
|
|
eREG_PORT } tUPSDataItemID;
|
|
|
|
//This enum is used in DialogAssociations below. This defines the
|
|
//type of registry query to perform when reading registry values.
|
|
//There are only two options, to perform a deep get, that is, go
|
|
//right to the registry every time, re-reading it from the registry, or to
|
|
//use the regfunc buffer value (shallow get).
|
|
typedef enum _tRegAccessType { eDeepGet = 0,
|
|
eShallowGet } tRegAccessType;
|
|
|
|
//This struct links the registry field and the dialog controls.
|
|
typedef struct _DialogAssociations {
|
|
const tUPSDataItemID theFieldTypeID; //the eREG_... id. This is used to read the
|
|
//registry data.
|
|
DWORD theStaticFieldID; //A control id (usually for a static control). This
|
|
//is the left-hand side control. For example, in the
|
|
//on-screen text "Model Type: Back-UPS Pro" there are
|
|
//actually two controls the left-hand side (LHS) is
|
|
//"Model Type:" and the right-hand side is "Back-UPS Pro".
|
|
//These controls are separated as the LHS's behavior is
|
|
//different to the RHS when no data is present.
|
|
DWORD theDisplayControlID; //A control id (usually an edit field or a static)
|
|
DWORD theResourceInsertID; //The id of the string resource to insert the value into
|
|
//If the registry value is a DWORD then
|
|
//the insertion point should be %n!lu!, if
|
|
//it's a string then the insertion point can be just %n
|
|
DWORD theResourceIndexID; //This is only relevant if theResourceStringType is
|
|
//of type RESOURCE_INCREMENT. This identifies the id
|
|
//of the string when the value read for this item is 0,
|
|
//it is assumed that the other string values are stored
|
|
//consequtively in the string table following this value.
|
|
//For an example see below.
|
|
DWORD theResourceStringType; //This can be RESOURCE_FIXED or RESOURCE_INCREMENT.
|
|
//RESOURCE_FIXED means that the value needs no special
|
|
//handling. Simple insert the value into the string
|
|
//identified by theResourceInsertID. If it's equal to
|
|
//RESOURCE_INCREMENT then the string inserted is determined
|
|
//by reading the value from the registry (say it's equal
|
|
//to 1). The theResourceIndexID indentifies the id of the
|
|
//string resource corresponding to a value. A value of 1
|
|
//gives up the string with id theResourceIndexID + 1. This
|
|
//string is loaded and inserted into the string identified
|
|
//by theResourceInsertID.
|
|
DWORD theResourceIndexMax; //This is only relevant if theResourceStringType is
|
|
//of type RESOURCE_INCREMENT. This identifies the maximum
|
|
//index value that is support for this increment type. This
|
|
//is to protect from unsupported registry value causing the
|
|
//"theResourceIndexID + value" addition going beyond the
|
|
//range of supported string resource values.
|
|
tRegAccessType theRegAccessType; //This define whether the access to the registry value
|
|
//should use a "shallow" or "deep" get. See help on
|
|
//tUPSDataItemID above.
|
|
void * theShallowAccessFunctionPtr; //This point to the regfuncs function to use when performing
|
|
//a shallow get. This parameter is only required if
|
|
//theRegAccessType is set to eShallowGet, otherwise it can
|
|
//be 0.
|
|
struct _reg_entry * theRegEntryPtr; //This is the _reg_entry * parameter passed to the regfuncs
|
|
//function (theShallowAccessFunctionPtr member) when
|
|
//performing a shallow get. This parameter is only required if
|
|
//theRegAccessType is set to eShallowGet, otherwise it can
|
|
//be 0.
|
|
} DialogAssociations;
|
|
|
|
/*
|
|
|
|
The following example helps to explain more the members of the DialogAssociations struct.
|
|
|
|
Say we have an instance of this struct as follows:
|
|
|
|
DialogAssociations da = { eREG_POWER_SOURCE,
|
|
IDC_POWER_SOURCE_LHS,
|
|
IDC_POWER_SOURCE,
|
|
IDS_STRING,
|
|
IDS_UTILITYPOWER_UNKNOWN,
|
|
RESOURCE_INCREMENT,
|
|
2,
|
|
eDeepGet,
|
|
0,
|
|
0 };
|
|
|
|
This describes a registry field called eREG_POWER_SOURCE. If we look at
|
|
tUPSDataItemID above we see that eREG_POWER_SOURCE has a value of 4. If
|
|
we then look at g_upsRegFields in datacces.c we that the RegField at index
|
|
4 has the following data:
|
|
|
|
{ HKEY_LOCAL_MACHINE, STATUS_KEY_NAME, TEXT("UtilityPowerStatus"), REG_DWORD },
|
|
|
|
The DoUpdateInfo function, for example, takes this information when updating
|
|
the onscreen data in the main UPS page. The function gets the RegField
|
|
information, as above. It then looks to see if it needs to do a deep get (read
|
|
directly from the registry), or a shallow get (take data from the current
|
|
values stored in the regfuncs buffers. If the registry item theValueType is
|
|
one of the string type then the string value is copied into the resource
|
|
string identified by theResourceInsertID. In this case theValueType is
|
|
REG_DWORD. In this case the DWORD is read from the registry directly. Its
|
|
value (say it had a value of 1) is then added to IDS_UTILITYPOWER_UNKNOWN
|
|
giving a value which corresponds to IDS_UTILITYPOWER_ON. The string
|
|
IDS_UTILITYPOWER_ON is then loaded and used as a parameter value when
|
|
loaded the parameterized string resource identified by the
|
|
theResourceInsertID string id. This string (which should include the inserted
|
|
text) is then displayed in the control identified by theDisplayControlID.
|
|
*/
|
|
|
|
|
|
//this struct describes a registy field item
|
|
typedef struct _RegField {
|
|
HKEY theRootKey; //Handle to an existing registry key.
|
|
LPCTSTR theKeyName; //The name of the subkey relative to the above handle.
|
|
LPCTSTR theValueName; //The name of the registry value.
|
|
DWORD theValueType; //The type of the value.
|
|
} RegField;
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
RegField * GetRegField (DWORD index);
|
|
|
|
// upsdata.h
|
|
//Note that the order and numbering of the enums in tUPSDataItemID is linked to
|
|
//the contents of the array of RegFields defined in datacces.h.
|
|
//Do not change these value without due care and attention. It's OK to change
|
|
//it as long as the array of RegFields is updated to match.
|
|
|
|
DWORD ReadRegistryValueData (HKEY aRootKey,
|
|
LPCTSTR aKeyName,
|
|
LPCTSTR aValueName,
|
|
DWORD aAllowedTypes,
|
|
DWORD * aTypePtr,
|
|
LPTSTR aReturnBuffer,
|
|
DWORD * aBufferSizePtr);
|
|
|
|
BOOL GetUPSDataItemDWORD (const tUPSDataItemID aDataItemID, DWORD * aReturnValuePtr);
|
|
BOOL GetUPSDataItemString (const tUPSDataItemID aDataItemID, LPTSTR aBufferPtr, DWORD * pSizeOfBufferPtr);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
|
|
#endif
|