You are viewing an old version of this page. View the current version.

Compare with Current View Page History

Version 1 Next »

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.

There are two variants to set up notifications:

  • 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.

Events are sent by the driver strictly in FIFO order. At the moment, the maximum number of events in the queue is 256. Once it is reached, newer events are not accepted until there is space for them. This mechanism is intended to prevent memory overflow and a cash server crash in case it is impossible to send messages, for example, if the event reception server does not respond.

For each address, there is a separate mailing list, as well as a separate log file. After the cash server is stopped, pending events will not be sent.

There is no waiting interval (timeout) for data delivery as the driver tries to send data immediately upon their arrival.

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:

<?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 server identifier is filled in. Please note that this event does not arrive immediately after the driver is loaded but after the POS server notifies the driver on its availability.

When the POS station is started, a similar message is queued, but it has an extended set of nodes:

<?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 server and data on the POS station. This mechanism allows to separate the events of the POS server loading and POS station loading for their separate processing.

The GUID shown in the example is not a constant and can be changed.

Supported commands sent by the driver (the Situation attribute):

Situation

Event

1

POS server or POS station start

3

Order changing

4

Order calculation

5

Receipt closing

9

Closing the order

10

POS station locking (logoff)

11

Creation of a New Order

12

Opening an existing order

13

Order saving

14

Receipt deleting

18

POS station closing

21

POS 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

<?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>

Creation of a New Order

<?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

The HTTP address to which data are sent. It is entered in the conventional URL address format. Can contain only one address. If you need to send data to multiple HTTP servers, an individual HTTP Order Notify driver must be added for each of those servers

Troubleshooting

When functioning, the driver adds information on its work to the log to facilitate localization of possible issues. A regular problem is that data does not arrive to the receiving HTTP server. In this case you should check the correctness of the address in the DestURLs parameter of the driver and the HTTP server health. If it is impossible to send data, the log will have messages containing the substring "HTTP: Post error", for example:

18.12.2019 16:25:32:343 HTTP: Post error: Socket Error # 10061

Frequently encountered 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

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:

XML: Can't add command. Max queue size: 256


 

  • No labels