Cwa14050 01 2000 Nov
Cwa14050 01 2000 Nov
Cwa14050 01 2000 Nov
WORKSHOP
AGREEMENT
CWA 14050-1
November 2000
Extensions for Financial Services (XFS) interface specification Release 3.0 - Part 1: Application Programming Interface (API) - Service
Provider Interface (SPI); Programmer's Reference
This CEN Workshop Agreement can in no way be held as being an official standard
as developed by CEN National Members.
2000 CEN
All rights of exploitation in any form and by any means reserved world-wide for
CEN National Members
Page 2
CWA 14050-1:2000
Table of Contents
Foreword ................................................................................................................................................ 5
1.
2.
References ............................................................................................................................... 8
3.
ARCHITECTURE ......................................................................................................................... 10
3.2
3.3
4.
4.2
4.3
4.2.1
4.2.2
4.3.2
4.3.3
4.4
4.5
4.6
4.7
4.8
4.9
4.8.1
4.8.2
Compound Devices................................................................................................................ 27
TIMEOUT ................................................................................................................................... 29
WFSCANCELASYNCREQUEST ................................................................................................... 40
5.2
WFSCANCELBLOCKINGCALL .................................................................................................... 41
5.3
WFSCLEANUP .......................................................................................................................... 42
5.4
WFSCLOSE .............................................................................................................................. 43
5.5
WFSASYNCCLOSE.................................................................................................................... 44
5.6
WFSCREATEAPPHANDLE ......................................................................................................... 45
Page 3
CWA 14050-1:2000
5.7
WFSDEREGISTER ..................................................................................................................... 46
5.8
WFSASYNCDEREGISTER ........................................................................................................... 47
5.9
WFSDESTROYAPPHANDLE ....................................................................................................... 49
WFPCANCELASYNCREQUEST ................................................................................................... 81
6.2
WFPCLOSE .............................................................................................................................. 82
6.3
WFPDEREGISTER ..................................................................................................................... 83
6.4
WFPEXECUTE .......................................................................................................................... 85
6.5
WFPGETINFO ........................................................................................................................... 87
6.6
WFPLOCK ................................................................................................................................ 89
6.7
WFPOPEN ................................................................................................................................ 90
6.8
WFPREGISTER ......................................................................................................................... 93
6.9
WFPSETTRACELEVEL .............................................................................................................. 94
6.10 WFPUNLOADSERVICE............................................................................................................... 96
6.11 WFPUNLOCK ............................................................................................................................ 97
7.
Support Functions................................................................................................................. 98
7.1
WFMALLOCATEBUFFER............................................................................................................ 98
7.2
WFMALLOCATEMORE............................................................................................................... 99
7.3
7.4
7.5
7.6
Page 4
CWA 14050-1:2000
7.7
WFMRELEASEDLL................................................................................................................. 104
7.8
7.9
8.
8.2
8.3
8.4
8.5
8.6
8.7
WFMOPENKEY....................................................................................................................... 114
8.8
8.9
9.
10.
9.2
10.1.2
12.
13.
14.
Page 5
CWA 14050-1:2000
Foreword
This CWA is revision 3.0 of the XFS interface specification.
The move from an XFS 2.0 specification (CWA 13449) to a 3.0 specification has been prompted by a series of
factors.
Initially, there has been a technical imperative to extend the scope of the existing specification of the XFS
Manager to include new devices, such as the Card Embossing Unit.
Similarly, there has also been pressure, through implementation experience and the advance of the Microsoft
technology, to extend the functionality and capabilities of the existing devices covered by the specification.
Finally, it is also clear that our customers and the market are asking for an update to a specification, which is
now over 2 years old. Increasing market acceptance and the need to meet this demand is driving the Workshop
towards this release.
The clear direction of the CEN/ISSS XFS Workshop, therefore, is the delivery of a new Release 3.0
specification based on a C API. It will be delivered with the promise of the protection of technical investment for
existing applications and the design to safeguard future developments.
The CEN/ISSS XFS Workshop gathers suppliers as well as banks and other financial service companies. A list
of companies participating in this Workshop and in support of this CWA is available from the CEN/ISSS
Secretariat.
This CWA was formally approved by the XFS Workshop meeting on 2000-10-18. The specification is
continuously reviewed and commented in the CEN/ISSS Workshop on XFS. It is therefore expected that an
update of the specification will be published in due time as a CWA, superseding this revision 3.0.
The CWA is published as a multi-part document, consisting of:
Part 1: Application Programming Interface (API) - Service Provider Interface (SPI); Programmer's Reference
Part 2: Service Classes Definition; Programmer's Reference
Part 3: Printer Device Class Interface - Programmer's Reference
Part 4: Identification Card Device Class Interface - Programmer's Reference
Part 5: Cash Dispenser Device Class Interface - Programmer's Reference
Part 6: PIN Keypad Device Class Interface - Programmer's Reference
Part 7: Check Reader/Scanner Device Class Interface - Programmer's Reference
Part 8: Depository Device Class Interface - Programmer's Reference
Part 9: Text Terminal Unit Device Class Interface - Programmer's Reference
Part 10: Sensors and Indicators Unit Device Class Interface - Programmer's Reference
Part 11: Vendor Dependent Mode Device Class Interface - Programmer's Reference
Part 12: Camera Device Class Interface - Programmer's Reference
Part 13: Alarm Device Class Interface - Programmer's Reference
Part 14: Card Embossing Unit Class Interface - Programmer's Reference
Part 15: Cash In Module Device Class Interface- Programmer's Reference
Part 16: Application Programming Interface (API) - Service Provider Interface (SPI) - Migration from Version
2.0 (see CWA 13449) to Version 3.0 (this CWA) - Programmer's Reference
Part 17: Printer Device Class Interface - Migration from Version 2.0 (see CWA 13449) to Version 3.0 (this
CWA) - Programmer's Reference
Page 6
CWA 14050-1:2000
Part 18: Identification Card Device Class Interface - Migration from Version 2.0 (see CWA 13449) to Version
3.0 (this CWA) - Programmer's Reference
Part 19: Cash Dispenser Device Class Interface - Migration from Version 2.0 (see CWA 13449) to Version 3.0
(this CWA) - Programmer's Reference
Part 20: PIN Keypad Device Class Interface - Migration from Version 2.0 (see CWA 13449) to Version 3.0 (this
CWA) - Programmer's Reference
Part 21: Depository Device Class Interface - Migration from Version 2.0 (see CWA 13449) to Version 3.0 (this
CWA) - Programmer's Reference
Part 22: Text Terminal Unit Device Class Interface - Migration from Version 2.0 (see CWA 13449) to Version
3.0 (this CWA) - Programmer's Reference
Part 23: Sensors and Indicators Unit Device Class Interface - Migration from Version 2.0 (see CWA 13449) to
Version 3.0 (this CWA) - Programmer's Reference
Part 24: Camera Device Class Interface - Migration from Version 2.0 (see CWA 13449) to Version 3.0 (this
CWA) - Programmer's Reference
Part 25: Identification Card Device Class Interface - PC/SC Integration Guidelines
In addition to these Programmer's Reference specifications, the reader of this CWA is also referred to a
complementary document, called Release Notes. The Release Notes contain clarifications and explanations on
the CWA specifications, which are not requiring functional changes. The current version of the Release Notes is
available online from http://www.cenorm.be/isss/Workshop/XFS.
The information in this document represents the Workshop's current views on the issues discussed as of the date
of publication. It is furnished for informational purposes only and is subject to change without notice.
CEN/ISSS makes no warranty, express or implied, with respect to this document.
Revision History:
1.0
May 24, 1993
1.11
February 3, 1995
2.00
3.00
Page 7
CWA 14050-1:2000
1.
The CEN XFS Workshop is a continuation of the Banking Solution Vendors Council workshop and maintains a
technical commitment to the Win 32 API. However, the XFS Workshop has extended the franchise of multi
vendor software by encouraging the participation of both banks and vendors to take part in the deliberations of
the creation of an industry standard. This move towards opening the participation beyond the BSVC's original
membership has been very succesful with a current membership level of more than 20 companies.
The fundamental aims of the XFS Workshop are to promote a clear and unambiguous specification for both
service providers and application developers. This has been achieved to date by sub groups working
electronically and quarterly meetings.
The move from an XFS 2.0 specification to a 3.0 specification has been prompted by a series of factors. Initially,
there has been a technical imperative to extend the scope of the existing specification of the XFS Manager to
include new devices, such as the Card Embossing Unit.
Similarly, there has also been pressure, through implementation experience and the advance of the Microsoft
technology, to extend the functionality and capabilities of the existing devices covered by the specification.
Finally, it is also clear that our customers and the market are asking for an update to a specification, which is
now over 2 years old. Increasing market acceptance and the need to meet this demand is driving the Workshop
towards this release.
The clear direction of the XFS Workshop, therefore, is the delivery of a new Release 3.0 specification based on
a C API. It will be delivered with the promise of the protection of technical investment for existing applications
and the design to safeguard future developments.
Page 8
CWA 14050-1:2000
2.
References
1. XFS Service Classes Definition, Programmers Reference Revision 3.00, October 18, 2000
Page 9
CWA 14050-1:2000
3.
A key element of the Extensions for Financial Services is the definition of a set of APIs, a corresponding set of
SPIs, and supporting services, providing access to financial services for Windows-based applications. The
definition of the functionality of the services, of the architecture, and of the API and SPI sets, is outlined in this
section, and described in detail in Sections 5 through 10.
The specification defines a standard set of interfaces such that, for example, an application that uses the API set
to communicate with a particular service provider can work with a service provider of another conformant
vendor, without any changes.
The specification is intended to be usable within all implementations and versions of the Windows operating
systems, from Windows version 3.1, Windows for Workgroups version 3.1 and the initial versions of Windows
NT, and onwards. It thus provides for both 16 and 32 bit operating environments (operating under the Win32s
subsystem in 16 bit environments).
Although the Extensions for Financial Services define a general architecture for access to service providers from
Windows-based applications, the initial focus of the CEN/ISSS XFS Workshop has been on providing access to
peripheral devices that are unique to financial institutions. Since these devices are often complex, difficult to
manage and proprietary, the development of a standardized interface to them from Windows-based applications
and Windows operating systems can offer financial institutions and their solution providers immediate
enhancements to productivity and flexibility.
Page 10
CWA 14050-1:2000
3.1
Architecture
The architecture of the Extensions for Financial Services (XFS) system is shown below.
Windows-based
applications
XFS APIs
XFS Manager
Configuration
Information
XFS SPIs
Service
providers
Figure 2.1 Extensions for Financial Services Architecture
The applications communicate with service providers, via the Extensions for Financial Services Manager, using
the API set. Most of these APIs can be invoked either "synchronously" (the Manager causes the application to
wait until the API's function is completed) or "asynchronously" (the application regains control immediately,
while the function is performed in parallel).
The common deliverable in all implementations of this Extensions for Financial Services specification is the
Extensions for Financial Services Manager, which maps the specified API to the corresponding SPI, then routes
this request to the appropriate service provider. The Manager uses the configuration information to route the API
call (made to a "logical service" or a "logical device") to the proper service provider entry point (which is always
local, even though the device or service that is the final target may be remote). Note that even though the API
calls may be either synchronous or asynchronous, the SPI calls are always asynchronous.
The developers of financial services to be used via XFS and the manufacturers of financial peripherals will be
responsible for the development and distribution of service providers for their services and devices. A setup
routine for each device or service will also be necessary to define the appropriate configuration information. This
information will allow an application to request capability and status information about the devices and services
available at any point in time.
The primary functions of the service providers are to:
Translate generic (e.g., forms-based) service requests to service-specific commands.
Route the requests to either a local service or device, or to one on a remote system, effectively defining
a peer-to-peer interface among service providers.
Arbitrate access by multiple applications to a single service or device, providing exclusive access when
requested.
Manage the hardware interfaces to services or devices.
Manage the asynchronous nature of the services and devices in an appropriate manner, always
presenting this capability to the XFS Manager and the applications via Windows messages.
The system design supports solution of complex problems, often not addressed by current systems, by providing
for maximum flexibility in all its capabilities:
Multiple service providers, developed by multiple vendors, can coexist in a single system and in a
network.
The service class definition is based on the logical functionalities of the service, with no assumption
being made as to the physical configuration. A physical device that includes multiple distinct physical
Page 11
CWA 14050-1:2000
Note that Figure 2.1 is a high level view of the architecture and, in particular, it makes no distinction between
service providers and the services they manage. This specification focuses on service providers rather than on
services, because the way a service provider communicates with a service is a vendor-specific internal design
issue that applications and the XFS Manager are unaware of. In fact, there are many different ways that service
providers can make services available to applications. Hence, this specification refers primarily to the service
providers, since these are the modules with which the XFS Manager communicates. There are occasional
references to 'service' where this is appropriate.
Example
Figure 2.2 below shows an XFS system supporting a set of financial peripherals. Note that in this framework the
XFS Manager interfaces directly with a set of service providers that interface directly with the physical devices.
Thus, the service providers are shown as implementing the service provider, service, and device driver functions,
although these are more likely to be two or more separate layers. Many other configurations are possible.
WorkStation 1
WorkStation 2
WorkStation 3
Application
Application
Application
Configuration
Information
XFS API
XFS
Manager
XFS API
XFS
Manager
XFS SPI
XFS SPI
Passbook
Printer
Service
Provider
Passbook
Printer
Service
Provider
Passbook
Printer
Service
Provider
Vendor X
Vendor Y
Vendor Y
Passbook
Printer
Vendor X
Configuration
Information
XFS API
Passbook
Printer
Vendor Y
Configuration
Information
XFS
Manager
XFS SPI
Magnetic
Card Reader
Service Provider
Vendor Y
Magnetic
Card Reader
Vendor Y
Passbook
Printer
Service
Provider
Vendor X
Passbook
Printer
Vendor X
Figure 2.2 An XFS architecture example for a branch office banking system
It should also be noted that one vendor's service providers are not necessarily compatible with another vendor's,
as shown in Figure 2.2. If one application has to access the same service class as implemented by different
vendors, a service provider is installed for each vendor.
Page 12
CWA 14050-1:2000
3.2
Sections 5 through 7 of this document present the interfaces that allow a financial application to communicate in
a standard fashion with financial services and devices. The functions are at a sufficiently high level to allow for
seamless redirection to other parts of the underlying operating system. A printer, for example, might rely on a set
of services provided by the operating system, but in order to handle the unique characteristics of a financial
printer and application, the service provider would preprocess the command, then redirect the derived commands
to the operating system's printing services. In other implementations, the printer might be supported entirely by
XFS service mechanisms, and not use the operating system printing services in any way.
The API is structured as sets of:
Basic functions, such as StartUp/CleanUp, Open/Close, Lock/Unlock, and Execute, that are
common to all the Extensions for Financial Services device/service classes,
Administration functions, such as device initialization, reset, suspend or resume, used for managing
devices and services, and
Specific commands, used to request information about a service/device, and to initiate device/servicespecific functions; these are sent to devices and services as parameters of the GetInfo and Execute
basic functions. These service-specific commands are specified in a set of separate specifications, one
for each service class.
To the maximum extent possible, the syntax of specific commands that are used with multiple device/service
classes is kept consistent across all devices. A primary objective is to standardize function codes and structures
for the widest possible variety of devices.
The SPI is kept as similar as possible to the API. Some commands are processed exclusively by the XFS
Manager, and so are not in the SPI, and there are minor differences in the specific parameters passed at the two
interface levels.
A typical scenario showing the usage of the APIs is shown below. This example illustrates the functions used to
print a form.
StartUp (connects the application to the XFS Manager, including version negotiation)
Open (establishes a session between the application and the service provider)
Register (specifies the messages that the application should receive from the service provider)
Lock (obtains exclusive access to the service by the application)
multiple Execute functions, passing one or more specific commands:
Print_Form
etc.
Unlock (releases exclusive access to the service by the application)
Deregister (specifies that the application should no longer receive messages from the service
provider)
Close (ends the session between the application and the service provider)
CleanUp (disconnects the application from the XFS Manager)
Note that within a session (defined by Open and Close), an application may at any time change the classes of
messages it wishes to receive from the service provider (using Register), and may either Lock the service only
for specified periods (typically for each transaction), or for the entire session. Also, note that several of the
commands are optional, depending on how the device is being managed and shared (i.e., Lock/Unlock,
Register/Deregister).
Page 13
CWA 14050-1:2000
3.3
Device Classes
The classes of devices that belong to the second version of the Extensions for Financial Services are described in
the separate Service Class Definition Document.
Page 14
CWA 14050-1:2000
4.
The remainder of this document provides the technical specifications for the CEN/ISSS Extensions for Financial
Services (referred to hereafter as XFS for brevity).
In this specification, the functions of the XFS Application Programming Interface (API) and Service Provider
Interface (SPI) are always described in terms of providing a standardized, portable interface for applications to
gain access to service providers. This architecture allows service providers to deliver an open-ended set of
capabilities to financial applications based on the Microsoft Windows operating systems, including access to
peripheral devices unique to financial institutions. Since the first priority of the CEN members for XFS
implementations has been to provide this peripheral device access capability, the examples used relate primarily
to device control and physical input/output.
The key elements of the Extensions for Financial Services are the API definition and the corresponding SPI
definition, used by the XFS Manager to communicate with the service providers, together with the set of
supporting services provided by the XFS Manager. These elements are combined in a XFS implementation,
providing access to financial devices and services for Windows-based applications.
The specification defines a standard set of interfaces in order to provide multi-vendor interoperability: if an
application uses the API to communicate successfully with a service provider, it should work with another
conformant service provider of the same type, developed by another vendor, without any changes. Similarly, any
service provider that conforms to the SPI definition can work with a range of conformant applications.
The specification is intended to be usable within all implementations and versions of the Windows operating
systems, beginning with versions 3.1 of Windows, Windows for Workgroups, and Windows NT, and all future
versions of these operating systems. In the 16 bit operating systems (Windows 3.x, Windows for Workgroups
3.x) the elements of an XFS subsystem (applications, XFS Manager, and service providers) will be 32 bit
modules, implemented using the Win32s API. The specification thus provides for the development and
deployment of 32 bit applications on both 16 and 32 bit operating systems, and the XFS software development
kit will include versions of the XFS Manager and associated programming aids that will allow development of
applications and service providers for both environments.
For clarity, three prefixes are used in naming the function interfaces in XFS:
Function type: Prefix
API functions: WFS...
Functions called by
Applications
XFS Manager
Service providers
Applications
Functions provided by
XFS Manager (and typically
passed through to WFP functions)
Service providers
XFS Manager
Page 15
CWA 14050-1:2000
4.1
The XFS Manager provides overall management of the XFS subsystem. The XFS Manager is responsible for
mapping the API (WFS...) functions to SPI (WFP...) functions, and calling the appropriate vendor-specific
service providers. Note that the calls are always to a local service provider.
The XFS Manager determines which service provider to call using the logical name parameter of the WFSOpen
or WFSAsyncOpen function. The logical name is the key providing access to the configuration information that
defines the Service Class (e.g., printer, cash dispenser, etc.), the Service Type (e.g., receipt printer, journal
printer, etc.) and the Service Provider (DLL file name), as well as additional information. The logical name must
be unique at least within each workstation. See Sections 3.7 and 7 for discussions of configuration information
access and management.
The XFS Manager also provides the Support Functions (WFM...) defined in Section 6 and the Configuration
Functions (also WFM...) defined in Section 7.
Before an application is allowed to utilize any of the services managed by the XFS subsystem, it must first
identify itself to the subsystem. This is accomplished using the WFSStartUp function. An application is only
required to perform this function once, regardless of the number of XFS services it utilizes, so this function
would typically be called during application initialization. Similarly, the complementary function,
WFSCleanUp, is typically called during application shutdown. If an application exits or is shut down without
issuing the WFSCleanUp function, the XFS Manager does the cleanup automatically, including the closing of
any sessions with service providers the application has left open.
Page 16
CWA 14050-1:2000
4.2
Service Providers
Each XFS service, for each vendor, is accessed via a service-specific module called a service provider. For
example, vendor A's journal printer is accessed via vendor A's journal printer service provider, and vendor B's
receipt printer is accessed via vendor B's receipt printer service provider.
The following sections describe the functionality and packaging of service providers.
4.2.1
The primary functions of XFS service providers, working in conjunction with their respective services and/or
device drivers, are as follows. Note that how these functions are implemented is left to the service provider
developer.
Route the requests to the device or service, which may be on a remote workstation.
Service providers may communicate with remote services in a variety of ways, such as NetBIOS, named
pipes, RPC (Remote Procedure Calls), Windows Sockets, proprietary network programming interfaces, etc.
Manage the asynchronous nature of the services in a consistent manner with respect to the applications.
The asynchronous nature of the SPI must always be presented back to the XFS Manager and the
applications in the form of Windows messages.
Error recovery.
In some kinds of software failures, such as an application crash, the service provider loses connection with
the application. In this situation, the service provider is responsible for an orderly shutdown of the session
with that application. In particular, the service provider generates a system event (see Section 3.11)
indicating that the connection was lost, and if any requests from the application were outstanding, it
generates a system event for each completion that would normally have generated a completion message to
the application.
4.2.2
Page 17
CWA 14050-1:2000
4.3
Windows and XFS are built on an event-driven, asynchronous model. However, the XFS design allows an
application using its interfaces to behave in either an asynchronous or synchronous manner. Thus the API
supports two versions of each of the appropriate functions (e.g., an application can request to lock a service
using either the asynchronous WFSAsyncLock function or the synchronous WFSLock function).
Each XFS API function operates in one of three synchronization modes: asynchronous, synchronous or
immediate. These are described in the following sections.
Note that the SPI is purely an asynchronous interface, so all SPI functions are either asynchronous or immediate;
there are no synchronous SPI functions.
See Sections 4 and 5 for a summary of the API and SPI functions and their synchronization modes.
4.3.1
Asynchronous Functions
Asynchronous mode is used for operations which may take an indeterminate amount of time to complete.
Performing an operation in an asynchronous, as opposed to a synchronous, mode allows the application to
operate in Windows' native event-driven, message-based manner. The processing of an asynchronous request
(e.g., WFSAsyncExecute) is as follows:
4.3.2
Synchronous Functions
Synchronous mode is also used when an operation can take an indeterminate amount of time to complete, but the
application wishes to handle the function in a sequential manner. The XFS Manager does not return control to
the application until the operation has completed, thus synchronous functions are referred to as blocking. Each
synchronous call made by an application is translated by the XFS Manager into its asynchronous SPI counterpart
before being passed to the service provider.
If a blocking operation is not completed immediately in a Windows 3.x system, the XFS Manager executes a
Windows message loop on behalf of the calling thread, thereby keeping the Windows system running. See
Section 3.12 for a more detailed discussion of process, threads and message loops. In Windows NT, the calling
application thread is blocked on request completion. A thread may have only one blocking XFS call outstanding
at any one time. See Section 3.12 for additional discussion of the management of synchronous functions,
including replacement of the default message loop.
The processing of a synchronous request (e.g., WFSExecute) is as follows:
The application calls the XFS Manager.
The XFS Manager translates the request into an asynchronous SPI, generates a RequestID to track the
request, provides its own window handle to receive the completion message, and calls the service provider
DLL.
The service provider schedules the request for deferred processing and immediately returns to the XFS
Manager.
The XFS Manager simulates synchronous processing as described above and in Section 3.12.
At some point, the service provider processes the deferred request.
Page 18
CWA 14050-1:2000
On completion, the service provider posts a completion message to the window handle specified by the XFS
Manager. The message contains a pointer to a WFSRESULT data structure defining the results of the
request, including the RequestID, the status code and the other relevant data.
The XFS Manager unpacks the information from the completion message into the appropriate parameters,
and returns them to the application, unblocking the original application request.
4.3.3
Immediate Functions
These are API functions that are not either asynchronous or synchronous. Typically, immediate APIs are those
which do not communicate with a service or a physical device (or use the network in any other way) and are thus
guaranteed to complete immediately, whether successfully or not. They are handled in two ways:
Processed entirely by the XFS Manager, which returns immediately to the application. Examples include
WFSStartUp, and WFSSetBlockingHook.
Passed by the XFS Manager to the service provider as an immediate SPI. The service provider processes the
request and immediately returns to the XFS Manager, which returns immediately to the application.
Examples include WFSCancelAsyncRequest and WFMSetTraceLevel.
Page 19
CWA 14050-1:2000
4.4
When an application calls a XFS API function one of the following processing scenarios takes place. Note that
this classification is distinct from the API synchronization modes discussed above. See Section 5 for the
mapping of API functions to SPI functions.
The function is converted by the XFS Manager directly into the corresponding SPI function
(e.g., WFSAsyncRegister).
The XFS Manager performs some preprocessing and then converts the function into the corresponding SPI
function (e.g., WFSAsyncExecute).
The XFS Manager performs some preprocessing and then translates the API function to a different SPI
function, which it passes to the service provider. Most of the synchronous API functions (e.g., WFSLock)
are of this type, since they are translated to their asynchronous SPI equivalents.
The XFS Manager performs some preprocessing and then translates the API function to multiple SPI
functions, which it passes to the service provider (e.g., WFSOpen).
The function is completely processed inside the XFS Manager (e.g., WFSIsBlocking,
WFSSetBlockingHook).
Service providers (and sometimes applications) call the XFS Manager for the support functions defined in
Section 6 and for the configuration functions defined in Section 7.
Page 20
CWA 14050-1:2000
4.5
Opening a session
Once a connection between an application and the XFS Manager has successfully been negotiated (via
WFSStartUp), the application establishes a virtual session with a service provider by issuing a WFSOpen (or
WFSAsyncOpen) request. Opens are directed towards logical services as defined in the XFS configuration. A
service handle (hService) is assigned to the session, and is used in all the calls to the service in the lifetime of the
session.
Note that applications may optionally choose to explicitly manage the concept of application identity when
they need to use interdependent compound devices (see Section 3.8.2). This is achieved by using the
WFSCreateAppHandle function to get an application handle (hApp), which is unique within the system. This
function can be called multiple times to obtain multiple unique handles. An application handle parameter is then
used in the WFSOpen function, directing the service provider to bind the specified application handle to the
session being initiated. This allows a single application process (potentially multi-threaded) to act as multiple
applications to the XFS subsystem, to allow effective use of interdependent compound devices. An example of a
case in which this could be useful is an application using the Multiple Document Interface (MDI); the
application could associate an application handle with each MDI child window. See Section 3.8.2 for additional
discussion of the use of application handles with compound devices. Note that neither service nor application
handles may be shared among two or more applications.
The actions performed by the XFS Manager on an open are as follows:
Retrieves the configuration information defining the specified logical service, in order to determine the DLL
name of the service provider. The logical service name is the key to the configuration information.
Loads the DLL containing the requested service provider, if it is not already loaded.
Performs pre-processing and translation as necessary, depending on whether the synchronous or
asynchronous open API has been issued.
Generates a unique service handle (hService) that identifies the session with the service provider that is
being established, to be passed back to the application as a parameter.
Calls the service provider's WFPOpen function, passing the parameters needed.
The service provider does the following:
Performs version negotiation, using the parameters specifying the SPI version requested by the XFS
Manager, and the service-specific interface version requested by the application.
Retrieves the configuration information.
Asynchronously establishes a session with the service specified in the configuration on the specified
workstation, if necessary, relying on the transport facilities provided.
Upon completion of the request, posts a completion message (WFS_OPEN_COMPLETE), which goes to
the application for a WFSAsyncOpen call, and to the XFS Manager for a WFSOpen call.
Note that even if the service is locked by another application, the open function succeeds, as defined in Section
3.8, Exclusive Service and Device Access.
An application programmer has at least two obvious choices as to when to perform the WFSOpen (and the
complementary WFSClose) of the services it utilizes:
Open the services during application initialization, keep them open, and close them during application
shutdown.
Perform the open each time the service is required, utilize it, and immediately close it.
Each technique has its own advantages. For example, while the first example might provide better performance,
the second might be easier to program. In any case, upon a successful completion of an open, the XFS subsystem
returns a service handle which must be used for all subsequent communication with the service.
Note that an application must perform an open for each logical service that it wishes to utilize, even if the
services are of the same type. For example, if an application wishes to utilize two separate receipt printers, it
must open two separate logical services.
Furthermore, an application may need to open multiple logical services, even when a set of devices are housed in
a single device. For example, consider a compound printer which includes both a receipt and a journal printer. If
the application requires access to both the receipt and journal printer functions, it must open both a receipt
logical service and a journal logical service.
Page 21
CWA 14050-1:2000
4.6
Closing a Session
When an application no longer requires the use of a particular service, it issues a WFSClose or
WFSAsyncClose request. The XFS subsystem then closes that session as follows:
The XFS Manager calls the service provider's WFPClose function.
The service provider schedules the request for deferred processing, and returns immediately to the XFS
Manager. Note that at this point the service handle, hService, is no longer valid.
At some point, the service provider processes the deferred close request, communicating with the service as
necessary to accomplish the request.
Requests that were issued by the application before the close are executed.
If the calling application has the service locked under the same hService, the service provider unlocks it
automatically (following the standard lock policy as defined in Section 3.8).
The service cleans up its administrative information (removes WFSRegister entries etc.).
If the XFS subsystem loses connection to an application, it closes the session as described above, and:
An application disconnect event (SYSTEM_EVENT class) is generated.
Since messages can no longer be posted to the application, any command completion and event notification
messages from this service for the application are converted to undeliverable message events
(SYSTEM_EVENT class).
Note that it is required that some application have registered for system events, or these events are effectively not
reported.
Page 22
CWA 14050-1:2000
4.7
Configuration Information
The XFS Manager uses its configuration information to define the relationships among the applications and the
service providers. In particular, this information defines the mapping between the logical service interface
presented at the API (via logical service name) and the appropriate service provider entry points.
The configuration information also includes specific information about logical services and service providers,
some of which is common to all solution providers; it may also include information about physical services, if
any are present on the system, and vendor-specific information. The location of the information is transparent to
both applications and service providers; they always store and retrieve it using the configuration functions
provided by the XFS Manager, as described in Section 7, for portability across Windows platforms.
It is the responsibility of solution providers, and the developers of each service provider, to implement the
appropriate setup and management utilities, to create and manage the configuration information about the XFS
subsystem configuration and its service providers, using the configuration functions.
These functions are used by service providers and applications to write and retrieve the configuration
information for a XFS subsystem, which is stored in a hierarchical structure called the Windows Registry. The
structure and the functions are based on the Win32 Registry architecture and API functions, and are
implemented in Windows NT/98 and future versions of Windows using the Registry and the associated
functions.
Each node in the configuration registry is called a key, each having a name and (optionally) values. All values
consist of a name and data pair, both null-terminated character strings. There are two logical groupings of XFS
Registry information; local PC dependent configuration information and user dependent configuration
information.
The local PC dependent configuration information is stored beneath the following Registry key.
HKEY_LOCAL_MACHINE
SOFTWARE
XFS
User dependent configuration information is stored in the HKEY_USERS section of the Registry.
HKEY_USERS
Default or
User ID
XFS
Page 23
CWA 14050-1:2000
Within the local PC dependent configuration information are stored three XFS related keys;
XFS_MANAGER Beneath this key are values and/or keys for information that the XFS Manager
creates and uses.
SERVICE_PROVIDERS Beneath this key is a key for each XFS compliant service provider.
PHYSICAL_SERVICES Beneath this key are physical attachment configuration information, defined
by the solution provider.
Within the User dependent configuration information is stored the following LOGICAL_SERVICES key:
LOGICAL_SERVICES Beneath this key is defined a key for each XFS logical service (ie: the
lpszLogicalName parameter of the WFSOpen, WFSAsyncOpen and WFPOpen functions)
The configuration functions provide the capabilities to create, enumerate, open and delete keys, and to set, query
and delete values within each key. Vendor-provided configuration utility programs set up the registry structure
and its contents, using these functions. Configured Registry values and keys define how the XFS subsystem,
services and providers are configured. These are used by the XFS Manager, applications and service providers.
Note that vendor-specific information may be added to any key in this structure, using optional values.
The figure below illustrates the full structure of the local PC dependent configuration information.
HKEY_LOCAL_MACHINE
SOFTWARE
XFS
XFS_MANAGER
XFS
Info 1
SERVICE_PROVIDERS
XFS
Info N
SP
Info 1
SP
Info N
PHYSICAL_SERVICES
PS
Info 1
PS
Info N
TraceFile
the name of the file containing trace data. If this value is not set in the
configuration, trace data is written to the default file path\name
C:\XFSTRACE.LOG.
ShareFilename
the name of the memory mapped file used by the memory management functions
of the XFS Manager.
ShareFilesize
the size of the memory mapped file used by the memory management functions
of the XFS Manager.
Page 24
CWA 14050-1:2000
Some additional values could be also defined in the XFS SDK release notes. Please refer to the related document
for more information.
Beneath the SERVICE_PROVIDERS key there are keys for each individual service providers, the keys are the
service provider names. Each of these keys have three mandatory values:
dllname
vendor_name
version
HKEY_USERS
Default or
User ID
XFS
LOGICAL_SERVICES
LS
Info 1
LS
Info N
Beneath the LOGICAL_SERVICE keys there are keys for each individual service provider the keys are the
logical service names: Each of these keys have two mandatory values:
class
the service class of the logical service; (see the Service Class Definition
Document for the standard values)
provider
the name of the service provider that provides the logical service
(the key name of the corresponding service provider key)
The User Id key is only applicable to the Windows Terminal Server platform. The User Id is the user name
associated with the session in which the application is executing.
An example of the content of the configuration information for an actual system in exported REGEDIT form is
shown below. See Section 7 for the definitions of the configuration functions.
REGEDIT4
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS]
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS\XFS_MANAGER]
"TraceFile"="C:\\XFSTRACE.LOG"
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS\PHYSICAL_SERVICES]
Page 25
CWA 14050-1:2000
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS\SERVICE_PROVIDERS]
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS\SERVICE_PROVIDERS\IBM4722]
"dllname"="IBM4722.DLL"
"vendor_name"="XFS Solutions Provider"
"version"="1.0.0"
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS\SERVICE_PROVIDERS\IBM4777]
"dllname"="IBM4777.DLL"
"vendor_name"="XFS Solutions Provider"
"version"="1.0.0"
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS\SERVICE_PROVIDERS\IBM4778]
"dllname"="IBM4778.DLL"
"vendor_name"="XFS Solutions Provoder"
"version"="1.0.0"
[HKEY_LOCAL_MACHINE\SOFTWARE\XFS\SERVICE_PROVIDERS\IBM4733]
"dllname"="IBM4733.DLL"
"vendor_name"="XFS Solutions Provider"
"version"="1.0.0"
[HKEY_USERS\.Default\XFS\LOGICAL_SERVICES]
[HKEY_USERS\.Default\XFS\LOGICAL_SERVICES\CashDispenser]
"class"="ATS"
"provider"="IBM4733"
[HKEY_USERS\.Default\XFS\LOGICAL_SERVICES\Document]
"class"="PTR"
"provider"="IBM4722"
[HKEY_USERS\.Default\XFS\LOGICAL_SERVICES\Magstripe]
"class"="IDC"
"provider"="IBM4777"
[HKEY_USERS\.Default\XFS\LOGICAL_SERVICES\Passbook]
"class"="PTR"
"provider"="IBM4722"
[HKEY_USERS\.Default\XFS\LOGICAL_SERVICES\Pinpad]
"class"="PIN"
"provider"="IBM4778"
[HKEY_USERS\.Default\XFS\LOGICAL_SERVICES\Receipt]
"class"="PTR"
"provider"="IBM4722"
Page 26
CWA 14050-1:2000
4.8
This section describes how application access to services and devices is handled by XFS subsystems, using the
lock facility. It discusses the meaning of timers within the context of a lock request and issues that arise when
multiple applications have issued lock requests. It also describes how requests that were submitted to the service
provider prior to a lock request are managed. Furthermore, it describes how compound devices (physical devices
that include two or more logical devices, such as a passbook printer that also includes a magnetic stripe reader)
are handled.
Typically, an application requires exclusive access to a particular service when it is about to utilize it,
particularly in combination with other services. For example, an application may need to use a PIN pad,
magnetic stripe reader, receipt printer and journal printer to complete a transaction. The application must be
guaranteed that it has access to all the devices before starting on the transaction, and that no other application
will be able to use them until the transaction is complete and it has explicitly released them. This is
accomplished by using the WFSLock (or WFSAsyncLock) function and the complementary WFSUnlock
function.
An application should act in a cooperative manner when locking a service, by keeping it locked for the minimum
time period that it requires exclusive access to the service. Typically, this means locking a set of services,
performing a series of requests to the services to complete a transaction, and immediately unlocking the services.
However, an application which has obtained a lock on a device will be informed via the
WFS_SYSE_LOCK_REQUESTED system event whenever another application requests a lock on the device
(i.e. Potentially multiple lock request events will occur one for each request by another application). Therefore
an alternative strategy is for the application to register for system events and unlock the device only when it
receives the event notification that another application has requested a lock on the device.
Applications must use appropriate techniques to avoid deadlock when locking multiple services, typically by
making use of the timeout parameter in the lock functions.
Also, note that there are cases in which exclusive access is not a requirement, so that it is not always required
that an application lock a service before issuing execute operations to it.
The lock policy describes the rules that services use in managing lock requests. In the description of this policy,
XFS requests are categorized into three types:
Non-deferred: Requests that can be processed completely by a service as soon as they arrive (e.g.,
WFPOpen, WFPRegister and most WFPGetInfo calls.
Deferred: Requests which may not be able to be processed completely as soon as they arrive, typically
because they require hardware and/or operator interaction (e.g., WFPExecute and some WFPGetInfo
calls).
The lock policy is described first for independent devices, i.e., logical services that correspond to devices whose
operation is not interdependent with any other (even though they may be housed in the same physical enclosure).
The following section describes the special requirements involved in managing compound interdependent
devices.
4.8.1
The following describes how the categories of requests are handled, in each of the lock states of a service. Note
that although the description refers to queues and other implied implementation characteristics, this is only for
convenience; no particular implementation techniques are required.
Service state: UNLOCKED
Deferred requests are placed in the deferred queue and processed FIFO.
Page 27
CWA 14050-1:2000
All requests in the deferred queue that arrived before the pending lock request are processed FIFO;
after all are processed, the the lock queue is processed. Note that depending on the nature of the
service/device, lock requests may be granted FIFO or in some other order, e.g., when an operator takes
an action such as pressing a station button.
When a WFPUnlock or WFPClose request is processed from the deferred queue, or the connection
between the service and the owner of the lock is lost:
If the lock queue is not empty, the service state changes to LOCK_PENDING.
If the lock queue is empty, the service state changes to UNLOCKED.
Note that most requests include a timeout parameter which must be managed appropriately, i.e., when the
specified time expires, the request is rejected with the error code WFS_ERR_TIMEOUT. The timeout parameter
is particularly important with the WFSLock request, since it allows applications to set a maximum time to wait
for a lock to be granted, to allow prevention of deadlock situations when requesting locks of multiple devices.
4.8.2
Compound Devices
Compound devices are very common in the financial services industry. For the purposes of this discussion, there
are three types of compound devices:
Two or more separate logical devices that share a physical housing (or perhaps some other attribute), but
function completely independently of one another
Two or more distinct logical devices that are functionally interdependent in some way, such as a journal
printer and passbook printer that use the same print head mechanism
Two or more logical devices that are simply different logical views of a single physical device, such as a
single printer that is managed as two separate logical devices, a document printer and a passbook printer
The first of these types has no special significance from the XFS point of view. Each of the devices is managed
as a separate logical and physical device, and the system configuration issues (e.g., making sure that devices that
are packaged together are assigned to the same workstation) are left to application utilities outside the scope of
this specification.
Page 28
CWA 14050-1:2000
The latter two types are treated identically in an XFS system. When any one of a set of interdependent logical
devices that forms a compound device is locked, all the other logical devices in that compound device are also
implicitly locked on behalf of the requesting application. (The specific policy is described below.) If the same
application (see the discussion of application identity below and in Section 3.5) explicitly requests a lock of
another of these logical devices, the lock is granted. In order to allow the application to know that the devices
are part of a compound device, and therefore interdependent, the WFSLock function returns an array of service
handles, defining the set of other devices within the compound device that are now explicitly locked by the
application. This allows the application to manage its use of these devices accordingly. Normally, it must use
them in a strictly sequential manner to avoid any possible conflicts, but if it has some special knowledge of how
the devices are related, it may be able to multiplex requests in some ways.
Note that an application can also determine whether a device is compound by using the device capabilities query
function of WFSGetInfo.
There are many different ways in which programmers can make use of multiple threads and/or processes in
financial applications. Each XFS service can be controlled from its own thread; all services can be controlled
from a single thread, with other threads/processes used for other application functions; several identical threads
can handle all open services as needed; etc. In some of these models, the user of a service could be considered
to be the process as a whole; in other models, the user is a single thread. The XFS design allows for both
models by providing the programmer the capability to explicitly control the identity of an application. The
programmer can make all the threads in a process appear to a service provider as one application, identify each
thread as a different application, or create some hybrid of these approaches, allowing interdependent
compound devices to be managed correctly no matter what application architecture is used.
In order to allow this flexibility in application architecture, the identity of an application can optionally be
managed explicitly using the concept of application handles. An application handle (hApp) is created using the
WFSCreateAppHandle function, and is guaranteed unique within the system. The WFSOpen function takes an
optional application handle parameter which is bound to the service handle (hService) returned by the open
function. This approach allows applications that use interdependent compound devices to be implemented with
any combination of single or multiple processes and/or threads, by explicitly managing an appropriate set of
application handles. If this facility is not used (indicated by the application using the value
WFS_DEFAULT_HAPP for the hApp parameter in WFSOpen), the XFS subsystem automatically treats each
process as having a single, unique application handle. See Section 3.5 for additional discussion of this topic.
The lock policy for interdependent compound devices uses the same rules as for independent devices, with some
additional constraints. In order to synchronize access via multiple logical services to a single physical device, or
to interdependent devices, the service manages a single lock queue and a single deferred queue for the set of
related logical services. The additional constraints are:
Service state: LOCK_PENDING
When a lock request has been granted to one of a set of related logical services:
All the other related services in the set change to a reserved state in which they are treated as
being in the LOCKED state for requests not from the owner.
Any lock request from the owner for one of the reserved services is granted on arrival.
Lock requests that are not from the owner of the reserved devices are placed in the lock queue.
Page 29
CWA 14050-1:2000
4.9
Timeout
There are two fundamentally different time domains in a system, each having a different implication on the
concept of timeout:
user time = real time; timeout here says simply this job is taking too long as defined by the application
and/or the user (indicated by a WFS_ERR_TIMEOUT error code)
service time = the time taken by the service request within the service; typically, the physical device
operation (indicated by WFS_ERR_DEV_NOT_READY or WFS_ERR_HARDWARE_ERROR error
code)
In XFS systems, the service manages the latter, without needing any input from the application, since it knows
the charactistics of the device, and can generate a timeout event if the device takes too long, even if the
application timeout value (if any) has not been exceeded. Therefore, the timeout value provided in the API is
treated by the service provider as user/real time. If the time is exceeded, the service provider cancels the request
and returns a timeout event to the application. An application can also specify that a request should wait until
completion, no matter how long the request takes, by specifying the special value WFS_INDEFINITE_WAIT.
Page 30
CWA 14050-1:2000
4.10
When an XFS API or SPI function call completes, it returns a value that either defines the completion status, or
in the case of asynchronous functions, the status of the initial processing of the request. When an asynchronous
function completes, the completion message includes the final status of the request. The return value of most
functions is a result handle, hResult, of type HRESULT. hResult values are defined to be WFS_SUCCESS
(zero) for success; other values indicate the specific error that occurred, as defined in each function specification.
The XFS Manager and the service providers return status from a function call, in the form of an hResult result
handle, in two manners:
By posting a completion message to the window specified in the request. The message contains a pointer to
a structure that includes the hResult.
Immediate API
The XFS Manager processes the request, and immediately returns a result handle. In some cases, the XFS
Manager calls the service provider to process the request, then returns the result handle from the service
provider to the application.
Asynchronous API
Since the processing is performed in a number of steps, as described earlier, return status is generated at a
number of levels:
The service provider performs any validations which can be processed immediately.
If an error is detected, the service provider returns the hResult to the XFS Manager, which immediately
returns it to the application.
Otherwise, the request is scheduled and an hResult of WFS_SUCCESS is immediately returned to the
XFS Manager, which immediately returns it to the application. This informs the application that the
request has been accepted and is being processed.
Upon completion of the deferred request, a completion message is posted to the application's window.
This message points to the structure that includes the hResult indicating the completion status of the
request.
Synchronous API
Since a synchronous API call is translated by the XFS Manager to an asynchronous SPI, the service
provider behaves the same as in asynchronous API processing. Specifically, the service provider
performs any validations which can be processed immediately.
If an error is detected, the service provider returns the hResult to the XFS Manager, which immediately
returns it to the application.
Otherwise, the request is scheduled and an hResult of WFS_SUCCESS is immediately returned to the
XFS Manager, indicating that the request has been accepted and is being processed.
Upon completion of the deferred request, a completion message is posted to the XFS Manager window.
The XFS Manager retrieves the hResult from the structure pointed to by the message and returns it to
the application.
Page 31
CWA 14050-1:2000
4.11
The WFSRegister and WFSDeregister functions (and their asynchronous counterparts) are used to register and
deregister the window procedures which are to receive Windows messages when particular unsolicited,
asynchronous events occur, either during request processing or at other times. In other words, they are used to
enable or disable the reception of event notifications. By providing notifications of this type to applications, the
requirement to poll for status is removed, and a simple method for implementing "monitoring" applications is
provided. Each WFSRegister call specifies a service handle (hService), one or more event classes, and an
application window handle (hWnd) which is to receive all the messages of the specified class(es). The
corresponding SPI functions, WFPRegister and WFPDeregister, implement the API functions.
There are four classes of events:
SERVICE_EVENTS
USER_EVENTS
SYSTEM_EVENTS
EXECUTE_EVENTS
For the first three of these event classes, if a class is being monitored and an event occurs in that class, a message
is broadcast to every hWnd registered for that class, specifying the service identified by the hService handle. The
exception to this is the WFS_SYSE_LOCK_REQUESTED system event, this event is posted only to the
application which owns the lock on the device. The events are generated when:
the service status changes (SERVICE_EVENTS), e.g., a printer is suspended or is no
longer available.
the service needs an operation from the user to take place (USER_EVENTS), e.g., a
device needs abnormal attention, such as adding paper or toner to a printer.
a system event occurs (SYSTEM_EVENTS), e.g., a hardware error occurs, a version
negotiation fails, the network is no longer available or there is no more disk space.
The EXECUTE_EVENTS class is different from the other three. These are events which occur as a normal part
of processing an WFSExecute command and they are always sent before the completion of the command.
Examples include the need to interact with the user or operator to request an action such as inserting a passbook
into a printer, swiping a mag stripe card, etc. A message generated by one of these events is sent only to the
application that issued the WFSExecute that caused the event, even though other applications are registered for
EXECUTE_EVENTS. Note that an application must explicitly register for these events; if it has not, and such an
event occurs, the event is not deliverable and the WFSExecute completes normally.
The logic of WFSRegister is cumulative: for a given service the number of notification messages sent may be
increased by specifying additional event classes. Since the XFS Manager does not keep track of what events the
application is registered for and the logic of the register/deregister mechanism is cumulative, the service
providers are responsible for implementing the logic of this process.
An application requests registration for more than one event class in a single call by using a logical OR:
hr = WFSRegister( hService,USER_EVENTS|SERVICE_EVENTS,hWnd );
Note that services always monitor their resources, regardless of whether any application has registered for event
monitoring or not. Issuing WFSRegister simply causes a service to send notifications to the service provider,
which, in turn, sends notifications to one or more applications.
To communicate to the XFS Manager that it no longer wishes to receive messages in one or more event classes,
an application can cancel any previous registration using the WFSDeregister function. The logic of
WFSRegister and WFSDeregister is symmetric: the application can deregister one or more classes of events
monitored for each window, by properly specifying them in the parameter list. To deregister completely (e.g.,
every event class for every window), an application uses NULL event class and window handle values in the
parameter list.
Although the WFSDeregister takes effect immediately, it is possible that messages may be waiting in the
application's message queue. A robust application must therefore be prepared to receive event messages even
after deregistration.
Page 32
CWA 14050-1:2000
Note that an event notification message always passes the information describing the event to an application by
pointing to a WFSRESULT data structure. After the application has used the data in the structure, it must free
the memory that the service provider allocated for the WFSRESULT data structure, using the WFSFreeResult
function.
Page 33
CWA 14050-1:2000
4.12
An application process contains one or more threads of execution. The XFS interface is designed to work in both
the single-threaded versions of the Windows operating systems (Windows 3.1 and Windows for Workgroups)
and in the multi-threaded versions of Windows (Windows NT and future versions of Windows). All references
to threads in this document refer to actual threads in multi-threaded Windows environments. In single-threaded
environments, thread is synonymous with process.
Within the XFS Manager, a blocking (synchronous) function is handled as follows: The XFS Manager initiates
the operation, and then enters a loop in which it dispatches any Windows messages (thus yielding the processor
to other applications as necessary) and checks for the completion of the operation. When the operation
completes, or WFSCancelBlockingCall is invoked, the blocking operation completes with an appropriate result.
When a Windows message is received for a thread for which a blocking operation is in progress, the thread is not
permitted to issue any XFS calls during the processing of the message, other than the two specific functions
provided to assist the programmer in this situation:
WFSIsBlocking determines whether or not a blocking call is in progress.
WFSCancelBlockingCall cancels a blocking call in progress.
Any other XFS function called when a blocking call is in progress fails with the error
WFS_ERR_OP_IN_PROGRESS. This restriction applies to requests for both blocking and non-blocking
operations.
Although this mechanism is sufficient for simple applications, it cannot support those applications which require
more complex message processing while blocked for a synchronous call, such as processing messages relating to
MDI (multiple document interface) events, accelerator key translations, and modeless dialogs. For such
applications, the XFS API includes the function WFSSetBlockingHook, which allows the programmer to define
a special routine which will be called instead of the default message dispatch routine described above. This
function gives an application the ability to execute its own routine at blocking time in place of the default
routine. It is not intended as a mechanism for performing general application functions while blocked; it is still
true that the only XFS functions that may be called from a blocking routine are WFSIsBlocking and
WFSCancelBlockingCall. The asynchronous versions of the XFS functions must be used to allow an
application to continue processing while an operation is in progress.
This mechanism is provided to allow a Windows 3.x or Windows for Workgroups application to make blocking
calls without blocking the rest of the system. Under Windows NT and future multi-threaded, preemptive versions
of Windows, the default blocking action is to suspend the calling application's thread until the request completes.
This is because the system is not blocked by a single application waiting for an operation to complete, and hence
not calling PeekMessage or GetMessage, which are required in the non-preemptive systems in order to cause
the application to yield control.
Therefore, if a single-threaded application is targeted at both single- and multi-threaded environments, and relies
on this functionality, it should install a specific blocking hook by calling WFSSetBlockingHook, even if the
default hook would suffice. This maximizes the portability of applications that depend on the blocking hook
behavior. Programmers who are constrained to use blocking modefor example, as part of an existing
application which is being portedshould be aware of the semantics of blocking operations.
In the XFS implementation in a single-threaded environment, the blocking function operates as follows. When an
application requests a blocking XFS API function, the XFS Manager initiates the requested function and then
enters a loop which is equivalent to the following pseudocode:
for(;;) {
/* flush messages for good user response */
DefaultBlockingHook();
/* check for WFSCancelBlockingCall() */
if( operation_cancelled() )
break;
/* check to see if operation completed */
if( operation_complete() )
break;
/* normal completion */
}
Page 34
CWA 14050-1:2000
The DefaultBlockingHook routine is equivalent to:
BOOL DefaultBlockingHook(void) {
MSG msg;
BOOL ret;
/* Wait for the next message */
ret = GetMessage(&msg, NULL, 0, 0);
if( (int) ret != -1 ) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
/* FALSE if we got a WM_QUIT message */
return( ret );
}
In a multi-threaded environment, the developer of a multi-threaded application must be aware that it is the
responsibility of the application, not the XFS Manager, to synchronize access to a service by multiple threads.
Failure to synchronize calls to a service leads to unpredictable results; for example, if two threads
"simultaneously" issue WFSExecute requests to send data to the same service, there is no guarantee as to the
order in which the data is sent. This is true in general; the application is responsible for coordinating access by
multiple threads to any object (e.g., other forms of I/O, such as file I/O), using appropriate synchronization
mechanisms. The XFS Manager can not, and will not, address these issues. The possible consequences of failing
to observe these rules are beyond the scope of this specification.
In order to allow maximum flexibility in the design and implementation of applications, especially in multithreaded environments, the concept of "application identity" can optionally be managed explicitly by the
application developer using the concept of application handles. See Sections 3.5 and 3.8.2 for additional
discussion of this concept.
Page 35
CWA 14050-1:2000
4.13
Every XFS application should open a session with the VDM ServiceProvider passing a valid ApplId
and then register for all VDM entry and exit notices.
Before opening any session with any other XFS Service Provider, check the status of the
VDM Service Provider. If Vendor Dependent Mode is not Inactive, do not open a
session.
When getting a VDM entry notice, close all open sessions with all other XFS Service Providers as soon
as possible and issue an acknowledgement for the entry to VDM.
When getting a VDM exited notice, re-open any required sessions with other XFS Service Providers.
Page 36
CWA 14050-1:2000
4.14
Memory Management
XFS specifies a protocol for dynamic allocation and release of memory. The general strategy is that the service
providers allocate memory as they need it, and the applications specify when it can be released. This is
implemented using a standard structure (WFSRESULT, defined in Section 8.1) that is always used to pass
information to the applications from the services.
Most service provider function calls are asynchronous, and return their results via a completion message, which
contains a pointer to a WFSRESULT structure, containing the function return status (hResult) and optional data.
The service provider allocates the memory for this structure, using the memory management framework
described below. The deallocation of the structure is done as follows:
Four functions are provided by the XFS Manager to implement this protocol: WFMAllocateBuffer,
WFMAllocateMore, WFMFreeBuffer, and WFSFreeResult. Using these functions, two widely applicable
allocation policies are supported:
a linear allocation policy
a linked allocation policy
Linear allocation can be used for any flat or contiguously allocated data structure. Such structures are returned
in a single block of allocated memory by the WFMAllocateBuffer function.
Linked allocation can be used as an efficient way of managing complex data structures, permitting the service
provider some flexibility while allowing the application to release the entire structure with a single call. In cases
in which the service provider does not know a priori the size of the result data set, it makes an initial estimate,
and uses WFMAllocateBuffer. If the service provider later determines that more space is required by the data,
new memory is requested using the function WFMAllocateMore, and is automatically linked to the originally
allocated block. The new memory block returned by WFMAllocateMore is, in general, not contiguous with the
root block, and the user of this function should behave in all circumstances as if it is not.
The service provider is free to choose whatever allocation granularity is most convenient. This is completely
transparent to the application or XFS Manager, which frees the entire WFSRESULT structure with a single
WFSFreeResult call (the XFS Manager can also use this call as an indication that it can clean up any other
objects associated with the request). Applications must be sure always to free a returned WFSRESULT
structure. Note that a WFSRESULT structure may be returned even if the service provider has returned an error;
if no WFSRESULT is returned, the pointer to the structure is NULL. A service provider may use also this
facility for its "private" memory management requirements; it then uses the WFMFreeBuffer support function
to free the allocated memory.
NOTE:
Applications and service providers must use the facilities provided by the XFS Manager for XFSrelated memory allocation and deallocation, in order to avoid memory management conflicts
among the applications, the XFS Manager and the service providers.
Page 37
CWA 14050-1:2000
The following example illustrates how a service provider dynamically allocates a WFSRESULT buffer structure
and an additional data buffer. Note that WFMAllocateMore automatically links these, allowing the application
to free both structures with a single call.
WFSRESULT *
lpResultBuffer;
Once the application has retrieved all the information it needs from the WFSRESULT buffer and any associated
structures, it must free the memory, which requires only a single call:
NOTE:
When an application invokes an asynchronous or immediate (i.e., non-blocking) function which
takes a pointer to a memory object as an argument, it is the responsibility of the service provider to
ensure that it no longer needs access to the object before returning control to the application. This
allows the application to release (deallocate) the memory object immediately upon the return from
the call.
Page 38
CWA 14050-1:2000
5.
Page 39
CWA 14050-1:2000
The table below summarizes the XFS API functions, and the sections in which they are defined.
Section
Function
Mode
Description
4.1
WFSCancelAsyncRequest
Immediate
4.2
WFSCancelBlockingCall
Immediate
4.3
WFSCleanUp
Synchronous
4.4
WFSClose
Synchronous
4.5
WFSAsyncClose
Asynchronous
4.6
WFSCreateAppHandle
Immediate
4.7
WFSDeregister
Synchronous
4.8
WFSAsyncDeregister
Asynchronous
4.9
WFSDestroyAppHandle
Immediate
4.10
WFSExecute
Synchronous
4.11
WFSAsyncExecute
Asynchronous
4.12
WFSFreeResult
Immediate
4.13
WFSGetInfo
Synchronous
4.14
WFSAsyncGetInfo
Asynchronous
4.16
WFSIsBlocking
Immediate
4.17
WFSLock
Synchronous
4.18
WFSAsyncLock
Asynchronous
4.19
WFSOpen
Synchronous
4.20
WFSAsyncOpen
Asynchronous
4.21
WFSRegister
Synchronous
4.22
WFSAsyncRegister
Asynchronous
4.23
WFSSetBlockingHook
Immediate
4.24
WFSStartUp
Immediate
4.25
WFSUnhookBlockingHook
Immediate
4.26
WFSUnlock
Synchronous
4.27
WFSAsyncUnlock
Asynchronous
Page 40
CWA 14050-1:2000
5.1
WFSCancelAsyncRequest
HRESULT
Cancels the specified (or every) asynchronous request being performed on the specified service, before its (their)
completion.
Parameters
HSERVICE hService
Handle to the service as returned by WFSOpen or WFSAsyncOpen.
REQUESTID RequestID
The request identifier for the request to be canceled, as returned by the original function call
(NULL to cancel all).
Mode
Immediate
Comments
If the RequestID parameter is set to NULL, the command will cancel all asynchronous
requests that are in progress using the specified hService.
A previously initiated asynchronous request is canceled prior to completion by issuing the
WFSCancelAsyncRequest function, specifying the request identifier returned by the
asynchronous function. This function is immediate with respect to its calling application, but
the cancellation process is inherently asynchronous. On completion, the specified request (or
all requests) will have finished, with a completion message indicating a status of
WFS_ERR_CANCELED, unless the cancel request was received by the service after the
request had completed. Thus, WFSCancelAsyncRequest is not guaranteed to stop all
asynchronous commands: normal completion messages may still be posted after the cancel. A
robust application that uses asynchronous commands should be designed to accept these
messages even after a cancel is issued.
The cancellation applies not only to the XFS Manager level, but also to the service provider
level. The request is passed through the SPI, and the service provider normally then also
cancels any physical I/O or other device operation in progress, in the appropriate manner for
the device or service.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_REQ_ID
The RequestID parameter does not correspond to an outstanding request on the service.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See also
WFSAsyncExecute
Page 41
CWA 14050-1:2000
5.2
WFSCancelBlockingCall
HRESULT
WFSCancelBlockingCall( dwThreadID )
DWORD dwThreadID
Identifies the thread for which the blocking operation is to be canceled; a NULL value
indicates the calling thread.
Mode
Immediate
Comments
This function is used to cancel a blocking call (synchronous request) that is in progress. Since
a thread may have only one blocking call in progress at any time, WFSIsBlocking and
WFSCancelBlockingCall are the only XFS functions allowed with respect to a thread when it
has a blocking call in progress.
The application that issued the blocking call receives a WFS_ERR_CANCELED return code if
the operation is successfully canceled.
The cancellation applies not only to the XFS Manager level, but also to the service provider
level. The request is passed through the SPI, and the service provider normally then also
cancels any physical I/O or other device operation in progress, in the appropriate manner for
the device or service.
Note: the cancel request is accepted and is honored as soon as all Windows messages have
been removed from the message queue (i.e. GetMessage returns no more messages). Refer to
WFSSetBlockingHook for more information.
Error Codes
See also
Page 42
CWA 14050-1:2000
5.3
WFSCleanUp
HRESULT
WFSCleanUp( )
None
Mode
Synchronous
Comments
The WFSCleanUp call indicates disconnection of an XFS application from the XFS Manager.
This function, for example, frees resources allocated to the specific application. WFSCleanUp
applies to all threads of a multi-threaded application. If WFSClose has not been issued for one
or more service providers, then the XFS Manager will automatically issue the close(s). Once
the WFSCleanUp has been performed, subsequent attempts to issue any XFS function other
than WFSStartUp will fail.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See also
WFSStartUp
Page 43
CWA 14050-1:2000
5.4
WFSClose
HRESULT
WFSClose( hService )
Terminates a session (a series of service requests initiated with the WFSOpen or WFSAsyncOpen function)
between the application and the specified service. The synchronous version of WFSAsyncClose.
Parameters
HSERVICE hService
The service handle returned by WFSOpen or WFSAsyncOpen. Matches the close request
to the open request, allowing an application to have multiple sessions open simultaneously
with a single service provider.
Mode
Synchronous
Comments
WFSClose directs the service to free all resources associated with the series of requests made
using the hService parameter since the WFSOpen that returned it. If there is a blocking call in
progress the close fails. If the service is locked, the close automatically unlocks it. If no
WFSDeregister has been issued, it is automatically performed.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions. Any
service-specific errors that can be returned are defined in the specifications for each service
class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See also
Page 44
CWA 14050-1:2000
5.5
WFSAsyncClose
HRESULT
Terminates a session (a series of service requests initiated with the WFSOpen or WFSAsyncOpen function)
between the application and the specified service. The asynchronous version of WFSClose.
Parameters
HSERVICE hService
The service handle returned by WFSOpen or WFSAsyncOpen. Matches the close request
to the open request, allowing an application to maintain several "open sessions"
simultaneously.
HWND hWnd
The window handle which is to receive the completion message for this request.
LPREQUESTID lpRequestID
Pointer to the request identifier for this request (returned parameter).
Mode
Asynchronous
Comments
See WFSClose.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
which is pointed to by the completion message. Note that a WFSRESULT structure may be
returned even if the function completes with an error; see Section 3.14.
Messages
WFS_CLOSE_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
The following error condition can be returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
See also
WFSOpen, WFSDeregister
Page 45
CWA 14050-1:2000
5.6
WFSCreateAppHandle
HRESULT
WFSCreateAppHandle( lphApp )
LPHAPP lphApp
A pointer to the application handle to be created (returned parameter).
Mode
Immediate
Comments
This function is used by an application to request a unique (within a single system) application
handle from the XFS Manager (to be used in subsequent WFSOpen/WFSAsyncOpen calls).
Note that an application may call this function multiple times in order to create multiple
application identities for itself with respect to the XFS subsystem. See Sections 3.5 and 3.8.2
for additional discussion.
Error Codes
See also
Page 46
CWA 14050-1:2000
5.7
WFSDeregister
HRESULT
Discontinues monitoring of the specified message class(es) (or all classes) from the specified hService, by the
specified hWndReg (or all the calling application's hWnd's). The synchronous version of WFSAsyncDeregister.
Parameters
HSERVICE hService
Service handle returned by WFSOpen or WFSAsyncOpen. If this value is NULL, and
dwEventClass is SYSTEM_EVENTS, the XFS manager deregisters the application for
those system events generated by the Manager itself.
DWORD dwEventClass
The class(es) of messages from which the application is deregistering. Specified as a bit
mask that can be a logical OR of the values for multiple classes. A NULL value requests that
all message classes be deregistered from the specified window for this hService.
HWND hWndReg
The window which has been previously registered to receive notification messages, and is
now to be deregistered. A NULL value requests that all the application's windows be
deregistered from the specified message class(es) for this hService.
Mode
Synchronous
Comments
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_EVENT_CLASS
The dwEventClass parameter specifies one or more event classes not supported by the
service.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWNDREG
The hWndReg parameter is not a valid window handle.
WFS_ERR_NOT_REGISTERED
The specified hWndReg window was not registered to receive messages for any event
classes.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See also
WFSRegister, WFSClose
Page 47
CWA 14050-1:2000
5.8
WFSAsyncDeregister
HRESULT
Discontinues monitoring of the specified message class(es) (or all classes) from the specified hService, by the
specified hWndReg (or all the calling application's hWnd's). The asynchronous version of WFSDeregister.
Parameters
HSERVICE hService
Service handle returned by WFSOpen or WFSAsyncOpen. If this value is NULL, and
dwEventClass is SYSTEM_EVENTS, the XFS manager deregisters the application for
those system events generated by the Manager itself.
DWORD dwEventClass
The class(es) of events from which the application is deregistering. Specified as a bit mask
that can be a logical OR of the values for multiple classes. A NULL value requests that all
event classes be deregistered from the specified window for this hService.
HWND hWndReg
The window which has been previously registered to receive notification messages, and is
now to be deregistered. A NULL value requests that all the application's windows be
deregistered from the specified message class(es) for this hService.
HWND hWnd
The window handle which is to receive the completion message for this request.
LPREQUESTID lpRequestID
Pointer to the request identifier for this request (returned parameter).
Mode
Asynchronous
Comments
See WFSDeregister.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
which is pointed to by the completion message. Note that a WFSRESULT structure may be
returned even if the function completes with an error; see Section 3.14.
Messages
WFS_DEREGISTER_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_EVENT_CLASS
The dwEventClass parameter specifies one or more event classes not supported by the
service.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_HWNDREG
The hWndReg parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_REGISTERED
The specified hWndReg window was not registered to receive messages for any event
classes.
Page 48
CWA 14050-1:2000
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
See also
WFSRegister, WFSClose
Page 49
CWA 14050-1:2000
5.9
WFSDestroyAppHandle
HRESULT
WFSDestroyAppHandle( hApp )
HAPP hApp
The application handle to be made invalid.
Mode
Immediate
Comments
This function is used by an application to indicate to the XFS Manager that it will no longer
use the specified application handle (from a previous WFSCreateAppHandle call). See
WFSCreateAppHandle and Sections 3.5 and 3.8.2 for additional discussion.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_INVALID_APP_HANDLE
The specified application handle is not valid, i.e., was not created by a preceding create call.
See also
WFSCreateAppHandle
Page 50
CWA 14050-1:2000
5.10
WFSExecute
HRESULT
HSERVICE hService
Handle to the service as returned by WFSOpen or WFSAsyncOpen.
DWORD dwCommand
Command to be executed by the service provider.
LPVOID lpCmdData
Pointer to a command data structure to be passed to the service provider.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
LPWFSRESULT * lppResult
Pointer to the pointer to the result data structure used to return the results of the execution.
The service provider allocates the memory for this structure.
Mode
Synchronous
Comments
This function is used to execute service-specific commands. Each class of service includes a
unique set of commands for the given class of device or service; they are defined in the
service-specific command specifications. Each service provider developer is responsible for
recognizing the complete set of commands for a given class, even if the service provider
doesn't support them all. Each command, for each service class, defines a command data
structure and/or a result data structure. See the separate specifications for each service class for
more discussion of these issues, and the definitions of the service-specific commands and
associated data structures.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
returned by this function. Note that a WFSRESULT structure may be returned even if the
function completes with an error; see Section 3.14.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions. Any
service-specific errors that can be returned are defined in the specifications for each service
class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_COMMAND
The dwCommand issued is not supported by this service class.
WFS_ERR_INVALID_DATA
The data structure passed as input parameter contains invalid data.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 51
CWA 14050-1:2000
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_LOCKED
The service is locked under a different hService.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_UNSUPP_COMMAND
The dwCommand issued, although valid for this service class, is not supported by this
service provider or device.
WFS_ERR_USER_ERROR
A user is preventing proper operation of the device.
WFS_ERR_UNSUPP_DATA
The data structure passed as an input parameter although valid for this service class, is not
supported by this service provider or device.
See Also
WFSAsyncExecute
Page 52
CWA 14050-1:2000
5.11
WFSAsyncExecute
HRESULT
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
DWORD dwCommand
Command to be executed by the service provider.
LPVOID lpCmdData
Pointer to the data structure to be passed to the service provider.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
HWND hWnd
The window handle which is to receive the completion message for this request.
LPREQUESTID lpRequestID
Pointer to the request identifier for this request (returned parameter).
Mode
Asynchronous
Comments
See WFSExecute.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
which is pointed to by the completion message. Note that a WFSRESULT structure may be
returned even if the function completes with an error; see Section 3.14.
Messages
WFS_EXECUTE_COMPLETE
WFS_EXECUTE_EVENT
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_COMMAND
The dwCommand issued is not supported by this service class.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
WFS_ERR_UNSUPP_COMMAND
The dwCommand issued, although valid for this service class, is not supported by this
service provider or device.
Page 53
CWA 14050-1:2000
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_DATA
The data structure passed as input parameter contains invalid data.
WFS_ERR_LOCKED
The service is locked under a different hService.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_UNSUPP_COMMAND
The dwCommand issued, although valid for this service class, is not supported by this
service provider or device.
WFS_ERR_USER_ERROR
A user is preventing proper operation of the device.
WFS_ERR_UNSUPP_DATA
The data structure passed as an input parameter although valid for this service class, is not
supported by this service provider or device.
See Also
WFSCancelAsyncRequest, WFSExecute
Page 54
CWA 14050-1:2000
5.12
WFSFreeResult
HRESULT
WFSFreeResult ( lpResult )
Notifies the XFS Manager that a memory buffer (or linked list of buffers) that was dynamically allocated by a
service provider is to be freed.
Parameters
LPWFSRESULT lpResult
Pointer to a WFSRESULT data structure.
Mode
Immediate
Comments
The XFS service providers may allocate memory to send data to an application. This function
is used by the application to deallocate the memory, and the application must call it when it no
longer needs access to the memory. When the applications calls WFSFreeResult, all memory
allocated by the service provider for this result is deallocated. See Section 3.14.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_RESULT
The lpResult parameter is not a pointer to an allocated WFSRESULT structure.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
See Also
Page 55
CWA 14050-1:2000
5.13
WFSGetInfo
HRESULT
Retrieves information from the specified service provider. The synchronous version of WFSAsyncGetInfo.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
DWORD dwCategory
Specifies the category of the query (e.g., for a printer, WFS_INF_PTR_STATUS to request
status or WFS_INF_PTR_CAPABILITIES to request capabilities). The available categories
depend on the service class, the service provider and the service. The information requested
can be either static or dynamic, e.g., basic service capabilities (static) or current service
status (dynamic).
LPVOID lpQueryDetails
Pointer to the data structure to be passed to the service provider, containing further details to
make the query more precise, e.g., a form name. (Many queries have no input parameters, in
which case this pointer is NULL.)
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
LPWFSRESULT * lppResult
Pointer to the pointer to the data structure to be filled with the result of the execution. The
service provider allocates the memory for the structure.
Mode
Synchronous
Comments
The XFS Manager passes the request to the service provider, and since the information may be
stored remotely, the function cannot be immediate. Note that many requests can be satisfied by
the service provider and will therefore complete immediately.
The definitions of the dwCategory and lpQueryDetails parameters are provided in the servicespecific command sections of this specification. Note that these information retrieval functions
are separate from the other service-specific commands, since those commands can be executed
only via WFSExecute or WFSAsyncExecute, which require that the service be either locked
by the application issuing the command, or unlocked. The GetInfo functions, however, can be
used even when a service is locked by another application.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
which is returned by this function. Note that a WFSRESULT structure may be returned even if
the function completes with an error; see Section 3.14.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions. Any
service-specific errors that can be returned are defined in the specifications for each service
class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
Page 56
CWA 14050-1:2000
WFS_ERR_INVALID_CATEGORY
The dwCategory issued is not supported by this service class.
WFS_ERR_INVALID_DATA
The data structure passed as input parameter contains invalid data.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_UNSUPP_CATEGORY
The dwCategory issued, although valid for this service class, is not supported by this service
provider.
WFS_ERR_USER_ERROR
A user is preventing proper operation of the device.
WFS_ERR_UNSUPP_DATA
The data structure passed as an input parameter although valid for this service class, is not
supported by this service provider or device.
See Also
WFSAsyncGetInfo
Page 57
CWA 14050-1:2000
5.14
WFSAsyncGetInfo
HRESULT
Retrieves information from the specified service provider. The asynchronous version of WFSGetInfo.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
DWORD dwCategory
See WFSGetInfo.
LPVOID lpQueryDetails
See WFSGetInfo.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
HWND hWnd
The window handle which is to receive the completion message for this request.
LPREQUESTID lpRequestID
The request identifier for this request (returned parameter).
Mode
Asynchronous
Comments
See WFSGetInfo. The only difference in the asynchronous version of the function is that the
results (query details) returned to the application (in the WFSRESULT data structure) are
pointed to by the WFS_GETINFO_COMPLETE message sent to the specified hWnd.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
which is pointed to by the completion message. Note that a WFSRESULT structure may be
returned even if the function completes with an error; see Section 3.14.
Messages
WFS_GETINFO_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_CATEGORY
The dwCategory issued is not supported by this service class.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
Page 58
CWA 14050-1:2000
WFS_ERR_UNSUPP_CATEGORY
The dwCategory issued, although valid for this service class, is not supported by this service
provider.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_DATA
The data structure passed as input parameter contains invalid data..
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_USER_ERROR
A user is preventing proper operation of the device.
WFS_ERR_UNSUPP_DATA
The data structure passed as an input parameter although valid for this service class, is not
supported by this service provider or device.
See also
WFSGetInfo, WFSCancelAsyncRequest
Page 59
CWA 14050-1:2000
5.15
WFSIsBlocking
BOOL
WFSIsBlocking( )
None
Return Value
The return value is TRUE if a blocking operation is in progress and FALSE otherwise.
Mode
Immediate
Comments
See also
WFSCancelBlockingCall
Page 60
CWA 14050-1:2000
5.16
WFSLock
HRESULT
Establishes exclusive control by the calling application over the specified service. The synchronous version of
WFSAsyncLock.
Parameters
HSERVICE hService
Service provider handle as returned by WFSOpen or WFSAsyncOpen.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
LPWFSRESULT * lppResult
Pointer to the pointer to a WFSRESULT data structure (see Comments). The service
provider allocates the memory for this structure.
Mode
Synchronous
Comments
A service provider can support a "shared" session, in which multiple applications' data are
mixed in the service's I/O stream. More typically, a session is exclusive at any point in time; all
I/O is for a single application. To define an exclusive use of the service provider, a lock
function (synchronous or asynchronous) must be used. See Section 3.8 for more discussion of
the lock concepts and policy.
The time to complete will depend on whether there is another application that has acquired
exclusive access to the service. Note that trying to lock several services at the same time can
lead to a deadlock. The timeout capability is provided in the API to allow applications to
prevent this.
lppResult is a pointer to a pointer to a WFSRESULT data structure containing a nullterminated array of service handles (hService values), specifying any other services that are
already locked by the application (i.e., under the same hApp) , only if those services are part of
a compound device that includes the service being locked, and are interdependent with it. The
returned pointer is NULL if there are no such "associated" services locked. See Section 3.8.2
for more discussion of this subject.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure, if
there is one. Note that a WFSRESULT structure may be returned even if the function
completes with an error; see Section 3.14.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
Page 61
CWA 14050-1:2000
WFS_ERR_TIMEOUT
The timeout interval expired.
See also
Page 62
CWA 14050-1:2000
5.17
WFSAsyncLock
HRESULT
Establishes exclusive control by the calling application over the specified service. The asynchronous version of
WFSLock.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
HWND hWnd
The window handle which is to receive the completion message for this request.
LPREQUESTID lpRequestID
Pointer to the request identifier for this request (returned parameter).
Mode
Asynchronous
Comments
See WFSLock and Section 3.8.2. In particular, note that if other services are locked as a result
of this call (i.e., because the service specified is part of a compound device), the handles of
these services are returned in the WFSRESULT data structure pointed to by the completion
message.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure.
Note that a WFSRESULT structure may be returned even if the function completes with an
error; see Section 3.14.
Messages
WFS_LOCK_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
Page 63
CWA 14050-1:2000
WFS_ERR_TIMEOUT
The timeout interval expired.
See also
Page 64
CWA 14050-1:2000
5.18
HRESULT
WFSOpen
WFSOpen( lpszLogicalName, hApp, lpszAppID, dwTraceLevel, dwTimeOut,
dwSrvcVersionsRequired, lpSrvcVersion, lpSPIVersion, lphService )
Initiates a session (a series of service requests terminated with the WFSClose function) between the application
and the specified service. This does not necessarily mean that the hardware is opened. This command will return
with WFS_SUCCESS even if the hardware is inoperable, offline or powered off. The status of the device can be
requested through a GetInfo command.
The synchronous version of WFSAsyncOpen.
Parameters
LPSTR lpszLogicalName
Points to a null-terminated string containing the pre-defined logical name of a service. It is a
high level name such as "SYSJOURNAL1," "PASSBOOKPTR3" or "CASHDISP02," that
is used by the XFS Manager and the service provider solely as a key to obtain the specific
configuration information they need.
HAPP hApp
The application handle to be associated with the session being opened. If this parameter is
equal to WFS_DEFAULT_HAPP, the session is associated with the calling process as a
whole (i.e., the calling process, not some subset of its threads, is the owner of the session
and its hService). See WFSCreateAppHandle and Sections 3.5 and 3.8.2 for details.
LPSTR lpszAppID
Points to a null-terminated string containing the application ID; the pointer may be NULL if
the ID is not used. This ID may be used by services in a variety of ways; e.g., it is included
in the SYSTEM_EVENT message for undeliverable events, to aid in finding system
problems
DWORD dwTraceLevel
See WFMSetTraceLevel. NULL turns off all tracing.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
DWORD dwSrvcVersionsRequired
Specifies the range of versions of the service-specific interface that the application can
support. (See Comments.) The low-order word indicates the highest version of the interface
the application can support; the high-order word indicates the lowest version of the interface
the application can support. In each word, the low-order byte specifies the major version
number and the high-order byte specifies the minor version number (i.e., the numbers before
and after the decimal).
Note: in order to allow intermediate minor revisions (e.g., between 1.10 and 1.20), the
minor version number should always be expressed as two decimal digits, i.e., 1.10, 1.11,
1.20, etc.
LPWFSVERSION lpSrvcVersion
Pointer to the data structure that is to receive version support information and other details
about the service-specific interface implementation (returned parameter).
LPWFSVERSION lpSPIVersion
Pointer to the data structure that is to receive version support information and (optionally)
other details about the SPI implementation of the service provider being opened (returned
parameter). This pointer may be NULL if the application is not interested in receiving this
information. See WFPOpen.
LPHSERVICE lphService
Pointer to the service handle that the XFS Manager assigns to the service on a successful
open; the application uses this handle for communication with the service provider for the
remainder of the session (returned parameter). If a process opens the same service twice, the
XFS Manager generates and returns different hService values.
Page 65
CWA 14050-1:2000
Mode
Synchronous
Comments
This function is used by an application to initiate a session with a service; the session is
terminated by WFSClose. After WFSStartUp, an application must use this function (or the
asynchronous version) to access a service. The request is made in terms of a logical service
name (lpLogicalName) which is mapped by the XFS Manager to a service provider. The XFS
Manager loads the service provider, if necessary, and returns a logical service handle to the
application which is used during the session to refer to the service.
In order to support future XFS implementations with maximum flexibility, two version
negotiations take place in WFSOpen processing. An application specifies in the
dwSrvcVersionsRequired parameter the range of versions of the service-specific interface (as
defined in the separate XFS specifications for specific classes of devices, such as banking
printers and cash dispensers) that it can support. If the range of versions specified by the
application overlaps the range of versions that the service providers implementation can
support, the call succeeds. Otherwise the call fails. (The other negotiation that takes place
during the open process is between the XFS Manager and the service provider regarding the
SPI level. See WFPOpen for details.)
Information describing the actual service provider implementation is returned in the
WFSVERSION data structure (defined in Section 8.2). In particular, it returns the version the
service provider expects the application to use (the highest common version), as well as the
lowest and highest versions it is capable of. If the call fails, WFSVERSION is still returned, to
help with analysis of the failure.
The version numbers refer to the complete interface specification: the service-specific
WFSExecute and WFSGetInfo commands, parameters, data structures, error codes, and
messages. If there are any changes to these, the version number should be changed.
This version negotiation allows an XFS application and a service provider to operate
successfully if there is any overlap in their versions. The following chart gives examples of
how WFSOpen works in conjunction with different application and service provider versions:
Application
version(s)
1.00
1.00 - 2.10
1.11
2.11 - 3.00
1.00
1.11 - 3.00
Service Provider
version(s)
1.00
1.00
1.00 - 2.00
1.00 - 2.20
2.20 - 3.00
1.00
Result
WFS_SUCCESS
WFS_SUCCESS
WFS_SUCCESS
WFS_SUCCESS
WFS_ERR_SRVC_VERS_TOO_LOW
WFS_ERR_SRVC_VERS_TOO_HIGH
use 1.00
use 1.00
use 1.11
use 2.20
fails
fails
Note that a version negotiation error also generates a system event (see Section 9.7).
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_APP_HANDLE
The specified application handle is not valid, i.e., was not created by a preceding create call.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_INVALID_SERVPROV
The file containing the service provider is invalid or corrupted.
WFS_ERR_INVALID_TRACELEVEL
The dwTraceLevel parameter does not correspond to a valid trace level or set of levels.
Page 66
CWA 14050-1:2000
WFS_ERR_NO_SERVPROV
The file containing the service provider does not exist.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
WFS_ERR_SERVICE_NOT_FOUND
The logical name is not a valid service provider name.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_SPI_VER_TOO_HIGH
The range of versions of XFS SPI support requested by the XFS Manager is higher than any
supported by the service provider for the logical service being opened.
WFS_ERR_SPI_VER_TOO_LOW
The range of versions of XFS SPI support requested by the a XFS Manager is lower than
any supported by the service provider for the logical service being opened.
WFS_ERR_SRVC_VER_TOO_HIGH
The range of versions of the service-specific interface support requested by the application
(in the dwSrvcVersionsRequired parameter of this call) is higher than any supported by the
service provider for the logical service being opened.
WFS_ERR_SRVC_VER_TOO_LOW
The range of versions of the service-specific interface support requested by the application
(in the dwSrvcVersionsRequired parameter of this call) is lower than any supported by the
service provider for the logical service being opened.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_VERSION_ERROR_IN_SRVC
Within the service, a version mismatch of two modules occurred.
See also
Page 67
CWA 14050-1:2000
5.19
WFSAsyncOpen
HRESULT
Initiates a session (a series of service requests terminated with the WFSClose or WFSAsyncClose function)
between the application and the specified service. This does not necessarily mean that the hardware is opened.
This command will return with WFS_SUCCESS even if the hardware is inoperable, offline or powered off. The
status of the device can be requested through a GetInfo command.
The asynchronous version of WFSOpen.
Parameters
LPSTR lpszLogicalName
See WFSOpen.
HAPP hApp
The application handle to be associated with the session being opened.
See WFSOpen, WFSCreateAppHandle and Sections 4.5 and 4.8.2 for details.
LPSTR lpszAppID
Points to a null-terminated string containing the application ID. See WFSOpen.
DWORD dwTraceLevel
See WFMSetTraceLevel. NULL turns off all tracing.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
LPHSERVICE lphService
Pointer to the service handle (returned parameter).
HWND hWnd
The window handle which is to receive the completion message for this request.
DWORD dwSrvcVersionsRequired
See WFSOpen.
LPWFSVERSION lpSrvcVersion
See WFSOpen (returned parameter).
LPWFSVERSION lpSPIVersion
See WFSOpen (returned parameter).
LPREQUESTID lpRequestID
Pointer to the request identifier for this request (returned parameter).
Mode
Asynchronous
Comments
See WFSOpen.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
which is pointed to by the completion message. Note that a WFSRESULT structure may be
returned even if the function completes with an error; see Section 3.14.
Messages
WFS_OPEN_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
Page 68
CWA 14050-1:2000
WFS_ERR_INVALID_APP_HANDLE
The specified application handle is not valid, i.e., was not created by a preceding create call.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_INVALID_SERVPROV
The file containing the service provider is invalid or corrupted.
WFS_ERR_INVALID_TRACELEVEL
The dwTraceLevel parameter does not correspond to a valid trace level or set of levels.
WFS_ERR_NO_SERVPROV
The file containing the service provider does not exist.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
WFS_ERR_SERVICE_NOT_FOUND
The logical name is not a valid service provider name.
WFS_ERR_SPI_VER_TOO_HIGH
The range of versions of XFS SPI support requested by the XFS Manager is higher than any
supported by the service provider for the logical service being opened.
WFS_ERR_SPI_VER_TOO_LOW
The range of versions of XFS SPI support requested by the a XFS Manager is lower than
any supported by the service provider for the logical service being opened.
WFS_ERR_SRVC_VER_TOO_HIGH
The range of versions of the service-specific interface support requested by the application
(in the dwSrvcVersionsRequired parameter of this call) is higher than any supported by the
service provider for the logical service being opened.
WFS_ERR_SRVC_VER_TOO_LOW
The range of versions of the service-specific interface support requested by the application
(in the dwSrvcVersionsRequired parameter of this call) is lower than any supported by the
service provider for the logical service being opened.
WFS_ERR_VERSION_ERROR_IN_SRVC
Within the service, a version mismatch of two modules occurred.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready timed out.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
Page 69
CWA 14050-1:2000
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_VERSION_ERROR_IN_SRVC
Within the service, a version mismatch of two modules occurred.
See also
Page 70
CWA 14050-1:2000
5.20
WFSRegister
HRESULT
Enables event monitoring for the specified service by the specified window; all messages of the specified
class(es) are sent to the window specified in the hWndReg parameter. The synchronous version of
WFSAsyncRegister.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen. If this value
is NULL, and dwEventClass is SYSTEM_EVENTS, the XFS manager registers the
application for those system events generated by the Manager itself.
DWORD dwEventClass
The class(es) of events for which the application is registering. Specified as a set of bit
masks that are logically ORed together into this parameter.
HWND hWndReg
The window handle which is to be registered to receive the specified messages.
Mode
Synchronous
Comments
Issuing a WFSRegister for a service enables event monitoring on that service. WFSRegister
calls can be cumulative for the same window. For example, to receive notification for both
system and user events, the application can call WFSRegister with both SYSTEM_EVENTS
and USER_EVENTS, as follows:
hr = WFSRegister(hPassbook1, SYSTEM_EVENTS | USER_EVENTS, hWndReg1);
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_EVENT_CLASS
The dwEventClass parameter specifies one or more event classes not supported by the
service.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWNDREG
The hWndReg parameter is not a valid window handle.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
Page 71
CWA 14050-1:2000
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See also
Page 72
CWA 14050-1:2000
5.21
WFSAsyncRegister
HRESULT
Enables event monitoring for the specified service by the specified window; all messages of the specified
class(es) are sent to the window specified in the hWndReg parameter. The asynchronous version of
WFSRegister.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen. If this value
is NULL, and dwEventClass is SYSTEM_EVENTS, the XFS manager registers the
application for those system events generated by the Manager itself.
DWORD dwEventClass
See WFSRegister.
HWND hWndReg
The window handle which is to be registered to receive the specified messages.
HWND hWnd
The window handle which is to receive the completion message for this request.
LPREQUESTID lpRequestID
Pointer to the request identifier for this request (returned parameter).
Mode
Asynchronous
Comments
See WFSRegister.
The application must call WFSFreeResult to deallocate the WFSRESULT data structure
pointed to by the completion message. Note that a WFSRESULT structure may be returned
even if the function completes with an error; see Section 3.14.
Messages
WFS_REGISTER_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_EVENT_CLASS
The dwEventClass parameter specifies one or more event classes not supported by the
service.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_HWNDREG
The hWndReg parameter is not a valid window handle.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
Page 73
CWA 14050-1:2000
The following error conditions can be returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
See also
Page 74
CWA 14050-1:2000
5.22
WFSSetBlockingHook
HRESULT
XFSBLOCKINGHOOK lpBlockFunc
Pointer to the procedure instance address of the blocking routine to be installed.
LPXFSBLOCKINGHOOK
lppPrevFunc
Returned pointer to a pointer to the procedure instance of the previously installed blocking
routine.
Mode
Immediate
Comments
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
See also
Page 75
CWA 14050-1:2000
5.23
HRESULT
WFSStartUp
WFSStartUp( dwVersionsRequired, lpWFSVersion )
DWORD dwVersionsRequired
Specifies the range of versions of the XFS Manager that the application can support. The
low-order word indicates the highest version of the XFS Manager the application can
support; the high-order word indicates the lowest version of the XFS Manager the
application can support. In each word, the low-order byte specifies the major version
number and the high-order byte specifies the minor version number (i.e., the numbers before
and after the decimal).
Note: in order to allow intermediate minor revisions (e.g., between 1.10 and 1.20), the
minor version number should always be expressed as two decimal digits, i.e., 1.10, 1.11,
1.20, etc.
LPWFSVERSION lpWFSVersion
Pointer to the data structure that is to receive version support information and other details
about the current XFS implementation (returned parameter).
Mode
Immediate
Comments
This function is used by an application to register itself with the XFS Manager and specify the
version(s) of the XFS API specification it can use, and returns information on the specific XFS
implementation. It must be the first XFS API function called by an application. An application
may only issue further XFS functions after a successful WFSStartUp has completed.
In order to support future XFS implementations with maximum flexibility, a version
negotiation process takes place in WFSStartUp. An application specifies in the
dwVersionsRequired parameter the range of versions of the XFS API specification which it
can support. If the range of versions specified by the application overlaps the range of versions
that the current implementation of XFS Manager can support, the call succeeds. Otherwise the
call fails.
Information describing the actual XFS implementation is returned by the XFS Manager in the
WFSVERSION data structure (defined in Section 8.2). In particular, it returns the version it
expects the application to use (the highest common version), as well as the lowest and highest
versions it is capable of. If the call fails, WFSVERSION is still returned, to help with analysis
of the failure.
The version numbers refer to the API specification, specifically functions, parameters, data
structures, error codes, and messages. If there are any changes to these, the version number
should be changed.
This version negotiation allows an XFS application and the XFS Manager to operate
successfully if there is any overlap in their versions. The following chart gives examples of
how WFSStartUp works in conjunction with different application and XFS Manager versions:
Application
versions
1.00
1.00 - 2.10
1.11
2.11 - 3.00
1.00
1.11 - 3.00
XFS Manager
versions
1.00
1.00
1.00 - 2.00
1.00 - 2.20
2.20 - 3.00
1.00
Result
WFS_SUCCESS
WFS_SUCCESS
WFS_SUCCESS
WFS_SUCCESS
WFS_ERR_API_VERS_TOO_LOW
WFS_ERR_API_VERS_TOO_HIGH
use 1.00
use 1.00
use 1.11
use 2.20
fails
fails
Note that a version negotiation error also generates a system event (see Section 9.7).
After making its last XFS call, an application must call WFSCleanUp to allow the XFS
Manager to release any resources allocated for the application.
Page 76
CWA 14050-1:2000
Error Codes
The return value indicates whether the application was registered successfully (i.e., the XFS
Manager can support requests from the application). If the function was successful, the
returned value is WFS_SUCCESS; if not, it is one of the following error conditions:
WFS_ERR_ALREADY_STARTED
A WFSStartUp has already been issued by the application, without an intervening
WFSCleanUp.
WFS_ERR_API_VER_TOO_HIGH
The range of versions of XFS API support requested by the application is higher than any
supported by this particular XFS implementation.
WFS_ERR_API_VER_TOO_LOW
The range of versions of XFS API support requested by the application is lower than any
supported by this particular XFS implementation.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
See also
WFSCleanUp
Page 77
CWA 14050-1:2000
5.24
WFSUnhookBlockingHook
HRESULT
WFSUnhookBlockingHook( )
Removes any previous blocking hook that had been installed and reinstalls the default blocking mechanism.
Parameters
None.
Mode
Immediate
Comments
The function will always install the default routine, not the previous routine. If an application
wishes to nest blocking hook routinesi.e., to establish a temporary blocking call and then
revert to the previous mechanismit must save and restore the value returned by the
WFSSetBlockingHook function. See Section 3.12.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See also
WFSSetBlockingHook
Page 78
CWA 14050-1:2000
5.25
WFSUnlock
HRESULT
WFSUnlock( hService )
Releases a service that has been locked by a previous WFSLock or WFSAsyncLock function. The synchronous
version of WFSAsyncUnlock.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
Mode
Synchronous
Comments
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_CANCELED
The request was canceled by WFSCancelBlockingCall.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_NOT_LOCKED
The application requesting a service be unlocked had not previously performed a successful
WFSLock or WFSAsyncLock.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See also
Page 79
CWA 14050-1:2000
5.26
WFSAsyncUnlock
HRESULT
Releases a service that has been locked by a previous WFSLock or WFSAsyncLock function. The
asynchronous version of WFSUnlock.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
HWND hWnd
The window handle which is to receive the completion message for this request.
LPREQUESTID lpRequestID
Pointer to the request identifier for this request (returned parameter).
Mode
Aynchronous
Comments
Messages
WFS_UNLOCK_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure:
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_NOT_LOCKED
The application requesting a service be unlocked had not previously performed a successful
WFSLock or WFSAsyncLock.
See also
Page 80
CWA 14050-1:2000
6.
The service provider functions are described in the following sections, in alphabetical order. The table below
shows the SPI functions, the sections in which they are defined, their modes, and the API functions they
implement.
Sectio
n
XFS SPI
Mode
XFS API
Mode
5.1
WFPCancelAsyncRequest
Immediate
WFSCancelAsyncRequest
Immediate
5.1
WFPCancelAsyncRequest
Immediate
WFSCancelBlockingCall
Immediate
(none)
WFSCleanUp
Synchronous
5.2
WFPClose
Asynchronous
WFSClose
Synchronous
5.2
WFPClose
Asynchronous
WFSAsyncClose
Asynchronous
(none)
WFSCreateAppHandle
Immediate
5.3
WFPDeregister
Asynchronous
WFSDeregister
Synchronous
5.3
WFPDeregister
Asynchronous
WFSAsyncDeregister
Asynchronous
(none)
WFSDestroyAppHandle
Immediate
5.4
WFPExecute
Asynchronous
WFSExecute
Synchronous
5.4
WFPExecute
Asynchronous
WFSAsyncExecute
Asynchronous
(none)
WFSFreeResult
Immediate
5.5
WFPGetInfo
Asynchronous
WFSGetInfo
Synchronous
5.5
WFPGetInfo
Asynchronous
WFSAsyncGetInfo
Asynchronous
(none)
WFSIsBlocking
Immediate
5.6
WFPLock
Asynchronous
WFSLock
Synchronous
5.6
WFPLock
Asynchronous
WFSAsyncLock
Asynchronous
5.7
WFPOpen
Asynchronous
WFSOpen
Synchronous
5.7
WFPOpen
Asynchronous
WFSAsyncOpen
Asynchronous
5.8
WFPRegister
Asynchronous
WFSRegister
Synchronous
5.8
WFPRegister
Asynchronous
WFSAsyncRegister
Asynchronous
(none)
WFSSetBlockingHook
Immediate
WFPSetTraceLevel
Immediate
(none)
(none)
WFSStartUp
Immediate
(none)
WFSUnhookBlockingHook
Immediate
5.9
5.10
WFPUnloadService
5.11
WFPUnlock
Asynchronous
WFSUnlock
Synchronous.
5.11
WFPUnlock
Asynchronous
WFSAsyncUnlock
Asynchronous
Note that in this section device drivers and devices are mentioned frequently, instead of service providers and
services. This is due primarily to the fact that access to financial peripheral devices is the first category of
financial services being addressed by the BSVC. However, note that in the future other financial services will be
part of the Extensions to Financial Services, and will also use these interfaces, with additions as necessary. See
Appendix A for more on this subject.
Page 81
CWA 14050-1:2000
6.1
WFPCancelAsyncRequest
HRESULT
Cancels the specified (or every) asynchronous request being performed on the specified service provider, before
its (their) completion.
Parameters
HSERVICE hService
Handle to the service provider.
REQUESTID RequestID
The request identifier (NULL to cancel all requests for the specified hService).
Mode
Comments
If the RequestID parameter is set to NULL, the command will cancel all asynchronous
requests on the specified service that are in progress on behalf of the calling application.
A previously initiated asynchronous request is canceled prior to completion by issuing the
WFSCancelAsyncRequest function, specifying the request identifier returned by the
asynchronous function. This function is immediate with respect to its calling application, but
the cancellation process is inherently asynchronous. On completion, the specified request (or
all the requests) will have finished, with a completion message indicating a status of
WFS_ERR_CANCELED, unless the cancel request was made after the request had completed.
The cancellation applies to the service provider level. The request is passed through the SPI,
and the service provider normally then also cancels any physical I/O or other device operation
in progress, in the appropriate manner for the device or service.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_REQ_ID
The RequestID parameter does not correspond to an outstanding request on the service.
Page 82
CWA 14050-1:2000
6.2
WFPClose
HRESULT
Terminates a session (a series of service requests initiated with the WFPOpen SPI function) between the XFS
Manager and the specified service provider.
Parameters
HSERVICE hService
Handle to the service provider.
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
Mode
Asynchronous
Comments
WFPClose directs the service to free all resources associated with the series of requests made
using the hService parameter. If the service is locked by the application, the close
automatically unlocks it. If no WFPDeregister has been issued, it is automatically performed.
See WFPOpen and Section 3.6 for further discussion.
Messages
WFS_CLOSE_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. The service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
Page 83
CWA 14050-1:2000
6.3
WFPDeregister
HRESULT
Discontinues monitoring of the specified message class(es) from the specified service provider, by the specified
hWndReg (or all hWnd's).
Parameters
HSERVICE hService
Handle to the service provider
DWORD dwEventClass
The class(es) of messages from which the application is deregistering. Specified as a set of
bit masks that can be logically ORed together. A NULL value requests that all message
classes be deregistered from the specified window for this service provider.
HWND hWndReg
The window to which notification messages are posted. A NULL value requests that all the
application's windows be deregistered from the specified message class(es) for this hService.
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
Mode
Asynchronous
Comments
WFPDeregister does not stop asynchronous command completion messages from being
posted; a robust application should be designed to accept these messages even after a
deregister is issued.
A WFPDeregister os performed automatically if a WFPClose is issued without a previous
WFPDeregister.
To deregister all messages for all hWnds, the call supplies NULL values for both the
dwEventClass and hWnd parameters.
See the WFPRegister function for a description of the types of events that may be monitored.
Messages
WFS_DEREGISTER_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. Any service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_EVENT_CLASS
The dwEventClass parameter specifies one or more event classes not supported by the
service.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_HWNDREG
The hWndReg parameter is not a valid window handle.
WFS_ERR_NOT_REGISTERED
The specified hWndReg window was not registered to receive messages for any event
classes.
Page 84
CWA 14050-1:2000
The following error condition is returned via the asynchronous command completion message,
as the hResult from the WFSRESULT structure. Any service-specific errors that can be
returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
Page 85
CWA 14050-1:2000
6.4
WFPExecute
HRESULT
HSERVICE hService
Handle to the service provider.
DWORD dwCommand
Command to be executed.
LPVOID lpCmdData
Pointer to the data structure to be passed.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
Mode
Asynchronous
Comments
See WFSExecute.
Messages
WFS_EXECUTE_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. Any service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_COMMAND
The dwCommand issued is not supported by this service class.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_UNSUPP_COMMAND
The dwCommand issued, although valid for this service class, is not supported by this
service provider.
Page 86
CWA 14050-1:2000
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INVALID_DATA
The data structure passed as input parameter contains invalid data..
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_LOCKED
The service is locked under a different hService.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_USER_ERROR
A user is preventing proper operation of the device.
WFS_ERR_UNSUPP_DATA
The data structure passed as an input parameter although valid for this service class, is not
supported by this service provider or device.
Page 87
CWA 14050-1:2000
6.5
WFPGetInfo
HRESULT
HSERVICE hService
Handle to the service provider.
DWORD dwCategory
Specifies the category of the query (e.g., for a printer, WFS_INF_PTR_STATUS to request
status or WFS_INF_PTR_CAPABILITIES to request capabilities). The available categories
depend on the service class, the service provider and the service. The information requested
can be either static or dynamic, e.g., basic service capabilities (static) or current service
status (dynamic).
LPVOID lpQueryDetails
Pointer to the data structure to be passed to the service provider, containing further details to
make the query more precise, e.g., a form name. (Many queries have no input parameters, in
which case this pointer is NULL.)
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
Mode
Asynchronous
Comments
The XFS Manager retrieves the information requested from the service provider itself, and,
since the information can be stored remotely, the function cannot be guaranteed to complete
immediately. Note that, typically, requests for generic and class specific categories can
complete immediately. See WFSGetInfo for additional discussion.
The specifications for the information structures for each service class can be found in the
specifications for the service-specific commmands.
Messages
WFS_GETINFO_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. Any service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_CATEGORY
The dwCategory issued is not supported by this service class.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 88
CWA 14050-1:2000
WFS_ERR_UNSUPP_CATEGORY
The dwCategory issued, although valid for this service class, is not supported by this service
provider.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_DATA
The data structure passed as input parameter contains invalid data..
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_USER_ERROR
A user is preventing proper operation of the device.
WFS_ERR_UNSUPP_DATA
The data structure passed as an input parameter although valid for this service class, is not
supported by this service provider or device.
Page 89
CWA 14050-1:2000
6.6
WFPLock
HRESULT
Establishes exclusive control by the calling application over the specified service.
Parameters
HSERVICE hService
Handle to the service provider.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
Mode
Asynchronous
Comments
See WFSLock.
Messages
WFS_LOCK_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. Any service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the
software.
WFS_ERR_TIMEOUT
The timeout interval expired.
Page 90
CWA 14050-1:2000
6.7
WFPOpen
HRESULT
Establishes a connection between the XFS Manager and the service provider that supports the specified service,
and initiates a session (a series of service requests terminated with the WFPClose function).
Parameters
HSERVICE hService
The service handle to be associated with the session being opened..
LPSTR lpszLogicalName
Points to a null-terminated string containing the pre-defined logical name of a service. It is a
high level name such as "SYSJOURNAL1," "PASSBOOKPTR3" or "ATM02," that is used
by the XFS Manager and the service provider as a key to obtain the specific configuration
information they need.
HAPP hApp
The application handle to be associated with the session being opened.
See WFSCreateAppHandle and Sections 3.5 and 3.8.2 for details.
LPSTR lpszAppID
Pointer to a null terminated string containing the application ID; the pointer may be NULL
if the ID is not used.
DWORD dwTraceLevel
See WFPSetTraceLevel.
DWORD dwTimeOut
Number of milliseconds to wait for completion (WFS_INDEFINITE_WAIT to specify a
request that will wait until completion).
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
HPROVIDER hProvider
Service provider handle supplied by the XFS Manager used by the service provider to
identify itself when calling the WFMReleaseDLL function.
DWORD dwSPIVersionsRequired
Specifies the range of XFS SPI versions that the XFS Manager can support. (See
Comments.) The low-order word indicates the highest version the XFS Manager can
support; the high-order word indicates the lowest version the XFS Manager can support. In
each word, the low-order byte specifies the major version number and the high-order byte
specifies the minor version number (i.e., the numbers before and after the decimal).
Note: in order to allow intermediate minor revisions (e.g., between 1.10 and 1.20), the
minor version number should always be expressed as two decimal digits, i.e., 1.10, 1.11,
1.20, etc.
LPWFSVERSION lpSPIVersion
Pointer to the data structure that is to receive SPI version support information and
(optionally) other details about the SPI implementation (returned parameter).
DWORD dwSrvcVersionsRequired
Service-specific interface versions required; see dwSPIVersionsRequired above, and
WFSOpen.
LPWFSVERSION lpSrvcVersion
Pointer to the service-specific interface implementation information; see lpSPIVersion
above, and WFSOpen (returned parameter).
Mode
Asynchronous
Page 91
CWA 14050-1:2000
Comments
This function establishes the connection between the XFS Manager and the service provider,
including version negotiation and passing of implementation information, and initiates a
session between the application and the service. This call is made by the XFS Manager each
time any application issues a WFSOpen or WFSAsyncOpen call to the specified service
(immediately after loading the service provider DLL, if it is not already loaded).
In order to support future XFS implementations with maximum flexibility, two version
negotiations take place in WFPOpen. In the first, the XFS Manager specifies in the
dwSPIVersionsRequired parameter the range of versions of the XFS SPI specification which it
can support. If the range of versions specified by the XFS Manager overlaps the range of
versions that the service provider can support, the call succeeds. Otherwise the call fails.
The WFSVERSION data structure (described in Section 8.2) is used by the service provider to
return the version of SPI support it expects the XFS Manager to use (the highest common
version), as well as the lowest and highest versions it is capable of. In addition, this structure is
used optionally by the XFS Manager to specify other information about the service provider
implementation. If the call fails, WFSVERSION is still returned, to help with analysis of the
failure.
The version numbers refer to the SPI specification, specifically functions, parameters, data
structures, error codes, and messages. If there are any changes to these, the version number
should be changed.
This version negotiation allows the XFS Manager and a service provider to operate
successfully if there is any overlap in their versions. The following chart gives examples of
how WFPOpen works in conjunction with different XFS Manager and service provider
versions:
XFS Manager
versions
1.00
1.00 - 2.10
1.11
2.11 - 3.00
1.00
1.11 - 3.00
Service Provider
versions
1.00
1.00
1.00 - 2.00
1.00 - 2.20
2.20 - 3.00
1.00
Result
WFS_SUCCESS
WFS_SUCCESS
WFS_SUCCESS
WFS_SUCCESS
WFS_ERR_SPI_VER_TOO_LOW
WFS_ERR_SPI_VER_TOO_HIGH
use 1.00
use 1.00
use 1.11
use 2.20
fails
fails
WFS_OPEN_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. Any service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_INVALID_TRACELEVEL
The dwTraceLevel parameter does not correspond to a valid trace level or set of levels.
Page 92
CWA 14050-1:2000
WFS_ERR_SPI_VER_TOO_HIGH
The range of versions of XFS SPI support requested by the XFS Manager is higher than any
supported by this particular service provider.
WFS_ERR_SPI_VER_TOO_LOW
The range of versions of XFS SPI support requested by the XFS Manager is lower than any
supported by this particular service provider.
WFS_ERR_SRVC_VER_TOO_HIGH
The range of versions of the service-specific interface support requested by the application
is higher than any supported by the service provider for the logical service being opened.
WFS_ERR_SRVC_VER_TOO_LOW
The range of versions of the service-specific interface support requested by the application
is lower than any supported by the service provider for the logical service being opened.
WFS_ERR_VERSION_ERROR_IN_SRVC
Within the service, a version mismatch of two modules occurred.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. The service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_VERSION_ERROR_IN_SRVC
Within the service, a version mismatch of two modules occurred.
Page 93
CWA 14050-1:2000
6.8
WFPRegister
HRESULT
Enables event monitoring for the specified service by the specified hWndReg; all events of the specified class(es)
generate messages to the hWndReg.
Parameters
HSERVICE hService
Handle to the service provider.
DWORD dwEventClass
The class(es) of events for which the application is registering. Specified as a set of bit
masks that can be logically ORed together.
HWND hWndReg
The window handle which is to be registered to receive the specified messages.
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
Mode
Asynchronous
Comments
Messages
WFS_REGISTER_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. Any service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_EVENT_CLASS
The dwEventClass parameter specifies one or more event classes not supported by the
service.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_HWNDREG
The hWndReg parameter is not a valid window handle.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
Page 94
CWA 14050-1:2000
6.9
WFPSetTraceLevel
HRESULT
Sets the specified trace level(s) at run time, in and/or below the service provider. See WFMSetTraceLevel.
Parameters
HSERVICE hService
Handle to the service provider.
DWORD dwTraceLevel
The level(s) of tracing being requested. See below.
Mode
Immediate
Comments
Issuing WFPSetTraceLevel for a service enables tracing on that service at various levels. The
predefined trace levels that can be used in this function, with their meanings to the service
provider, are as follows (see WFMSetTraceLevel for the API and support function trace
levels):
WFS_TRACE_SPI 0x00000004
Trace all the SPI calls to the service provider, and notification and event messages generated
by the service provider, that are associated with the specified hService.
WFS_TRACE_ALL_SPI
0x00000008
Trace all SPI, notification and event activity of the service provider (the hService parameter
is not relevant to this trace level).
Other standard trace levels may be defined in the future, and a range of trace level values (the
high order 16 bits of this parameter) is reserved for use by individual service providers.
Example of other functions that may be traced include network messages, interactions between
the service provider and service, and device interface interaction.
Trace level values can be ORed together in a single dwTraceLevel parameter to request more
than one kind of tracing be started. A NULL value stops all tracing in the service provider.
If more than one process may be using the trace facility, this function should always be
preceded with the WFMGetTraceLevel function. This value returned by this function is
ORed together with the new trace level(s), and the resulting value is used with
WFMSetTraceLevel, thus adding the new trace level(s) to whatever the existing trace level(s)
had been,
This function has the highest priority to the service provider; it activates the trace as soon as
possible.
WFPOpen also includes an option to set these trace levels, to allow the open process itself to
be traced.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_TRACELEVEL
The dwTraceLevel parameter does not correspond to a valid trace level or set of levels.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
Page 95
CWA 14050-1:2000
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See Also
Page 96
CWA 14050-1:2000
6.10
WFPUnloadService
HRESULT
WFPUnloadService( )
Asks the called service provider whether it is OK for the XFS Manager to unload the service providers DLL.
Parameters
None
Mode
Immediate
Comments
This function is issued after the XFS Manager has received a WFMReleaseDLL request from
the service provider or during the processing of the WFSCleanUp command. The service
provider returns WFS_SUCCESS only if it has fully cleaned up, i.e., has freed any resources
it has allocated, has no separate threads running, etc. If this is not true, it returns the error
below, and initiates or continues the clean up process.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_NOT_OK_TO_UNLOAD
The XFS Manager may not unload the service provider DLL at this time. It will repeat this
request to the service provider until the return is WFS_SUCCESS, or until a new session is
started by an application with this service provider.
Page 97
CWA 14050-1:2000
6.11
WFPUnlock
HRESULT
HSERVICE hService
Handle to the service provider
HWND hWnd
The window handle which is to receive the completion message for this request.
REQUESTID ReqID
Request identification number.
Mode
Asynchronous
Comments
Messages
WFS_UNLOCK_COMPLETE
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions,
indicating that the asynchronous operation was not initiated. Any service-specific errors that
can be returned are defined in the specifications for each service class.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
The following error conditions are returned via the asynchronous command completion
message, as the hResult from the WFSRESULT structure. Any service-specific errors that can
be returned are defined in the specifications for each service class.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_NOT_LOCKED
The service to be unlocked is not locked under the calling hService.
Page 98
CWA 14050-1:2000
7.
Support Functions
Support functions are services of the XFS Manager used by service providers and applications. All the functions
are immediate, since they are completely processed inside the XFS Manager, or use only immediate functions of
the service providers.
7.1
WFMAllocateBuffer
HRESULT
Allocates a memory buffer for the service provider in which to return results.
Parameters
ULONG ulSize
Size (in bytes) of the memory to be allocated.
ULONG ulFlags
Flags, see comments below.
LPVOID * lppvData
Address of the variable in which the XFS Manager will place the pointer to the allocated
memory.
Comments
A service provider must use this call when creating data structures for the XFS Manager or an
application to use, and may use it when allocating memory for its own private use. The flags
can be ORed together, and specify:
WFS_MEM_SHARE
WFS_MEM_ZEROINIT
The application, XFS Manager or service provider then must, in turn, use the WFSFreeResult
or WFMFreeBuffer functions to deallocate the memory.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_OUT_OF_MEMORY
There is not enough memory available to satisfy the request.
See also
Page 99
CWA 14050-1:2000
7.2
WFMAllocateMore
HRESULT
ULONG ulSize
Size (in bytes) of the memory to be allocated
LPVOID lpvOriginal
Address of the original buffer to which the newly allocated buffer should be linked
LPVOID * lppvData
Address of the variable in which the XFS Manager will place the pointer to the newly
allocated memory.
Comments
This function allocates an additional memory buffer and link it to one previously allocated by
WFMAllocateBuffer. The returned buffer has the same properties as the previous buffer (i.e.,
the WFS_MEM_SHARE and WFS_MEM_ZEROINIT flags) and it can be freed only by
freeing the original buffer (using WFMFreeBuffer or WFSFreeResult).
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INVALID_ADDRESS
The lpvOriginal parameter does not point to a previously allocated buffer.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_OUT_OF_MEMORY
There is not enough memory available to satisfy the request.
See also
Page 100
CWA 14050-1:2000
7.3
WFMFreeBuffer
HRESULT
WFMFreeBuffer( lpvData )
LPVOID lpvData
Address of the memory buffer to free.
Comments
See WFMAllocateBuffer and WFSFreeResult. This function frees a set of one or more
linked buffers, as does the WFSFreeResult API function, except that it is used by service
providers to free memory that they have allocated for "private" use, via the
WFMAllocateBuffer and WFMAllocateMore functions.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INVALID_BUFFER
The lpvData parameter is not a pointer to an allocated buffer structure.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
See also
Page 101
CWA 14050-1:2000
7.4
WFMGetTraceLevel
HRESULT
Returns the trace level associated with the specified hService (at run time). See WFMSetTraceLevel.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
LPDWORD lpdwTraceLevel
Pointer to the value defining the current trace level (returned parameter).
Mode
Immediate
Comments
This function returns the current tracing levels in the XFS Manager and the service provider
specified by hService. See WFMSetTraceLevel.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See Also
Page 102
CWA 14050-1:2000
7.5
WFMKillTimer
HRESULT
WFMKillTimer(wTimerID )
Cancels the timer identified by the wTimerID parameter. Any pending WFS_TIMER_EVENT message
associated with the timer is removed from the message queue.
Parameters
WORD wTimerID
ID of the timer to be canceled.
Comments
See WFMSetTimer.
Error Codes
Page 103
CWA 14050-1:2000
7.6
WFMOutputTraceData
HRESULT
WFMOutputTraceData( lpszData )
Requests the XFS Manager to output the specified data to the current trace destination.
Parameters
LPSTR lpszData
Pointer to a null-terminated string containing the trace data.
Comments
Normally used by a service provider that has been requested via WFMSetTraceLevel to trace
its operation. The XFS Manager adds standard header information (timestamp, etc.) to the data
before writing it to the trace stream. Note that the XFS Manager also writes data to the trace
stream if the appropriate trace level(s) have been requested.
Error Codes
Page 104
CWA 14050-1:2000
7.7
WFMReleaseDLL
HRESULT
WFMReleaseDLL( hProvider )
Notifies the XFS Manager that the service provider is available to be unloaded from memory.
Parameters
HPROVIDER hProvider
Handle to the service provider, obtained from the XFS Manager in the WFPOpen call.
Comments
This function initiates the process in which the service provider is unloaded from memory by
the XFS Manager. However, note that the Manager must issue the WFPUnloadService
function to the service provider before it actually unloads the service provider DLL. The
recommended procedure is as follows:
Error Codes
The service provider finishes processing the WFPClose for its last open session
The SP does appropriate cleanup (deallocating memory, killing separate threads, etc.)
The SP posts the WFS_CLOSE_COMPLETE message for the final close
The SP calls WFMReleaseDLL, and after the return from this call, does nothing other
than return from the procedure that called WFMReleaseDLL
The XFS Manager calls WFPUnloadService, verifying that the SP is in fact still ready to
be unloaded
If the SP says OK, the XFS Manager unloads the SP DLL
Page 105
CWA 14050-1:2000
7.8
WFMSetTimer
HRESULT
HWND hWnd
The window to which the requested timer message is to be posted.
LPVOID lpContext
Context pointer supplied by the service provider requesting the timer; may be NULL.
DWORD dwTimeVal
Timer value (in milliseconds).
LPWORD lpwTimerID
Pointer to the timer identifier (returned parameter).
Comments
The WFMSetTimer function requests the XFS Manager to start a system timer with the
specified time value; when that time interval expires, the XFS Manager posts a
WFS_TIMER_EVENT message to the specified hWnd, containing the wTimerID value and
the lpContext pointer.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 106
CWA 14050-1:2000
7.9
WFMSetTraceLevel
HRESULT
Sets the specified trace level(s) at run time; to be used for debugging and testing purposes.
Parameters
HSERVICE hService
Handle to the service provider as returned by WFSOpen or WFSAsyncOpen.
DWORD dwTraceLevel
The level(s) of tracing being requested. See below.
Mode
Immediate
Comments
Issuing WFMSetTraceLevel for a service enables tracing on that service at various levels.
Five standard trace levels are predefined:
WFS_TRACE_API 0x00000001
Trace all input and output parameters of all API function calls using the specified hService.
WFS_TRACE_ALL_API
0x00000002
Trace all input and output parameters of all API function calls associated with the service
provider identified by the specified hService, not just the ones associated with the specified
hService.
WFS_TRACE_SPI 0x00000004
Trace all input and output parameters of all SPI function calls associated with the specified
hService, as well as all notification and event messages generated by the service provider for
the hService.
WFS_TRACE_ALL_SPI
0x00000008
As for WFS_TRACE_ALL_API, but trace all SPI, notification and event activity on the
service provider, not just that associated with the specified hService.
WFS_TRACE_MGR 0x00000010
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
Page 107
CWA 14050-1:2000
WFS_ERR_INVALID_TRACELEVEL
The dwTraceLevel parameter does not correspond to a valid trace level or set of levels.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and
WFSIsBlocking are permitted at this time.
See Also
Page 108
CWA 14050-1:2000
8.
Configuration Functions
See Section 3.7 for the overall discussion of configuration information and how it is stored within the Windows
Registr
8.1
WFMCloseKey
HRESULT
WFMCloseKey ( hKey )
HKEY hKey
Handle to the currently open key that is to be closed.
Comments
The hkey handle can not be used after it has been closed, because it will no longer be valid.
Note that it is not valid to close the XFS root key (passing WFS_CFG_HKEY_XFS_ROOT
as value for hkey parameter).
Error Codes
Page 109
CWA 14050-1:2000
8.2
WFMCreateKey
HRESULT
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
WFS_CFG_MACHINE_XFS_ROOT
WFS_CFG_USER_DEFAULT_XFS_ROOT
The key opened or created by this function is a subkey of the key identified by this
parameter.
LPSTR lpszSubKey
Pointer to a null-terminated string containing the name of the key to be created or opened.
PHKEY phkResult
Pointer to a variable that receives the handle of the created or opened key.
LPDWORD lpdwDisposition
Pointer to a variable that receives one of the disposition values:
WFS_CFG_CREATED_NEW_KEY
WFS_CFG_OPENED_EXISTING_KEY
Comments
If this function creates a new key, it has no values. The WFMSetValue function is used to
create values.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions:
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 110
CWA 14050-1:2000
8.3
WFMDeleteKey
HRESULT
Deletes the specified key. This function cannot delete a key that has subkeys.
Parameters
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
The key specified by the lpszSubKey parameter must be a subkey of the key identified by
this parameter.
LPSTR lpszSubKey
Pointer to a null-terminated string specifying the name of the key to be deleted.
Comments
If this function succeeds, the specified key is removed from the configuration information. The
entire key, including all its values, is removed.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_CFG_INVALID_SUBKEY
The key specified by lpszSubKey does not exist.
WFS_ERR_CFG_KEY_NOT_EMPTY
The specified key has subkeys and cannot be deleted. The subkeys must be deleted first.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 111
CWA 14050-1:2000
8.4
WFMDeleteValue
HRESULT
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
LPSTR lpszValue
Pointer to a null-terminated string specifying the name of the value to be deleted.
Comments
The specified value is removed from the specified open key. The WFMSetValue function is
used to create or modify values.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_CFG_INVALID_VALUE
The specified value does not exist within the specified open key.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 112
CWA 14050-1:2000
8.5
WFMEnumKey
HRESULT
Enumerates the subkeys of the specified open key. Retrieves information about one subkey each time it is called.
Parameters
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
The keys enumerated by this function are subkeys of the key identified by this parameter.
DWORD iSubKey
The index of the subkey to retrieve. This parameter should be zero for the first call to this
function, then incremented for each subsequent call, in order to enumerate all the subkeys of
the specified open key.
Because subkeys are not ordered, any new subkey will have an arbitrary index. This means
that the function may return subkeys in any order.
LPSTR lpszName
Pointer to a buffer that receives the name of the subkey, including the terminating null
character.
LPDWORD lpcchName
Pointer to a variable that specifies the size, in characters, of the buffer specified by the
lpszName parameter, including the terminating null character. When the function returns,
this variable contains the the number of characters actually stored in the buffer, not
including the terminating null character.
PFILETIME lpftLastWrite
Pointer to a variable that receives the time the enumerated subkey was last written to, in the
form of a FILETIME structure (see Microsoft Win32 Programmer's Reference, Vol. 5):
typedef struct _FILETIME {
DWORD dwLowDateTime;
DWORD dwHighDateTime;
} FILETIME;
Comments
While a program is using this function iteratively, it should not call any other configuration
functions that would change the key being enumerated.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_CFG_NO_MORE_ITEMS
There are no more subkeys to be returned (the iSubKey parameter is greater than the index
of the last subkey).
WFS_ERR_CFG_NAME_TOO_LONG
The length of the name to be returned exceeds the length of the buffer.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 113
CWA 14050-1:2000
8.6
WFMEnumValue
HRESULT
Enumerates the values of the specified open key. Retrieves the name and data for one value each time it is called.
Parameters
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
The value enumerated by this function is a value of the key identified by this parameter.
DWORD iValue
The index of the value to retrieve. This parameter should be zero for the first call to this
function, then incremented for each subsequent call, in order to enumerate all the values of
the specified open key.
Because values are not ordered, any new value will have an arbitrary index. This means that
the function may return values in any order.
LPSTR lpszValue
Pointer to a buffer that receives the name of the value, including the terminating null
character.
LPDWORD lpcchValue
Pointer to a variable that specifies the size, in characters, of the buffer pointed to by the
lpszValue parameter. This size should include the terminating null character. When the
function returns, this variable contains the the number of characters actually stored in the
buffer, not including the terminating null character.
LPSTR lpszData
Pointer to a buffer that receives the data for the value entry, including the terminating null
character. This parameter can be NULL, if the data is not required.
LPDWORD lpcchData
Pointer to a variable that specifies the size, in characters, of the buffer pointed to by the
lpszData parameter, including the terminating null character. When the function returns, this
variable contains the the number of characters actually stored in the buffer, not including the
terminating null character. Ignored if lpszData is NULL.
Comments
While a program is using this function iteratively, it should not call any other configuration
functions that would change the key being queried.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_CFG_NO_MORE_ITEMS
There are no more values to be returned (the iValue parameter is greater than the index of
the last value).
WFS_ERR_CFG_NAME_TOO_LONG
The length of the name to be returned exceeds the length of the buffer.
WFS_ERR_CFG_VALUE_TOO_LONG
The length of the value to be returned exceeds the length of the buffer.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 114
CWA 14050-1:2000
8.7
WFMOpenKey
HRESULT
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
The key opened by this function is a subkey of the key identified by this parameter.
LPSTR lpszSubKey
Pointer to a null-terminated string containing the name of the key to be opened. If this
parameter is NULL, or points to an empty string, the function opens another handle to the
key identified by the hKey parameter (and does not close any previously opened handles).
PHKEY phkResult
Pointer to a variable that receives the handle of the opened key.
Comments
In contrast with the WFMCreateKey function, this function does not create the specified key
if it does not exist.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_CFG_INVALID_SUBKEY
The key specified by lpszSubKey does not exist.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 115
CWA 14050-1:2000
8.8
WFMQueryValue
HRESULT
Retrieves the data for the value with the specified name, within the specified open key.
Parameters
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
The value data returned is within the key identified by this parameter.
LPSTR lpszValueName
Pointer to a null-terminated string containing the name of the value being queried.
LPSTR lpszData
Pointer to a buffer that receives the data for the value entry, including the terminating null
character.
LPDWORD lpcchData
Pointer to a variable that specifies the size, in characters, of the buffer pointed to by the
lpszData parameter, including the terminating null character. When the function returns, this
variable contains the the number of characters actually stored in the buffer, not including the
terminating null character.
Comments
None.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_CFG_INVALID_NAME
The value specified by the lpszValueName parameter does not exist in the specified key.
WFS_ERR_CFG_VALUE_TOO_LONG
The length of the value to be returned exceeds the length of the buffer.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 116
CWA 14050-1:2000
8.9
WFMSetValue
HRESULT
Stores data in the specified value of the specified key. If the value does not exist, it is created.
Parameters
HKEY hKey
Handle to a currently open key, or the predefined handle value:
WFS_CFG_HKEY_XFS_ROOT
The value set or created is within the key identified by this parameter.
LPSTR lpszValueName
Pointer to a null-terminated string containing the name of the value being set. If a value with
this name does not already exist in the specified key, it is added to the key.
LPSTR lpszData
Pointer to a buffer containing the data (a null-terminated character string) to be stored with
the specified value name.
DWORD cchData
The size, in characters, of the string pointed to by the lpszData parameter, including the
terminating null character.
Comments
Value lengths are limited by available memory. Long values (more than 2048 bytes) should be
stored as files with the filenames stored in the configuration information.
Error Codes
If the function return is not WFS_SUCCESS, it is one of the following error conditions.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
Page 117
CWA 14050-1:2000
9.
Data Structures
9.1
WFSRESULT
Description
Request ID of the completed command; not used for event notifications other than
Execute events
hService
Service handle identifying the session that created the result
tsTimestamp
Time the event occurred (local time, in a Win32 SYSTEMTIME structure)
hResult
Result handle (note that for synchronous WFSExecute and WFSGetInfo commands,
this value is identical to the synchronous function return value)
u.dwCommandCode WFSExecute command code or WFSGetInfo category code; not used for other
command completions
u.dwEventID
ID of the event (for unsolicited events)
lpBuffer
Pointer to the results of the command (if any) or the contents of the event notification
Page 118
CWA 14050-1:2000
9.2
WFSVERSION
This structure is used to return version information from WFSStartUp, WFSOpen and WFPOpen.
typedef struct _wfsversion {
WORD
wVersion;
WORD
wLowVersion;
WORD
wHighVersion;
char
szDescription[WFSDDESCRIPTION_LEN+1];
char
szSystemStatus[WFSDSYSSTATUS_LEN+1];
} WFSVERSION, *LPWFSVERSION;
The members of this structure are (note that this structure is used to report version information for three distinct
XFS interfaces: API, SPI, and the service-specific interface):
Element
wVersion
wLowVersion
wHighVersion
szDescription
szSystemStatus
Usage
The version number to be used.
The lowest version number that the called DLL can support.
The highest version number that the called DLL can support.
A null-terminated ASCII string into which the called DLL copies a description of the
implementation. The text (up to 256 characters in length) may contain any characters: the
most likely use that an application will make of this is to display it (possibly truncated) in a
status message.
A null-terminated ASCII string into which the called DLL copies relevant status or
configuration information. Not to be considered as an extension of the szDescription field.
Used only if the information might be useful to the user or support staff.
Page 119
CWA 14050-1:2000
10.
Messages
This section defines the Windows messages used in the XFS subsystem.
10.1
10.1.1
WFS_OPEN_COMPLETE
WFS_CLOSE_COMPLETE
WFS_LOCK_COMPLETE
WFS_UNLOCK_COMPLETE
WFS_REGISTER_COMPLETE
WFS_DEREGISTER_COMPLETE
WFS_GETINFO_COMPLETE
WFS_EXECUTE_COMPLETE
10.1.2
Event Messages
WFS_EXECUTE_EVENT
WFS_SERVICE_EVENT
WFS_USER_EVENT
WFS_SYSTEM_EVENT
Page 120
CWA 14050-1:2000
10.2
Timer Events
The timer event message has the following format (see WFMSetTimer, WFMKillTimer):
WFS_TIMER_EVENT
wParam = wTimerID;
lParam = lpContext;
Page 121
CWA 14050-1:2000
10.3
Status changes of logical services (which typically reflect changes in physical devices) are reported as system
events. This is in addition to being reported by the WFS_INF_xxx_STATUS query of the WFSGetInfo or
WFSAsyncGetInfo functions. The WFSRESULT data structure (defined in Section 8.1) is utilized as follows:
Field
RequestID
hService
tsTimestamp
hResult
u.dwEventID
lpBuffer
Description
(not used)
Service handle identifying the session that created the result
Time the status change occurred (local time, in a Win32 SYSTEMTIME structure)
(not used)
= WFS_SYSE_DEVICE_STATUS
Pointer to a WFSDEVSTATUS structure:
typedef struct
wfs_devstatus {
LPSTR
lpszPhysicalName;
LPSTR
lpszWorkstationName;
DWORD
dwState;
} WFSDEVSTATUS, * LPWFSDEVSTATUS;
Description
Pointer to the physical service name of the service that changed its state.
Pointer to the name of the workstation in which the logical service name is defined.
Specifies the new state of the physical device managed by the service as one of the
following:
Value
Meaning
WFS_STAT_DEVONLINE
The device is online (i.e., powered on and
operable).
WFS_STAT_DEVOFFLINE
The device is offline (e.g., the operator has taken
the device offline by turning a switch or pulling
out the device).
WFS_STAT_DEVPOWEROFF
The device is powered off or physically not
connected.
WFS_STAT_DEVNODEVICE
There is no device intended to be there; e.g.
this type of self service
machine does not contain such a device or it
is internally not configured..
WFS_STAT_DEVHWERROR
The device is inoperable due to a hardware error.
WFS_STAT_DEVUSERERROR
The device is inoperable because a person is
preventing proper device operation.
Page 122
CWA 14050-1:2000
10.4
Undeliverable Messages
If a command completion or event message cannot be delivered, it is reported as a system event. The
WFSRESULT data structure (defined in Section 8.1) is utilized as follows:
Field
RequestID
hService
tsTimestamp
hResult
u.dwEventID
lpBuffer
Description
(not used)
Service handle identifying the session associated with the completion or event
Time the event occurred (local time, in a Win32 SYSTEMTIME structure)
(not used)
= WFS_SYSE_UNDELIVERABLE_MSG
Pointer to a WFSUNDEVMSG structure:
Description
Pointer to the logical service name of the service that generated the original
undeliverable message
lpszWorkstationName Pointer to the the name of the workstation in which the logical service name is defined
lpszAppID
Pointer to the the application ID associated with the session that generated the original
message
dwSize
The size in bytes of the following description
lpbDescription
Pointer to a vendor-specific description of the reason why the message could not be
delivered
dwMsg
The message identifier of the original message
lpWFSResult
Pointer to the WFSRESULT structure of the original message (which has the lpBuffer
parameter set to NULL)
Page 123
CWA 14050-1:2000
10.5
Application Disconnect
If the XFS subsystem loses connection to an application, it closes the session (see Section 3.6) and generates this
system event. The WFSRESULT data structure (defined in Section 8.1) is utilized as follows:
Field
RequestID
hService
tsTimestamp
hResult
u.dwEventID
lpBuffer
Description
(not used)
Service handle identifying the session associated with the event
Time the event occurred (local time, in a Win32 SYSTEMTIME structure)
(not used)
= WFS_SYSE_APP_DISCONNECT
Pointer to a WFSAPPDISC structure:
Description
Pointer to the logical service name of the service that the application was connected to
Pointer to the the name of the workstation in which the logical service name is defined
Pointer to the the application ID associated with the session that generated the event
Page 124
CWA 14050-1:2000
10.6
Hardware and software errors are reported as system events. In most cases, this is in addition to being reported
via the WFS_ERR_HARDWARE_ERROR or the WFS_ERR_SOFTWARE_ERROR or
WFS_ERR_USER_ERROR error code that is returned when a hardware or software or user error occurs in the
course of executing a function. The WFSRESULT data structure (defined in Section 8.1), is utilized as follows:
Field
RequestID
hService
tsTimestamp
hResult
u.dwEventID
Description
Request ID of the request being processed when the error occurred (if any)
Service handle identifying the session associated with the error (if any)
Time the error occurred (local time, in a Win32 SYSTEMTIME structure)
Result handle of the request being processed when the error occurred (if any)
The ID of the error
Value
WFS_SYSE_HARDWARE_ERROR
WFS_SYSE_SOFTWARE_ERROR
WFS_SYSE_USER_ERROR
lpBuffer
Meaning
The error is a hardware error
The error is a software error
The error is a user error
Description
Pointer to the logical service name of the service that generated the error (if any)
Pointer to the physical service name of the service that generated the error (if any)
Pointer to the the name of the workstation in which the logical service name is defined (if
any)
Pointer to the application ID associated with the session that generated the error (if any)
The action required to manage the error. Possible values are:
Value
Meaning
Page 125
CWA 14050-1:2000
WFS_ERR_ACT_SUSPEND
dwSize
lpbDescription
Page 126
CWA 14050-1:2000
10.7
Lock Requested
The Lock requested system event is sent to any application which currently has a device locked whenever a
request for a lock on the same device is received from another application or service handle. Note that this event
is generated each time another application requests a lock on the same device. This system event differs from
other system events in that it is only posted to the owner of the lock, it is NOT posted to any other application.
Field
RequestID
hService
tsTimestamp
hResult
u.dwEventID
lpBuffer
Description
(not used)
Service handle identifying the device and session which has obtained the lock.
Time the status change occurred (local time, in a Win32 SYSTEMTIME structure)
(not used)
= WFS_SYSE_LOCK_REQUESTED
(not used)
Page 127
CWA 14050-1:2000
10.8
Failures in version negotiation are reported as system events. This is in addition to being reported by the version
error code returned by the WFSStartUp or WFSOpen functions. The WFSRESULT data structure (defined in
Section 8.1) is utilized as follows:
Field
RequestID
hService
tsTimestamp
hResult
u.dwEventID
lpBuffer
Description
(not used)
(not used)
Time the error occurred (local time, in a Win32 SYSTEMTIME structure)
The version error code (e.g., WFS_ERR_SPI_VER_TOO_HIGH)
= WFS_SYSE_VERSION_ERROR
Pointer to a WFSVRSNERROR structure:
Page 128
CWA 14050-1:2000
11.
Error Codes
The following are the error codes that can be returned from a call to an XFS API or SPI function, either as a
function return or in a result structure pointed to by a completion message. Errors from service-specific
commands are defined in the specifications for each service class.
WFS_ERR_ALREADY_STARTED
A WFSStartUp has already been issued by the application, without an intervening WFSCleanUp.
WFS_ERR_API_VER_TOO_HIGH
The range of versions of XFS API support requested by the application is higher than any supported by this
particular XFS Manager implementation.
WFS_ERR_API_VER_TOO_LOW
The range of versions of XFS API support requested by the application is lower than any supported by this
particular XFS Manager implementation.
WFS_ERR_CANCELED
The request was canceled by WFSCancelAsyncRequest or WFSCancelBlockingCall.
WFS_ERR_CFG_INVALID_HKEY
The specified hKey parameter does not correspond to a currently open key.
WFS_ERR_CFG_INVALID_NAME
The value specified by the lpszValueName parameter does not exist in the specified key.
WFS_ERR_CFG_INVALID_SUBKEY
The key specified by lpszSubKey does not exist.
WFS_ERR_CFG_INVALID_VALUE
The specified value does not exist within the specified open key.
WFS_ERR_CFG_KEY_NOT_EMPTY
The specified key has subkeys and cannot be deleted. The subkeys must be deleted first.
WFS_ERR_CFG_NAME_TOO_LONG
The length of the name to be returned exceeds the length of the buffer.
WFS_ERR_CFG_NO_MORE_ITEMS
There are no more subkeys to be returned (the iSubKey parameter is greater than the index of the last subkey).
WFS_ERR_CFG_VALUE_TOO_LONG
The length of the value to be returned exceeds the length of the buffer.
WFS_ERR_CONNECTION_LOST
The connection to the service is lost.
WFS_ERR_DEV_NOT_READY
The function required device access, and the device was not ready or timed out.
WFS_ERR_HARDWARE_ERROR
The function required device access, and an error occurred on the device.
WFS_ERR_INTERNAL_ERROR
An internal inconsistency or other unexpected error occurred in the XFS subsystem.
WFS_ERR_INVALID_ADDRESS
The lpvOriginal parameter does not point to a previously allocated buffer.
WFS_ERR_INVALID_APP_HANDLE
The specified application handle is not valid, i.e., was not created by a preceding create call.
WFS_ERR_INVALID_BUFFER
The lpvData parameter is not a pointer to an allocated buffer structure.
WFS_ERR_INVALID_CATEGORY
The dwCategory issued is not supported by this service class.
Page 129
CWA 14050-1:2000
WFS_ERR_INVALID_COMMAND
The dwCommand issued is not supported by this service class.
WFS_ERR_INVALID_EVENT_CLASS
The dwEventClass parameter specifies one or more event classes not supported by the service.
WFS_ERR_INVALID_HSERVICE
The hService parameter is not a valid service handle.
WFS_ERR_INVALID_HPROVIDER
The hProvider parameter is not a valid provider handle.
WFS_ERR_INVALID_HWND
The hWnd parameter is not a valid window handle.
WFS_ERR_INVALID_HWNDREG
The hWndReg parameter is not a valid window handle.
WFS_ERR_INVALID_POINTER
A pointer parameter does not point to accessible memory.
WFS_ERR_INVALID_DATA
The data structure passed as input parameter contains invalid data..
WFS_ERR_INVALID_REQ_ID
The RequestID parameter does not correspond to an outstanding request on the service.
WFS_ERR_INVALID_RESULT
The lpResult parameter is not a pointer to an allocated WFSRESULT structure.
WFS_ERR_INVALID_SERVPROV
The file containing the service provider is invalid or corrupted.
WFS_ERR_INVALID_TIMER
The hWnd and usTimerID parameters do not correspond to a currently active timer.
WFS_ERR_INVALID_TRACELEVEL
The dwTraceLevel parameter does not correspond to a valid trace level or set of levels.
WFS_ERR_LOCKED
The service is locked under a different hService.
WFS_ERR_NO_BLOCKING_CALL
There is no outstanding blocking call for the specified thread.
WFS_ERR_NO_SERVPROV
The file containing the service provider does not exist.
WFS_ERR_NO_SUCH_THREAD
The specified thread does not exist.
WFS_ERR_NO_TIMER
The timer could not be created.
WFS_ERR_NOT_LOCKED
The application requesting a service be unlocked had not previously performed a successful WFSLock or
WFSAsyncLock.
WFS_ERR_NOT_OK_TO_UNLOAD
The XFS Manager may not unload the service provider DLL.
WFS_ERR_NOT_STARTED
The application has not previously performed a successful WFSStartUp.
WFS_ERR_NOT_REGISTERED
The specified hWndReg window was not registered to receive messages for any event classes.
WFS_ERR_OP_IN_PROGRESS
A blocking operation is in progress on the thread; only WFSCancelBlockingCall and WFSIsBlocking are
permitted at this time.
Page 130
CWA 14050-1:2000
WFS_ERR_OUT_OF_MEMORY
There is not enough memory available to satisfy the request.
WFS_ERR_SERVICE_NOT_FOUND
The logical name is not a valid service provider name.
WFS_ERR_SOFTWARE_ERROR
The function required access to configuration information, and an error occurred on the software.
WFS_ERR_SPI_VER_TOO_HIGH
The range of versions of XFS SPI support requested by the XFS Manager is higher than any supported by the
service provider for the logical service being opened.
WFS_ERR_SPI_VER_TOO_LOW
The range of versions of XFS SPI support requested by the XFS Manager is lower than any supported by the
service provider for the logical service being opened.
WFS_ERR_SRVC_VER_TOO_HIGH
The range of versions of the service-specific interface support requested by the application is higher than any
supported by the service provider for the logical service being opened.
WFS_ERR_SRVC_VER_TOO_LOW
The range of versions of the service-specific interface support requested by the application is lower than any
supported by the service provider for the logical service being opened.
WFS_ERR_TIMEOUT
The timeout interval expired.
WFS_ERR_UNSUPP_CATEGORY
The dwCategory issued, although valid for this service class, is not supported by this service provider.
WFS_ERR_UNSUPP_COMMAND
The dwCommand issued, although valid for this service class, is not supported by this service provider or device.
WFS_ERR_UNSUPP_DATA
The data structure passed as an input parameter although valid for this service class, is not supported by this
service provider or device.
WFS_ERR_USER_ERROR
A user is preventing proper operation of the device.
WFS_ERR_VERSION_ERROR_IN_SRVC
Within the service, a version mismatch of two modules occurred.
Page 131
CWA 14050-1:2000
12.
This section describes functions and facilities that are not fully defined in this version of the Extensions for
Financial Services specification; modifications and complete definitions will be supplied in later versions.
Vendor and user input is encouraged on these functions and facilities, as well as suggestions as to additional
functionality.
XFS currently includes specifications for access to the key classes of financial peripherals for attended and selfservice environments. These existing specifications will be extended and enhanced based on vendor and user
experience with them. The Service Class Definition Document lists the classes of devices or services that,
together with others that customers and vendors request, will be evaluated for inclusion in future versions of this
specification.
Also to be considered for future versions of XFS are other types of services, such as financial transaction
messaging and management, as well as related services for financial networks such as network and systems
management and security. As with the current specification, all these capabilities will be specified for access
from the familiar, consistent Microsoft Windows user interface and programming environments. Another portion
of the XFS API set will deal with administration issues.
Page 132
CWA 14050-1:2000
12.1
The XFS subsystem will need additional facilities for managing exception conditions (i.e., those that are not
anticipated in the error codes, events, etc., that are defined in this specification). One general facility for this is
the system event capability, as described in Sections 3.11 and 9. This will utilize a combination of one or more
functions provided by the XFS Manager and other methods for applications, the XFS Manager, service
providers, and services to report exception conditions in special circumstances (e.g., when the XFS Manager is
not available). Such conditions would presumably be monitored by a system management agent responsible for
logging and reporting them via a network management facility.
Page 133
CWA 14050-1:2000
13.
Page 134
CWA 14050-1:2000
14.
14.1
/************************************************************************
*
*
* xfsapi.h
XFS - API functions, types, and definitions
*
*
*
*
Version 3.00 -- 10/18/00
*
*
*
************************************************************************/
#ifndef __inc_xfsapi__h
#define __inc_xfsapi__h
#ifdef __cplusplus
extern "C" {
#endif
/*
be aware of alignment
#pragma pack(push,1)
*/
256
256
WFS_STAT_DEVONLINE
WFS_STAT_DEVOFFLINE
WFS_STAT_DEVPOWEROFF
WFS_STAT_DEVNODEVICE
WFS_STAT_DEVHWERROR
WFS_STAT_DEVUSERERROR
WFS_STAT_DEVBUSY
(0)
(1)
(2)
(3)
(4)
(5)
(6)
(0)
Page 135
CWA 14050-1:2000
/****** Data Structures *************************************************/
typedef struct _wfs_result
{
REQUESTID
RequestID;
HSERVICE
hService;
SYSTEMTIME
tsTimestamp;
HRESULT
hResult;
union {
DWORD
dwCommandCode;
DWORD
dwEventID;
} u;
LPVOID
lpBuffer;
} WFSRESULT, * LPWFSRESULT;
typedef struct _wfsversion
{
WORD
wVersion;
WORD
wLowVersion;
WORD
wHighVersion;
CHAR
szDescription[WFSDDESCRIPTION_LEN+1];
CHAR
szSystemStatus[WFSDSYSSTATUS_LEN+1];
} WFSVERSION, * LPWFSVERSION;
/****** Message Structures **********************************************/
typedef struct _wfs_devstatus
{
LPSTR
lpszPhysicalName;
LPSTR
lpszWorkstationName;
DWORD
dwState;
} WFSDEVSTATUS, * LPWFSDEVSTATUS;
typedef struct _wfs_undevmsg
{
LPSTR
lpszLogicalName;
LPSTR
lpszWorkstationName;
LPSTR
lpszAppID;
DWORD
dwSize;
LPBYTE
lpbDescription;
DWORD
dwMsg;
LPWFSRESULT
lpWFSResult;
} WFSUNDEVMSG, * LPWFSUNDEVMSG;
typedef struct _wfs_appdisc
{
LPSTR
lpszLogicalName;
LPSTR
lpszWorkstationName;
LPSTR
lpszAppID;
} WFSAPPDISC, * LPWFSAPPDISC;
typedef struct _wfs_hwerror
{
LPSTR
lpszLogicalName;
LPSTR
lpszPhysicalName;
LPSTR
lpszWorkstationName;
LPSTR
lpszAppID;
DWORD
dwAction;
DWORD
dwSize;
LPBYTE
lpbDescription;
} WFSHWERROR, * LPWFSHWERROR;
typedef struct _wfs_vrsnerror
{
LPSTR
lpszLogicalName;
LPSTR
lpszWorkstationName;
LPSTR
lpszAppID;
DWORD
dwSize;
LPBYTE
lpbDescription;
LPWFSVERSION
lpWFSVersion;
} WFSVRSNERROR, * LPWFSVRSNERROR;
/****** Error codes ******************************************************/
Page 136
CWA 14050-1:2000
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
#define
WFS_SUCCESS
WFS_ERR_ALREADY_STARTED
WFS_ERR_API_VER_TOO_HIGH
WFS_ERR_API_VER_TOO_LOW
WFS_ERR_CANCELED
WFS_ERR_CFG_INVALID_HKEY
WFS_ERR_CFG_INVALID_NAME
WFS_ERR_CFG_INVALID_SUBKEY
WFS_ERR_CFG_INVALID_VALUE
WFS_ERR_CFG_KEY_NOT_EMPTY
WFS_ERR_CFG_NAME_TOO_LONG
WFS_ERR_CFG_NO_MORE_ITEMS
WFS_ERR_CFG_VALUE_TOO_LONG
WFS_ERR_DEV_NOT_READY
WFS_ERR_HARDWARE_ERROR
WFS_ERR_INTERNAL_ERROR
WFS_ERR_INVALID_ADDRESS
WFS_ERR_INVALID_APP_HANDLE
WFS_ERR_INVALID_BUFFER
WFS_ERR_INVALID_CATEGORY
WFS_ERR_INVALID_COMMAND
WFS_ERR_INVALID_EVENT_CLASS
WFS_ERR_INVALID_HSERVICE
WFS_ERR_INVALID_HPROVIDER
WFS_ERR_INVALID_HWND
WFS_ERR_INVALID_HWNDREG
WFS_ERR_INVALID_POINTER
WFS_ERR_INVALID_REQ_ID
WFS_ERR_INVALID_RESULT
WFS_ERR_INVALID_SERVPROV
WFS_ERR_INVALID_TIMER
WFS_ERR_INVALID_TRACELEVEL
WFS_ERR_LOCKED
WFS_ERR_NO_BLOCKING_CALL
WFS_ERR_NO_SERVPROV
WFS_ERR_NO_SUCH_THREAD
WFS_ERR_NO_TIMER
WFS_ERR_NOT_LOCKED
WFS_ERR_NOT_OK_TO_UNLOAD
WFS_ERR_NOT_STARTED
WFS_ERR_NOT_REGISTERED
WFS_ERR_OP_IN_PROGRESS
WFS_ERR_OUT_OF_MEMORY
WFS_ERR_SERVICE_NOT_FOUND
WFS_ERR_SPI_VER_TOO_HIGH
WFS_ERR_SPI_VER_TOO_LOW
WFS_ERR_SRVC_VER_TOO_HIGH
WFS_ERR_SRVC_VER_TOO_LOW
WFS_ERR_TIMEOUT
WFS_ERR_UNSUPP_CATEGORY
WFS_ERR_UNSUPP_COMMAND
WFS_ERR_VERSION_ERROR_IN_SRVC
WFS_ERR_INVALID_DATA
WFS_ERR_SOFTWARE_ERROR
WFS_ERR_CONNECTION_LOST
WFS_ERR_USER_ERROR
WFS_ERR_UNSUPP_DATA
#define WFS_INDEFINITE_WAIT
(0)
(-1)
(-2)
(-3)
(-4)
(-5)
(-6)
(-7)
(-8)
(-9)
(-10)
(-11)
(-12)
(-13)
(-14)
(-15)
(-16)
(-17)
(-18)
(-19)
(-20)
(-21)
(-22)
(-23)
(-24)
(-25)
(-26)
(-27)
(-28)
(-29)
(-30)
(-31)
(-32)
(-33)
(-34)
(-35)
(-36)
(-37)
(-38)
(-39)
(-40)
(-41)
(-42)
(-43)
(-44)
(-45)
(-46)
(-47)
(-48)
(-49)
(-50)
(-51)
(-52)
(-53)
(-54)
(-55)
(-56)
0
WFS_OPEN_COMPLETE
WFS_CLOSE_COMPLETE
WFS_LOCK_COMPLETE
WFS_UNLOCK_COMPLETE
WFS_REGISTER_COMPLETE
WFS_DEREGISTER_COMPLETE
WFS_GETINFO_COMPLETE
WFS_EXECUTE_COMPLETE
#define WFS_EXECUTE_EVENT
(WM_USER
(WM_USER
(WM_USER
(WM_USER
(WM_USER
(WM_USER
(WM_USER
(WM_USER
+
+
+
+
+
+
+
+
1)
2)
3)
4)
5)
6)
7)
8)
(WM_USER + 20)
Page 137
CWA 14050-1:2000
#define WFS_SERVICE_EVENT
#define WFS_USER_EVENT
#define WFS_SYSTEM_EVENT
(WM_USER + 21)
(WM_USER + 22)
(WM_USER + 23)
#define WFS_TIMER_EVENT
(WM_USER + 100)
SERVICE_EVENTS
USER_EVENTS
SYSTEM_EVENTS
EXECUTE_EVENTS
(1)
(2)
(4)
(8)
WFS_SYSE_UNDELIVERABLE_MSG
WFS_SYSE_HARDWARE_ERROR
WFS_SYSE_VERSION_ERROR
WFS_SYSE_DEVICE_STATUS
WFS_SYSE_APP_DISCONNECT
WFS_SYSE_SOFTWARE_ERROR
WFS_SYSE_USER_ERROR
WFS_SYSE_LOCK_REQUESTED
(1)
(2)
(3)
(4)
(5)
(6)
(7)
(8)
WFS_TRACE_API
WFS_TRACE_ALL_API
WFS_TRACE_SPI
WFS_TRACE_ALL_SPI
WFS_TRACE_MGR
0x00000001
0x00000002
0x00000004
0x00000008
0x00000010
WFS_ERR_ACT_NOACTION
WFS_ERR_ACT_RESET
WFS_ERR_ACT_SWERROR
WFS_ERR_ACT_CONFIG
WFS_ERR_ACT_HWCLEAR
WFS_ERR_ACT_HWMAINT
WFS_ERR_ACT_SUSPEND
(0x0000)
(0x0001)
(0x0002)
(0x0004)
(0x0008)
(0x0010)
(0x0020)
Page 138
CWA 14050-1:2000
HRESULT extern WINAPI WFSGetInfo ( HSERVICE hService, DWORD dwCategory, LPVOID
lpQueryDetails, DWORD dwTimeOut, LPWFSRESULT * lppResult);
HRESULT extern WINAPI WFSAsyncGetInfo ( HSERVICE hService, DWORD dwCategory, LPVOID
lpQueryDetails, DWORD dwTimeOut, HWND hWnd, LPREQUESTID lpRequestID);
BOOL extern WINAPI WFSIsBlocking ();
HRESULT extern WINAPI WFSLock ( HSERVICE hService, DWORD dwTimeOut , LPWFSRESULT *
lppResult);
HRESULT extern WINAPI WFSAsyncLock ( HSERVICE hService, DWORD dwTimeOut, HWND hWnd,
LPREQUESTID lpRequestID);
HRESULT extern WINAPI WFSOpen ( LPSTR lpszLogicalName, HAPP hApp, LPSTR lpszAppID,
DWORD dwTraceLevel, DWORD dwTimeOut, DWORD dwSrvcVersionsRequired, LPWFSVERSION
lpSrvcVersion, LPWFSVERSION lpSPIVersion, LPHSERVICE lphService);
HRESULT extern WINAPI WFSAsyncOpen ( LPSTR lpszLogicalName, HAPP hApp, LPSTR
lpszAppID, DWORD dwTraceLevel, DWORD dwTimeOut, LPHSERVICE lphService, HWND hWnd,
DWORD dwSrvcVersionsRequired, LPWFSVERSION lpSrvcVersion, LPWFSVERSION
lpSPIVersion, LPREQUESTID lpRequestID);
HRESULT extern WINAPI WFSRegister ( HSERVICE hService, DWORD dwEventClass, HWND
hWndReg);
HRESULT extern WINAPI WFSAsyncRegister ( HSERVICE hService, DWORD dwEventClass,
HWND hWndReg, HWND hWnd, LPREQUESTID lpRequestID);
HRESULT extern WINAPI WFSSetBlockingHook ( XFSBLOCKINGHOOK lpBlockFunc,
LPXFSBLOCKINGHOOK lppPrevFunc);
HRESULT extern WINAPI WFSStartUp ( DWORD dwVersionsRequired, LPWFSVERSION
lpWFSVersion);
HRESULT extern WINAPI WFSUnhookBlockingHook ();
HRESULT extern WINAPI WFSUnlock ( HSERVICE hService);
HRESULT extern WINAPI WFSAsyncUnlock ( HSERVICE hService, HWND hWnd, LPREQUESTID
lpRequestID);
HRESULT extern WINAPI WFMSetTraceLevel ( HSERVICE hService, DWORD dwTraceLevel);
/*
restore alignment
#pragma pack(pop)
*/
#ifdef __cplusplus
}
/*extern "C"*/
#endif
#endif
/* __inc_xfsapi__h */
Page 139
CWA 14050-1:2000
14.2
XFSADMIN.H
/******************************************************************************
*
*
* xfsadmin.h
XFS-Administration and Support functions
*
*
*
*
Version 3.00 -- 10/18/00
*
*
*
******************************************************************************/
#ifndef __INC_XFSADMIN__H
#define __INC_XFSADMIN__H
#ifdef __cplusplus
extern "C" {
#endif
#include
<xfsapi.h>
/*
be aware of alignment
#pragma pack(push,1)
*/
0x00000001
0x00000002
*/
#ifdef __cplusplus
}
/*extern "C"*/
#endif
#endif
/* __INC_XFSADMIN__H */
Page 140
CWA 14050-1:2000
14.3
XFSCONF.H
/******************************************************************************
*
*
* xfsconf.h
XFS - definitions for the Configuration functions
*
*
*
*
Version 3.00 -- 10/18/00
*
*
*
******************************************************************************/
#ifndef __INC_XFSCONF__H
#define __INC_XFSCONF__H
#ifdef __cplusplus
extern "C" {
#endif
/******* Common **************************************************************/
#include
<xfsapi.h>
/*
be aware of alignment
#pragma pack(push,1)
//
//
//
//
*/
WINAPI
HRESULT extern
WINAPI
HRESULT extern WINAPI WFMEnumKey ( HKEY hKey, DWORD iSubKey, LPSTR lpszName,
LPDWORD lpcchName, PFILETIME lpftLastWrite);
HRESULT extern WINAPI WFMEnumValue ( HKEY hKey, DWORD iValue, LPSTR lpszValue,
LPDWORD lpcchValue, LPSTR lpszData, LPDWORD lpcchData);
HRESULT extern
WINAPI
*/
#ifdef __cplusplus
}
/*extern "C"*/
#endif
#endif
/* __INC_XFSCONF__H */
Page 141
CWA 14050-1:2000
14.4
XFSSPI.H
/******************************************************************************
*
*
* xfsspi.h
XFS - SPI functions, types, and definitions
*
*
*
*
Version 3.00 -- 10/18/00
*
*
*
******************************************************************************/
#ifndef __inc_xfsspi__h
#define __inc_xfsspi__h
#ifdef __cplusplus
extern "C" {
#endif
#include <xfsapi.h>
typedef HANDLE HPROVIDER;
#include <xfsconf.h>
#include <xfsadmin.h>
/*
be aware of alignment
#pragma pack(push,1)
*/
);
*/
#ifdef __cplusplus
}
/*extern "C"*/
#endif
#endif
/* __inc_xfsspi__h */