Introduction
The interface is designed for sending the information on cash station events through the HTTP protocol to the address indicated in the driver parameter.
The main task is to transfer data on order changes, but other cash station events are also supported.
...
- Using the mailing mechanism for version 7.6.5.440 and later
- Via HTTP Order Notify interface for versions earlier than 7.6.5.440
Procedure
Once started, the driver waits either for the cash station events or for the cash server to shut down.
...
The driver is loaded once the cash server is started. Regardless of the cash station availability, the message on the cash server start with the Situation = 1 is put on a queue. This event is similar to the ordinary cash start but with a limited number of nodes.
An example message appearing after cash server loading and initializing:
Anchor | ||||
---|---|---|---|---|
|
Code Block |
---|
<?xml version="1.0" encoding="utf-8"?> |
...
<a RestCode="199990093" DateTime="2020-01-14T15:38:23" Situation="1" seqnumber="1" guid="{9ECCB1B5-97EE-4B88-9840-8568F05586D0}" name="Started" ShiftNum="1" ShiftDate="2019-11-18T00:00:00"> |
...
<Server id="15002"/> |
...
<Item/> |
...
</a> |
In this event, only the POS cash server identifier is filled in. Please note that this event does not arrive immediately after the driver is loaded but after the POS specified. If the address is specified in the cash server properties, the server notifies the driver on about its availability. After that, the event occurs.
When the POS cash station is started, a similar message is queued, but it has an extended set of nodes:
Code Block |
---|
<?xml version="1.0" encoding="utf-8"?> |
...
<a RestCode="199990093" DateTime="2019-12-18T17:17:58" Situation="1" seqnumber="1" guid="{9ECCB1B5-97EE-4B88-9840-8568F05586D0}" name="Started" ShiftNum="1" ShiftDate="2019-11-18T00:00:00"> |
...
<Station id="15003" code="1" name="MM_CASH" NetName="MM_CASH_169058"/> |
...
<Server id="15002" code="15002" name="MM_MID" NetName="MM_MID"/> |
...
<Item/> |
...
</a> |
It has both the extended information on the POS cash server and data on the POS cash station. This mechanism allows to separate separating the events of the POS cash server loading and POS cash station loading for their separate processing.
...
Supported commands sent by the driver (in the Situation attribute):
Situation | Event |
1 | POS Cash server or POS cash station start |
3 | Order changing |
4 | Order calculation |
5 | Receipt closing |
9 | Closing the order |
10 | POS Cash station locking (logoff) |
11 | Creation of a New Ordernew order |
12 | Opening an existing order |
13 | Order saving |
14 | Receipt deleting |
18 | POS Cash station closing |
21 | POS Cash station sign in |
24 | Switching to the receipt print mode |
You will not find a detailed description of these commands here, but some commands are relatively simple while others, for example, order changing (3), can contain varying data depending on the actions that include adding or deleting dishes, discounts, modifiers, prepayments, payments; changing the dish quantity or prices, etc.
XML Examples
Signing into the POS Station
...
HTTP Order Notify Licensing
If you need more than one connection, the HttpOrderNotify interface must be licensed.
The license must be activated starting from version 7.6.5.459. The license in the licensing system is called R-Keeper module Order notification interface 12 months software.
HTTP Order Notify Interface
HTTP Order Notify works on the side of the cash server to which the cash station is connected. The driver is added to the cash server.
For the correct loading of the driver, it is necessary to bind the interface for the cash server to it. Find more information below.
For r_keeper versions earlier than 7.6.5
Add HTTP Order Notify to the cash server:
Parameters:
Name | Description and Possible Values |
---|---|
Log File | The path to the file, that will serve as a driver operation log. It may be absent, but in this case, it would be difficult to define the operation problems. |
LogLevel | Logging level. There are three possible values:
|
DestURLs | HTTP address where the data will be sent to. Has the commonly used form of URL addresses. |
For the cash server to download the driver, bind it to the interface:
- In the manager station, go to Service > Interfaces
Create a new interface with the following properties:
NameDescription and Value[Cash server name] select the driver added to the cash server Common DLL Name specify the driver file name, always httpnotf.dll - Restart the cash server.
For r_keeper version 7.6.5 and later
Driver parameters are specified in the HTTP Order Notify properties of the cash server.
Parameters:
Name | Description and Possible Values |
---|---|
DestURLs | HTTP addresses where the data will be sent to. Have the commonly used form of URL addresses. Can contain several addresses, separated by semicolons. There are certain license restrictions when several addresses are specified. |
Log File Name | The path to the file, that will serve as a driver operation log. It may be absent, but in this case, it would be difficult to define the operation problems. The address' number from the addresses list is added to the log file name, starting from zero. Thus, if a log file name is httpnotf.stk, the file name will be httpnotf0.stk for the first address, httpnotf1.stk — for the second one, and so on. |
Log Level | Logging level. There are three possible values:
|
The value of the DestURLs parameter is used only when starting the cash server. After changing this setting, restart the cash server to change the address list. To change the address list while the server is running, use the subscription mechanism.
Expand | ||
---|---|---|
| ||
For r_keeper 7.6.5 and later
For r_keeper versions earlier than 7.6.5If your r_keeper version is earlier than 7.6.5, you should add the HTTP Order Interface to the cash station manually. To do this:
|
Note |
---|
In versions later than r_keeper 7.6.5, the HTTP Order Notify driver works only through the subscription mechanism, using the interface is not supported. |
Subscription Mechanism
To make the cash server send the notifications about changes, send the following POST request to it:
Code Block |
---|
https://127.0.0.1:8001/rk7api/v1/subscribe.xml?service=httpnotf&url=https://HTTP_KDS2:1@172.18.2.2:1234/orderTaker |
where:
Parameter | Meaning |
---|---|
service | The service name, should be httpnotf |
url | URL to send notifications to |
The address specified in the URL parameter will be added to the list of existing mailing addresses. An event with name=Started will be immediately sent to it.
If the number of addresses exceeds the available, then r_keeper will issue an error: HttpOrderNotify: address URL is disabled, license check failed.
XML Examples
Cash Station Authorization
Code Block |
---|
<?xml version="1.0" encoding="utf-8"?> |
...
<a RestCode="199990093" DateTime="2019-12-18T17:18:00" Situation="21" seqnumber="3" guid="{81A89081-D394-4070-BD37-A8E54CCA7B56}" name="Login" ShiftNum="1" ShiftDate="2019-11-18T00:00:00"> |
...
<Station id="15003" code="1" name="MM_CASH" NetName="MM_CASH_169058"/> |
...
<Server id="15002" code="15002" name="MM_MID" NetName="MM_MID"/> |
...
<Waiter id="1" code="7" name="Administrator"> |
...
<Role id="100007" code="7" name="Administrators"/> |
...
</Waiter> |
...
<Item/> |
...
</a> |
...
Creating New Order
Code Block |
---|
<?xml version="1.0" encoding="utf-8"?> |
...
<a RestCode="199990093" DateTime="2019-12-18T17:18:33" Situation="11" seqnumber="13" guid="{833F0492-E8ED-4F34-81BC-8A9F4D73A995}" name="New Order" ShiftNum="1" ShiftDate="2019-11-18T00:00:00"> |
...
<Station id="15003" code="1" name="MM_CASH" NetName="MM_CASH_169058"/> |
...
<Server id="15002" code="15002" name="MM_MID" NetName="MM_MID"/> |
...
<Waiter id="1" code="7" name="Administrator"> |
...
<Role id="100007" code="7" name="Administrators"/> |
...
</Waiter> |
...
<Order visit="477823977" orderIdent="256" guid="{763C7F09-875A-438A-B6CB-25F7D3F74741}" url="http://code.ucs.ru/qr?id=209A9A2B872A4728BEC8F0B09C667E6A763C7F09875A438AB6CB25F7D3F74741B6995A91" orderName="8888888888" locked="1" version="0"crc32="0" orderSum="0" unpaidSum="0" discountSum="0" totalPieces="0" seqNumber="1" paid="1" finished="0" persistentComment=""nonPersistentComment="" openTime="2019-12-18T17:18:32"> |
...
<Creator id="1" code="7" name="Administrator"> |
...
<Role id="100007" code="7" name="Administrators"/> |
...
</Creator> |
...
<Waiter id="1" code="7" name="Administrator"> |
...
<Role id="100007" code="7" name="Administrators"/> |
...
</Waiter> |
...
<OrderCategory id="10033" code="1" name="Main"/> |
...
<OrderType id="10069" code="9001" name="not selected"/> |
...
<Table id="1000259" code="93" name="8888888888"/> |
...
<Station id="15003" code="1" name="MM_CASH"/> |
...
<Guests count="1"> |
...
<Guest guestLabel="1"/> |
...
</Guests> |
...
</Order> |
...
<Session uni="2" line_guid="{39271E37-867D-41FF-99B8-59CB182323E9}" state="1" sessionID="2" isDraft="0" remindTime="2019-12-18T17:18:00" startService="2019-12-18T17:18:33" printed="0" cookMins="0"> |
...
<Station id="15003" code="1" name="MM_CASH"/> |
...
<Author id="1" code="7" name="Administrator"> |
...
<Role id="100007" code="7" name="Administrators"/> |
...
</Author> |
...
<Creator id="1" code="7" name="Administrator"> |
...
<Role id="100007" code="7" name="Administrators"/> |
...
</Creator> |
...
<Course id="1" code="1" name="Cook later"/> |
...
<PriceScale id="3" code="1" name="Main"/> |
...
<TradeGroup id="7" code="1" name="By default"/> |
...
</Session> |
...
<Item ClassName="TOrder"/> |
...
</a>
Setup
Now you add the HTTP Order Notify driver to the POS server
Here you should define three parameters:
...
Name
...
Description and possible values
...
Log File
...
The path to the file that will be used as a driver action log. Can be missing but in this case it will be difficult to identify issues in driver functioning
...
LogLevel
The logging level, can take one of the following three values:
Value | Description |
0 - errors only | In this mode, the log will have only the most important messages (for example, notifications on interface loading) or error messages: exceeded number of events in the queue, failure to send data to the HTTP server, etc. |
1 - input xmls and errors | In this mode, in addition to the errors only mode, some other important messages are added, for example, those on the start of sending XMLs to the HTTP server address |
2 - max log | The most complete logging mode that comprises the most detailed information on driver functioning including incoming and outgoing XMLs, the status of the messaging queue, etc. |
...
DestURLs
...
</a> |
Troubleshooting
When functioning, the driver adds information on its work to the log to facilitate localization of possible issuestroubleshooting.
A regular problem is that data does not arrive to the receiving HTTP server. In this case you should check the correctness of , check if the address in the DestURLs parameter of the driver is correct and the HTTP server healthis available. If it is impossible to send data, the log will have messages containing the substring "HTTP: Post error" substring, for example:
Code Block |
---|
18.12.2019 16:25:32:343 HTTP: Post error: Socket Error # 10061 |
Frequently encountered Frequent error codes:
HTTP Code | Description |
10061 | 'Connection refused' means that it is impossible to connect to the server |
10054 | 'Connection reset by peer' means that the connection is closed by the server |
In this case you should , check the HTTP server settings.
Messages of the type
Code Block |
---|
SEND_THREAD: Signal [Send] ENTER, items in queue: 19 |
contain the current number of objects in the queue. Once the maximum number is reached, the log will display the following message:
Code Block |
---|
XML: Can't add command. Max queue size: 256 |
...