Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  • 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

...

  1. Go to Service > Stations and Devices
  2. Select a required restaurant and go to the cash server
  3. In the server properties:
    • Specify a free port in the HTTP Data Port field. Optionally, enable the Use Free Listen Port setting to make the server choose a different port when the port specified in the HTTP Data Port property is busy.
    • In the HTTP Restrictions Rights section, select the HTTP _ Access privilege in all fields
      Image Added
  4. Save Changesthe changes
  5. Reboot Restart the cash server.

If you want need to create a separate privilege and role with HTTPS access right, click below.

Expand
titleCreating a Privilege and a Role
  1. Go to

...

  1. Service > Manager Station > Object Privileges

...

  1. Add a new privilege,

...

  1. for example HTTP_port

...


  1. Image Added
  2. Go to

...

  1. Options > OLAP Reports >

...

  1. Reporting Servers
  2. Select the required

...

  1. reference server
  2. In the server properties:
    • In the HTTP Server section, find the HTTP Data Port field and enter a free port.

...

    • Check the Use Free Listen Port

...

    • box to

...

    • make the program select a different port when the port specified in the HTTP Data Port property is busy.
      To access the web interface of this server, you can use:
      • The port specified in the reference server properties

...

      • in the manager

...

      • station  — HTTP Data Port
      • The port specified in

...

      • the [TSPSOC] section

...

      • of rk7srv.ini — the port parameter

...

    • In the HTTP

...

    • Rights section,

...

    • select the created privilege in all fields
    • In the Restrictions section, include the created privilege in the object privilege
      Image Added
  1. Save Changes
  2. Restart the server
  3. In the manager station, go to

...

  1. Service > Stations and Devices
  2. Select a required restaurant and go to the cash server
  3. In the server properties:
    • In the HTTP Server section, find the HTTP Data Port field and

...

    • specify a free port.
      Enable the Use Free Listen Port setting to

...

    • make the program select a different port when the port specified in the HTTP Data Port property is busy.
      To access the web interface of this server, you can use:
      • The port specified in the reference server properties

...

      • in the manager

...

      • station  — HTTP Data Port
      • The port specified in

...

      • the [TSPSOC] section

...

      • of rk7srv.ini — the port parameter

...

    • In the HTTP

...

    • Rights section,

...

    • select the created privilege in all fields
      Image Added
  1. Create a role with rights to the created privilege
    Image Added

    Info

    When authorizing HTTPS requests, only the roles of the current restaurant and the

...

  1. head office are used.


  2. For the created role, add an employee, set a password for him.
    The name and password of this employee will be used for authorization on the server via HTTPS.

...

  1. Image Added

Requests to the cash server should be sent to the following URL:

Code Block
https://*IP:HTTPDataPort*/rk7api/v0/xmlinterface.xml

IP:HTTPDataPort you You need to specify your own IP:HTTPDataPort.

To access the interface, you must 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 must should be performed in UTF-8 encoding.

...

Testing XML Interface with Built-in

...

Utility

To validate an test the XML interface over an via the HTTPS interface:

...

  • login information of the created employee: the username and the password
  • Enter the text of the XML request to execute
  • Click the Execute button
    The result should be like the picture below:
    Image Added

Authentication and

...

Request Execution

For authentication and authorization, the name and the password of the employee from r_keeper 7 are used.

The WEB interface at the time of this writing has the following limitations:

...

...

After specifying the right and assigning it to the corresponding role, you can check the correctness of the settings by opening the corresponding pages in the WEB interface.

Enter one of the options variants in the address bar, an authorization window will appear - enter the employee's name of the employee and password. Please note that you need to enter your own IP and port.

  • The

...

...


  • Image Added

Executing Request

...

via wget

An example of making a request using the wget utility:

Code Block
wget.exe --secure-protocol=TLSv1 --no-check-certificate --header="Content-Type: text/xml" --http-user

...

=9006 --http-password=9006 --post-file=requestData.xml https://127.0.0.1:20001/rk7api/v0/xmlinterface.xml

Request parameters:

  • User: --http-user=9006
  • Password: --http-password=9006
  • Request file: --post-file=requestData.xml

After executing such a request, its result will be saved to the xmlinterface.xml file.

...

Configuring XML Interface Using rk7xml.dll

Info
titleAttention!

This way of interacting with the XML interface is not recommended due to lack of authorization.


Expand
titleInstructions for

...

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

...

cash server:

  1. Go to

...

  1. Service > Stations and Devices
  2. Select a required restaurant and go to

...

  1. its cash server
  2. On the

...

  1. Drivers tab, add the XML Interface For Windows driver
  2. Write the port in the Port parameter
    Image Added
  3. Bind the added interface to a logical interface in the

...

  1. Service > Interfaces

...

  1. reference.
    By default, the system

...

  1. already

...

  1. has a pre-installed XML interface with code 104. For each external application, you can make a copy of this interface and

...

  1. bind it with the driver on the

...

  1. cash server

...


  1. Image Added
  2. After binding the interface, restart the cash server. Check that the interface is loaded in the cash server properties
  3. 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
  4. Functions are called via RK7XML.dll, an interface module:
    1. CallRK7XMLRPC

...

    1. function

...

    1. Parameters:
      • AddressName

...

      • address:port
      • Request

...

      • 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
    1. CallRK7XMLRPCToStream function

...

    1. similar to the function above, but its result is written to the IStream stream

...

    1. Parameters:
      • AddressName

...

      •  — address:port
      • Request

...

      • XML ​​request
      • RequestSize

...

      •  — XML ​​request size
      • ResultStream

...

      • IStream

...

      • the stream where the result is transferred
      • ErrorBuf

...

      • the place where connection errors are written
      • ErrorBufSize — ErrorBuf size
    1. The SetUseTempFileLimit function sets the file size limit if the result return time exceeds the threshold.

...

    1. The default value is 1000000ms
    2. GetDLLVersion function

...

    1. returns the DLL version
    2. SetCryptKey function

...

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

...


ResultFile: PChar;

...


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.

...


ResultStream: IStream;

...


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
titleThe launch example

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

...

Parameters description:

  • 127.0.0.1:1122

...

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

...


<RK7Query>

...


<RK7CMD CMD="GetSystemInfo"/>

...


</RK7Query>


For convenience, there is a utility with a graphical interface TestXML.zip.

Request

...

Logging

Expand
titleEnabling request logging when using HTTPS
  1. Go to

...

  1. Service > Stations and Devices
  2. Select a required restaurant and go to

...

  1. its cash server
  2. In the

...

  1. 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
titleEnabling request logging when using RK7XML.dll
  1. Go to

...

  1. Service > Stations and Devices
  2. Select a required restaurant and go to

...

  1. its cash server
  2. On the

...

  1. Drivers tab, select one of the XML Interface For Windows drivers
  2. 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

...

INxxxxx.XML and

...

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.