Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Section
Column
width50%
Panel
borderColor#CCCCCC
bgColor#FFFFFF
titleBGColor#F0F0F0
borderStylesolid
titleOn the page:

Table of Contents

 

Column


General information

This action starts an external program on the selected Server server of the Axxon-domain.

Note
titleAttention!

We don't recommend running programs with GUI on the Serverserver. If you have problems with running interactive services, refer to the the Windows OS user manual. 

Configuring an action

To configure this action, do the following:

  1. Allow interaction of the server NGP Host service with

  2. the
  3. desktop: StartControl PanelAdministrative ToolsServices

  4. Net Logon
  5. Netlogon PropertiesLog On.
    Image Modified

    Info
    titleNote

    For the Failover server and client installation type (

  6. see
  7. see Installation), you must allow the NGP RaFT supervisor service to interact with desktop.

  8. Add to folder <Axxon One installation directory>\UserScripts\ one or more .bat files with the application startup command.

  9. The
  10.  The command must include a path to the executable file of the program. You can specify a network path, command line parameters (
  11. see
  12. see Run external application on client) and use templates (see Text templates in the action settings).
  13. Go to the Programming tab.
  14. In the Event rules or Cycle rules list, click Create... (see Configuring macros).
  15. Select
  16. the Server
  17. a start condition that triggers a macro (see Configuring start conditions).
  18. Click the Image Added button below start conditions.
  19. From the drop-down list, select General: Run external application on server.
  20. In the Launch external program on server parameter, select the server where you want to run the program
  21. (1)
  22. .
  23. Image RemovedSelect
  24. Image Added
  25. In the Executable files parameter, select a .bat file with the run command
  26. (2)
  27. .
  28. Enter
  29. In the Launch parameters parameter, enter templates, if they were set
  30. via
  31. in a .bat file
  32. (3)
  33. .
    Note
    titleAttention!

    If

  34. the
  35. you expect a wildcard

  36. is expected
  37. to contain spaces and/or some special shell characters (> & | <, and so on) as a result of the query, the template must be enclosed in quotation marks (

  38. “”
  39. ""). For example,

  40. "{rectangles}

  41. ". It is necessary to quote the entire template string.

  42. Click the Apply Image Added button.

Configuration of the Run external application on server action is complete.

Example use

Example 1

:If you apply the following use a bat file with contents:

Code Block
SET "datatime=%1"
SET "cameraIpAddress=%2"
 
msg * Current time is %datatime%, IP-address: %cameraIpAddress%

executing the macro will lead to results in the following message:

Image RemovedImage Added

Example 2

Export : Exporting events about camera status change changes (offlinesignal lost/online) to a csv.bat file containing the followingrestored) in csv format, a bat file with contents:

Code Block
SELECT "timestamp"
    ,REGEXP_REPLACE("object_id", 'hosts/', '') as device,
    CASE
                                WHEN ("any_values"::json->>'state') = '4' THEN 'Signal Lost'
                                WHEN ("any_values"::json->>'state') = '3' THEN 'Signal Restored'
                                ELSE ''
        END as state
FROM public."t_json_event"
WHERE type = '0' AND ("any_values"::json->>'state'='3' OR "any_values"::json->>'state'='4') AND timestamp >= '20200211T0000'
ORDER by timestamp DESC

Example 3

Export of all input events in csv format, a bat file with contents:: Exporting events from all inputs to a csv.bat file containing the following: 

Code Block
SELECT "timestamp",
        REGEXP_REPLACE("object_id", 'hosts/', '') as device,
        CASE
                                WHEN ("any_values"::json->>'phase') = '1' THEN 'Closed'
                                WHEN ("any_values"::json->>'phase') = '2' THEN 'Opened'
                                ELSE ''
        END as state
FROM public."t_json_event"
WHERE type = '1' AND timestamp >= '20200209T110000' AND "object_id" LIKE '%ray%'
ORDER by timestamp DESC

...