Windows2003-3790/public/sdk/inc/faxext.h
2020-09-30 16:53:55 +02:00

128 lines
4.2 KiB
C

/*++
Copyright (c) Microsoft Corporation. All rights reserved.
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.
Module Name:
faxext.h
Abstract:
Declarations of fax extension configuration and notification functions.
--*/
#ifndef _FAX_EXT_H_
#define _FAX_EXT_H_
#if _MSC_VER > 1000
#pragma once
#endif
#ifdef __cplusplus
extern "C" {
#endif
/************************************
* *
* Extension configuration data *
* *
************************************/
typedef enum
{
DEV_ID_SRC_FAX, // Device id is generated by the fax server
DEV_ID_SRC_TAPI // Device id is generated by a TAPI TSP (of FSP).
} FAX_ENUM_DEVICE_ID_SOURCE;
//
// Prototype of FaxExtGetData
//
DWORD
FaxExtGetData (
DWORD dwDeviceId, // Device id (0 = No device)
FAX_ENUM_DEVICE_ID_SOURCE DevIdSrc, // The source of the device id
LPCWSTR lpcwstrDataGUID,// GUID of data
LPBYTE *ppData, // (Out) Pointer to allocated data
LPDWORD lpdwDataSize // (Out) Pointer to data size
);
typedef DWORD (CALLBACK *PFAX_EXT_GET_DATA) (DWORD, FAX_ENUM_DEVICE_ID_SOURCE, LPCWSTR, LPBYTE *, LPDWORD);
//
// Prototype of FaxExtSetData
//
DWORD
FaxExtSetData (
HINSTANCE hInst, // Instance of calling extension
DWORD dwDeviceId, // Device id (0 = No device)
FAX_ENUM_DEVICE_ID_SOURCE DevIdSrc, // The source of the device id
LPCWSTR lpcwstrDataGUID,// GUID of data
LPBYTE pData, // Pointer to data
DWORD dwDataSize // Data size
);
typedef DWORD (CALLBACK *PFAX_EXT_SET_DATA) (HINSTANCE, DWORD, FAX_ENUM_DEVICE_ID_SOURCE, LPCWSTR, LPBYTE, DWORD);
HRESULT
FaxExtConfigChange (
DWORD dwDeviceId, // The device for which configuration has changed
LPCWSTR lpcwstrDataGUID, // Configuration name
LPBYTE lpData, // New configuration data
DWORD dwDataSize // Size of new configuration data
);
typedef HRESULT (WINAPI *PFAX_EXT_CONFIG_CHANGE) (DWORD, LPCWSTR, LPBYTE, DWORD);
//
// Prototype of FaxExtRegisterForEvents
//
HANDLE
FaxExtRegisterForEvents (
HINSTANCE hInst, // Instance of calling extension
DWORD dwDeviceId, // Device id (0 = No device)
FAX_ENUM_DEVICE_ID_SOURCE DevIdSrc, // The source of the device id
LPCWSTR lpcwstrDataGUID,// GUID of data
PFAX_EXT_CONFIG_CHANGE lpConfigChangeCallback
);
typedef HANDLE (CALLBACK *PFAX_EXT_REGISTER_FOR_EVENTS) (HINSTANCE, DWORD, FAX_ENUM_DEVICE_ID_SOURCE, LPCWSTR, PFAX_EXT_CONFIG_CHANGE);
//
// Prototype of FaxExtUnregisterForEvents
//
DWORD
FaxExtUnregisterForEvents (
HANDLE hNotification
);
typedef DWORD (CALLBACK *PFAX_EXT_UNREGISTER_FOR_EVENTS) (HANDLE);
//
// Prototype of FaxExtFreeBuffer
//
VOID
FaxExtFreeBuffer (
LPVOID lpvBuffer
);
typedef VOID (CALLBACK *PFAX_EXT_FREE_BUFFER) (LPVOID);
//
// The extension should implement and export the following function:
//
HRESULT
FaxExtInitializeConfig (
PFAX_EXT_GET_DATA, // Pointer to FaxExtGetExtensionData in service
PFAX_EXT_SET_DATA, // Pointer to FaxExtSetExtensionData in service
PFAX_EXT_REGISTER_FOR_EVENTS, // Pointer to FaxExtRegisterForExtensionEvents in service
PFAX_EXT_UNREGISTER_FOR_EVENTS, // Pointer to FaxExtUnregisterForExtensionEvents in service
PFAX_EXT_FREE_BUFFER // Pointer to FaxExtFreeBuffer in service
);
typedef HRESULT (WINAPI *PFAX_EXT_INITIALIZE_CONFIG) (PFAX_EXT_GET_DATA, PFAX_EXT_SET_DATA, PFAX_EXT_REGISTER_FOR_EVENTS, PFAX_EXT_UNREGISTER_FOR_EVENTS, PFAX_EXT_FREE_BUFFER);
#ifdef __cplusplus
}
#endif
#endif // _FAX_EXT_H_