The illustrative embodiments described in the present application are useful in systems including those for providing controlled access to value dispensing devices and more particularly are useful in systems including those for providing controlled access to a postage meter from multiple programs executing on an external collocated processor.
Value storage and dispensing devices including postage meters have been in use including the DM SERIES mailing machines including postage meters available from PITNEY BOWES INC. of Stamford, Conn. Such devices typically do not provide user access from a collocated processor through multiple programs.
The MAILSTATION mailing machine is an example of a mailing machine including a postage meter that is available from PITNEY BOWES INC. of Stamford Conn. The MAILSTATION system includes a multi-line display and a keypad for providing user access for configuring and using the mailing machine. Additionally, the MAILSTATION mailing machine includes an analog modem communications subsystem that is useful for communicating with a remote data center to process transactions such as postage refill operations.
The present application describes illustrative embodiments of systems and methods for providing controlled access to value dispensing devices and in certain illustrative embodiments describes systems and methods for providing controlled access to a postage meter from multiple programs executing on an external collocated processor.
In one illustrative example, a collocated processor configured with a proxy server program arbitrates access to a mailing machine through a communications channel by managing exclusive access requests to the mailing machine.
In another illustrative embodiment, a mailing machine manages exclusive access requests by locking out an embedded user interface while servicing exclusive access requests from a collocated processor.
In yet another illustrative example, a collocated processor configured with a proxy server program retrieves authentication data from a remote data center in order to determine whether a requesting PC application is authorized to access the mailing machine.
The accompanying drawings illustrate several alternative embodiments of the invention, and together with the general description given above and the detailed description given below, serve to explain the principles of the invention. As shown throughout the drawings, like reference numerals designate like or corresponding parts.
The illustrative embodiments of the present application describe systems and methods including those that are useful for providing controlled access to value dispensing devices. In certain illustrative embodiments, the application describes systems and methods for providing controlled access to a postage meter from multiple programs executing on an external collocated processor.
The illustrative embodiments described here are described as modifications to the MAILSTATION mailing machine available from Pitney Bowes Inc. of Stamford, Conn. Such mailing machines incorporate a postage meter. The modified mailing machine described herein may receive operating input from several different controlling sources. It may receive operator input through the traditional integrated keypad and display user interface. It may also receive operating input data from a collocated processor such as a PC configured to run a control program designed specifically to use as an interface to the mailing machine.
Moreover, the mailing machine may receive operating input from one or more types of multi-purpose software such as third-party shipping solution software running on the collocated processor. One possible multi-purpose third-party program that could be configured to interface with illustrative embodiments described herein includes the modified SHIPPING ASSISTANT available from the United States Postal Service (USPS).
In at least some embodiments, the collocated processor is configured to execute a specific purpose program designed to manage access to the mailing machine from the multi-purpose software running on the collocated processor. In at least some of the embodiments, only one input source may control the mailing machine at a particular time. Accordingly, systems and methods for controlling access to the mailing machine are described to ensure that control contention issues do not arise. If more than one source were permitted access without appropriate safeguards, user confusion and/or inappropriate meter actions might occur.
In at least some of the embodiments, a common special purpose Proxy program is installed on a collocated processor. All of the multi-purpose PC Software Applications must be designed to communicate through the common Proxy program using its Application Program Interface (API) calls. The Proxy program then communicates using a communications interface and protocol such as the Universal Serial Bus (USB) interface to the mailing machine.
The Proxy program may be a portion of a MAILSTATION ASSISTANT special purpose program (a dedicated external user interface, PC APP #2) designed to interface with the MAILSTATION mailing machine. The special purpose assistant program includes an API that permits other PC Software Applications to interact with the assistant program and therefore the mailing machine operatively connected to the assistant software. The Proxy program is configured to act as the arbitrator in granting access to the mailing machine from the multi-purpose PC applications.
When the Proxy program is successful in obtaining such exclusive access for a PC Software Application, the mailing machine and postage meter is captured for exclusive use by that requesting PC Software Application. In at least some embodiments, once exclusive use is granted, the meter keypad and display in order are locked by the meter to prevent the meter from being operated using the embedded keypad and display.
Certain illustrative embodiments described herein may be used to provide multiple access arbitration to a mailing machine without requiring extensive redesign of components of a traditional mailing machine such as the internal user interface and operating programs. As described herein, a mailing machine and associated postage meter may maintain a state that is consistent with user intentions, thus avoiding user confusion and possible wasted postage. Furthermore, the described Proxy Server software and interface specification may be restricted to approved vendors for creation of compatible third-party PC Applications.
Referring to
Referring to
Data Center 240 includes a suitable processing system having a computing device such as a server computer and one or more memory components for data storage. The Data Center 240 may include server computers such as those available from DELL Corp. The collocated processor comprises an x86-based desktop PC computer such as those available from DELL Corp. including a WINDOWS operating system such as the WINDOWS XP operating system available from MICROSOFT. The collocated processor includes a CPU, a mass storage device such as a hard drive and working memory such as RAM memory.
Referring to
The Proxy Server may also communicate through network 230 with the data center 240 using the TCP/IP protocol stack 324. PC SW App 2 includes the special purpose user interface program designed to operate with mailing machine 210. PC SW App 1 is a representative multi-purpose software application program that is not necessarily dedicated to interfacing with the mailing machine such as the USPS modified SHIPPING ASSISTANT program. As an alternative, the third-party software application may also be a single purpose program dedicated to interfacing with the mailing machine. Furthermore, additional PC SW Applications may be executing in user space 305 and enabled to request exclusive access to mailing machine 210.
Referring to
Additionally, the MAILSTATION ASSISTANT application may be used to read mailing machine status and obtain information such as error conditions, postage balance and postage meter state. The MAILSTATION ASSISTANT may also utilize its connection to the remote Data Center in order to update the mailing machine embedded software, update postal rate tables and add custom advertising slogan images as appropriate. Furthermore, the modified SHIPPING ASSISTANT application or other non-dedicated application may read postage meter status, read the mailing machine scale weight, zero the scale and set the postage value. Alternatively, the MAILSTATION ASSISTANT may also be configured to perform those functions. Accordingly, the sample messages in the illustrative message sequence diagram 400 are not limited to the messages shown, but could include messages related to all of the interface functions possible with the multiple programs executing on the external collocated processor.
When message 430 is sent to the Proxy Server 412 to request exclusive access through a CaptureProxyServer message, the Proxy server acts. The Proxy server denies the request if another program currently has exclusive access. If available, the Proxy server sends a Capture command to the mailing machine 410 across channel 402. If the mailing machine is available, it accepts the capture command. Then the Proxy server 412 sends a ProxyServerCaptured message 432 to PC SW App 2 and broadcasts a notify message 434 to the operating system. Thus at about time A, PC SW App 2 is the Active User of the Proxy Server and is provided exclusive access to the mailing machine in order to perform various operations.
PC SW App 2 then sends a RefillPostage message 436 to initiate a postage refill, followed by a CheckBalance message 438 in order to check the balance of the postage meter. PC SW App 2 then sends an UpdateMeter message 440 to update the postage meter and then releases the exclusive access by sending a ReleaseProxyserver message 442. The Proxy server 412 receives that message and sends a Release command to the mailing machine using channel 402. The Proxy Server 412 also broadcasts a notify message 444 to the operating system to inform the other programs that the Proxy server has been released.
PC SW App 1416 is registered to receive the broadcast Notify 434 event such that message 450 ProxyServerisNotAvailable is sent to it. Thus, at about time B, PC SW App 1 is informed that the Proxy server is not available. PC SW App 1416 is registered to receive the broadcast Notify 444 event such that message 452 ProxyServerisAvailable is sent to it. Thus, at about time C, PC SW App 1 is informed that the Proxy server is available. If the Proxy server receives an exclusive access request while another program has exclusive access to the mailing machine, the Proxy server is configured to reject the later request and provide a status message.
Since the Proxy server is available, PC SW App 1 will be able to successfully request exclusive access (so long as the embedded user interface is not being utilized). Therefore, message 454 CaptureProxyServer is sent. Since the Proxy server is available, a capture command is sent to the mailing machine. If accepted, the Proxy Server sends message 456 ProxyServerCapturedbyThirdPartySoftware and to provide exclusive access and also sends a broadcast notify message 458.
Thus, at about time D, PC SW App 1 is the Active User of the Proxy server and can now exclusively access the Proxy Server. The PC SW App 1 can then pass through a CaptureMeter command to obtain exclusive access to the mailing machine if the embedded user interface is not being used. If the Proxy server receives an exclusive access request while another program has exclusive access to the mailing machine, the Proxy Server is configured to reject the later request and provide a status message. PC SW App 2414 is registered to receive the broadcast Notify 458 event such that message 446 ProxyServerisNotAvailable is sent to it. Thus, at about time E, PC SW App 2 is informed that the Proxy Server is not available.
Message 460 MeterStatusRequest is sent through the Proxy server and a Response provides a MeterStatus=Idle message 464 to indicate the meter is idle. Since the postage meter is idle, exclusive access will likely be granted when requested. Accordingly, when message 464 CaptureMeter is sent, the meter is configured for exclusive access by PC SW App 1. Accordingly, when message 466 SetPostage is sent, the meter then franks an envelope or meter tape when inserted with the amount of postage set by the message. The mailing machine provides a SetPostageResponse message 468 to provide postage meter status. Message 470 Release Meter is sent through the Proxy Server to inform the mailing machine postage meter to release exclusive control.
Thereafter, message 472 ReleaseProxyServer is sent to release the Proxy Server for access by other programs on the collocated processor. Thus, at about time F, PC SW App 1 has release exclusive access to the Proxy server and notice message 474 is broadcast. PC SW App 2414 is registered to receive the broadcast Notify 474 event such that message 448 ProxyServerisAvailable is sent to it. Thus at about time G, PC SW App 2 is informed that the Proxy server is available.
Referring to
In an alternative, the Proxy server provides two levels of exclusivity. First, the Proxy server may be captured such that only one of the PC SW programs has access. Then, during a subset of time when the Proxy Server is captured, the mailing machine may be captured such that the embedded user interface is also locked out. Accordingly, the Proxy Server may be captured by the modified SHIPPING ASSISTANT application and yet still allow operation of the embedded user interface until the mailing machine is captured. Therefore, the modified SHIPPING ASSISTANT program may capture the meter only when needed so that the user may still utilize the mailing machine using the embedded user interface when the mailing machine is not locked by the modified SHIPPING ASSISTANT application.
In step 520, if the Proxy server does not have an Active Meter Capture, it sends a Capture Request to the mailing machine and postage meter. In step 530, if the mailing machine is available, it accepts the meter capture request and sends an associated notification that is received by the Proxy Server. In step 540, the Proxy server registers the PC Software App as the Active User and returns a BUSY notice to any other requesters. In step 550, the Proxy server issues an event notification to the operating system noting the meter capture condition. Each of the relevant programs configured to utilize the proxy server will have been registered to receive such event notifications from the operating system.
In step 560, the Proxy Server receives a Release Command from the PC SW App and unregisters the PC SW App as the Active User. The Proxy Server sends the Release Command to the mailing machine/postage meter. In step 570, the Proxy server receives confirmation of the release from the mailing machine and issues an event notice to indicate that the mailing machine/postage meter is available.
Referring to
Otherwise, in step 640, the meter accepts the capture command and locks out the embedded user interface. For example, the display may provide a message stating that the meter is under PC control. Alternatively, the meter may also provide a message stating the embedded user interface control may be regained using a master password or the like.
In step 650, the meter sends a capture acceptance notice and starts a timer. In step 660, the meter releases the capture condition if it suffers a critical error, a timeout of the timer or a master override from the embedded user interface keypad. In step 670, the meter releases the capture condition upon a request from the Proxy server and then sends a notice of the capture release and the meter process ends and returns control to the traditional meter control.
In a Meter Capture process, the Proxy accepts a Capture command from a PC Software Application and registers the PC Software Application as the Active User of the meter. Next, the Proxy prevents other PC Software Applications from accessing the meter based on the existence of a registered Active User. The Proxy returns a ‘busy’ state to any requesting applications and also notifies any running application that an Active User has been granted access to the meter.
Once a registered user is identified, the Proxy acts to Capture the meter for the exclusive use of the requesting application by sending a Capture command to the meter via the USB Driver/USB port. The meter receives the Capture command and returns a response indicating whether the Capture was a success or not. Once the meter accepts the Capture command it locks its keypad and display to prevent local user interaction.
In a Meter Release process, The Proxy accepts a meter Release command from PC Software Application and unregisters the PC Software Application as the Active User. Next, the Proxy sends a Release command to the meter. This puts the meter in a state in which it can be used standalone using the local keypad and display.
The Meter prevents Capture and returns its current status under certain critical error conditions. The Meter also prevents user keypad interaction when Captured except under critical error conditions. If a critical error condition occurs while Captured, the meter exits its Capture mode and annunciates an error to the registered Active User. The Meter releases itself and goes to sleep after a timeout period such as 10 minutes if no Release command is ever received. This prevents the meter from remaining Captured should the registered Active User go off-line unexpectedly.
The PC software programs described herein are written in “C++” using the MICROSOFT VISUAL STUDIO development environment and the .NET framework. However, other appropriate languages and development environments may be utilized.
In an alternative applicable to any of the illustrative embodiments herein, the Proxy Server 312 may communicate with the data center 240 using the TCP/IP stack 324 to obtain valid signatures for authorized PC SW APPs. The digital signatures may be used to authenticate any of the PC SW APPs before providing user interface access to the mailing machine 210.
In an alternative applicable to any of the illustrative embodiments herein, the mailing machine 210 may be configured to allow an operator to override the lockout condition upon correct entry of a system or configurable password. The system may be configured to allow a certain transition period before passing control back to the embedded user interface. Additionally, the mailing machine 210 may be configured to send an event through USB to the collocated processor to disconnect the proxy server.
In an alternative applicable to any of the illustrative embodiments herein, the mailing machine 210 may be configured to allow read access by the external collocated processor to certain data such as the current scale reading without requiring lockout of the postage meter embedded interface.
In another alternative applicable to any of the illustrative embodiments herein, the collocated processor 220 also includes a physically secure cryptographic processor such as an IBUTTON used to authenticate the processor 220 to the mailing machine 210. The multi-purpose software applications may be authenticated in several ways. Initially, a public key cryptographic authentication process may be used for a challenge/response authentication. The proxy server software may also be utilized to check for a valid cryptographic digital signature of the executing version of the multi-purpose software application. A table of signatures may be stored in the collocated processor proxy server application or may be stored in a physically secure cryptographic coprocessor connected to the collocated processor 220. Similarly, each message on the USB bus between the mailing machine and the collocated processor may be cryptographically secured and/or authenticated.
In yet another alternative applicable to any of the illustrative embodiments herein, the collocated processor 220 executes an “open” PC postage application that utilizes the PSD vault of the collocated mailing machine. Illustrative “virtual meter” systems are referred to and described in commonly-owned U.S. Pat. No. 6,619,544 B2, entitled System And Method For Instant Online Postage Metering, issued Sep. 16, 2003 to Bator, et al. and incorporated herein by reference. As an alternative here, the systems and methods referred to and described therein are modified such that the collocated processor 220 is configured to produce “open” indicium using the PCIBI-O specification available from the USPS, but by using the meter license and funds stored in the PSD of the collocated mailing machine 210.
Co-pending, commonly-owned U.S. patent application Ser. No. 11/645,980 entitled “Simultaneous Voice and Data Systems for Secure Catalog Orders,” filed Dec. 27, 2006 by Jeffrey D. Pierce, et al., describes systems for simultaneous voice and data systems and is incorporated herein by reference. In yet another alternative applicable to any of the illustrative embodiments herein, the systems and methods described therein may be utilized with the systems and methods described here.
While illustrative embodiments of the invention have been described and illustrated above, it should be understood that these are exemplary of the invention and are not to be considered as limiting. Additions, deletions, substitutions, and other modifications can be made without departing from the spirit or scope of the present invention. Accordingly, the invention is not to be considered as limited by the foregoing description.
Number | Name | Date | Kind |
---|---|---|---|
6151590 | Cordery et al. | Nov 2000 | A |
6157919 | Cordery et al. | Dec 2000 | A |
6865557 | Cordery et al. | Mar 2005 | B1 |
7076736 | Hugh | Jul 2006 | B2 |
7490089 | Georgiev | Feb 2009 | B1 |
20020077991 | Heimann et al. | Jun 2002 | A1 |
20020143713 | Stutz | Oct 2002 | A1 |
20030117434 | Hugh | Jun 2003 | A1 |
20070136216 | Simcik et al. | Jun 2007 | A1 |
Number | Date | Country |
---|---|---|
0927959 | Jul 1999 | EP |
1739628 | Jan 2007 | EP |
Number | Date | Country | |
---|---|---|---|
20090172126 A1 | Jul 2009 | US |