...
- LifeTime — RKeeper 7 Write XML Order — a license is purchased once for a specific object and does not imply any restrictions on requests within this object.
After purchasing a license, you need to generate a license key and add it to the restaurant properties in the manager station. Read more in the article Saving Orders XML Interface - Subscription based — a license for the integration of external applications for 1 or 12 months. SaveOrder, PayOrder, MakeRetunGoods requests must be signed and verified by the licensing system. For more information, see Using the XML Interface by Subscription.
Methods of Data Exchange with XML Interface
There are two ways to exchange data with the XML interface:
Configuring XML Requests Work via HTTPS
...
To access the interface, you need to send a login and password — the name and password of an employee — of the Basic Authorization type when sending each request.
Data exchange with the cash server should be performed in UTF-8 encoding.
Testing XML Interface
...
with Built-in Utility
To test the XML interface via the HTTPS interface:
...
Info |
---|
|
This way of interacting with the XML interface is not recommended due to lack of authorization. |
...
configuring the XML interface using rk7xml.dll |
|
The XML interface works |
...
via the iTCPXML.dll driver. When working with the XML interface via rk7xml.dll, in addition to the settings described above, you must manually add the interface to the |
...
...
- Service > Stations and Devices
- Select a required restaurant and go to
|
...
...
- Drivers tab, add the XML Interface For Windows driver
- Write the port in the Port parameter
Image Added - Bind the added interface to a logical interface in the
|
...
...
- reference.
By default, the system
|
...
...
- has a pre-installed XML interface with code 104. For each external application, you can make a copy of this interface and
|
...
- bind it with the driver on the
|
...
...
Image Added- After binding the interface, restart the cash server. Check that the interface is loaded in the cash server properties
- Start the cash server with the /desktop parameter and open its interface by double-clicking on its tray icon.
The loaded interface should be visible on the Interfaces tab - Functions are called via RK7XML.dll, an interface module:
- CallRK7XMLRPC
|
...
...
...
...
- — XML request
- RequestSize
|
...
- — XML request length
- ResultFile
|
...
- — the name of the file where the result is written
- ErrorBuf
|
...
- — the place where connection errors are written
- ErrorBufSize — ErrorBuf size
- CallRK7XMLRPCToStream function
|
...
- — similar to the function above, but its result is written to the IStream stream
|
...
...
...
- — XML request
- RequestSize
|
...
- — XML request size
- ResultStream
|
...
...
- — the stream where the result is transferred
- ErrorBuf
|
...
- — the place where connection errors are written
- ErrorBufSize — ErrorBuf size
- The SetUseTempFileLimit function sets the file size limit if the result return time exceeds the threshold.
|
...
- The default value is 1000000ms
- GetDLLVersion function
|
...
- — returns the DLL version
- SetCryptKey function
|
...
- — sets the encryption key. It can be different for different cash servers, it is specified in the properties of the XML interface.
The current protocol version 2 assumes control over the execution of commands by the server. In the previous version, it was impossible to know if the last request is completed |
...
in case there was a disconnect after the request started processing.
|
...
For this purpose, now there are new functions — GetLastXMLResult and GetLastXMLResultToStream |
...
. If the response could not be sent after the request was completed, it is stored on the server until a special request is made when calling these functions or until the next request. If the response was successfully sent, it is not stored on the server. In any case, you can always find out the number of the last executed request for a particular ConnectName. ConnectName |
...
— an arbitrary Null-terminated string, a connection identifier RequestNum |
...
— a sequential number of the request, maintained for each connection identifier separately. You must pass 0, otherwise the passed request number will be used. Code Block |
---|
function CallRK7XMLRPC2(AddressName: PChar; ConnectName:PChar; |
|
...
Request: PChar; RequestSize: integer; |
|
...
var RequestNum: DWord; //round trip. If 0, then generated by the server. |
|
...
...
ErrorBuf: PChar; ErrorBufSize: integer):BOOL;stdcall; |
|
...
function CallRK7XMLRPCToStream2(AddressName: PChar; ConnectName, |
|
...
Request: PChar; RequestSize: integer; |
|
...
var RequestNum: DWord; //round trip. If 0, then generated by the server. |
|
...
...
ErrorBuf: PChar; ErrorBufSize: integer):BOOL;stdcall; |
|
...
function GetLastXMLResult(AddressName: PChar; ConnectName:PChar; |
|
...
out RequestNum: DWord; //always returns the number of the last executed request |
|
...
ResultFile: PChar; //result is filled if there was a result data transmission error, after successful transmission it is cleared |
|
...
ErrorBuf: PChar; ErrorBufSize: integer):BOOL;stdcall; |
|
...
function GetLastXMLResultToStream(AddressName: PChar; ConnectName: PChar; |
|
...
out RequestNum: DWord; //always returns the number of the last executed request |
|
...
ResultStream: IStream; //result is filled if there was a result data transmission error, after successful transmission it is cleared |
|
...
ErrorBuf: PChar; ErrorBufSize: integer):BOOL;stdcall; |
|
...
Testing XML Requests with TESTXML.exe
To check the request when using rk7xml.dll, use the XMLTEST.exe utility, which can be downloaded from the link or from the FTP server at: ftp://FTP.ucs.ru/rk7/ForDealers/XMLInterface/.Launch
...
Expand |
---|
|
Please note that when run without parameters, the utility displays usage information: Code Block |
---|
xmltest.exe 127.0.0.1:1122 xmlquery.xml response.xml /pass:password |
|
...
...
- — IP address and port to which the XML interface is configured in r_keeper 7
- xmlquery.xml
|
...
- — file name with XML request
- response.xml
|
...
- — the name of the file where the response should be written
- /pass:password
|
...
- — the password set in the XML interface in r_keeper 7
After execution, the utility will save the response from the r_keeper 7 XML interface to the response.xml file. To check the functionality and correctness of the settings, you can use the following query, which should be saved to the xmlquery.xml file: Code Block |
---|
<?xml version="1.0" encoding="UTF-8"?> |
|
...
...
<RK7CMD CMD="GetSystemInfo"/> |
|
...
For convenience, there is a utility with a graphical interface TestXML.zip.
Request
...
Logging
Expand |
---|
title | Enabling request logging when using HTTPS |
---|
|
- Go to
|
...
- Service > Stations and Devices
- Select a required restaurant and go to
|
...
...
- cash server properties, in the HTTP Server section, specify the HTTP Log path and check the Log HTTP query and response checkbox:
Image Added
|
Expand |
---|
title | Enabling request logging when using RK7XML.dll |
---|
|
- Go to
|
...
- Service > Stations and Devices
- Select a required restaurant and go to
|
...
...
- Drivers tab, select one of the XML Interface For Windows drivers
- Expand the Options section and fill in the OutputDir parameter
Image Added
Be sure to restart the cash server after the changes have been made. Requests will be paired |
...
...
OUTxxxxx.XML. Additionally, you can enable the NoLogginQueries parameter |
...
— it is responsible for disabling logging of the queries specified in the parameter. Specify the required requests in the field. |