Command Line Interface (CLI)The router provides a command line interface (CLI) for a configuration from the local network or remote via Telnet or SSH. One parameter after the other will be entered line by line via the CLI and stored in the opened profile. The modifications to the profile will not yet be effective in the running profile with this. The profile must still be activated, i.e. become the running profile, that the modifications to the configuration become effective. Activating the CLIBefore an access to the router via Telnet or SSH is possible, this must be configured accordingly in the Administration menu on the CLI page. For this, access via Telnet or SSH must be activated and, if the firewall is active, an appropriate exceptional rule must be present and active. A suitable firewall rule is prepared in the Netfilter menu on the IP filter page with the description Local access to command line via SSH and must only be set to active. AuthenticationThe authentication will be made using a combination of user name and password that is managed in the Administration menu on the Users page. SyntaxThe syntax of a parameter is composed of the sections and the parameter, each separated by a full stop. The sections correspond to the menu structure in the web interface. The parameter Activate command line via SSH in the Administration menu on the CLI page has the following syntax for example: The available sections and parameters depend on the respective device and the installed plug-in cards. These can easily be shown using auto-complete via tabulator key. Pressing the tabulator key shows all available sections of the first level (corresponds to the menus in the web interface). Entering the first letter(s) of a section fallowed by the tabulator key completes the section and pressing the tabulator key again shows all available sections of the next level (corresponds to the pages of this menu in the web interface). Pressing the tabulator key again shows possible further sections or available parameters. In case of lists, the opening square bracket ([) will be output automatically. If this is replaced by a full stop, another click on the tabulator key will output the available list functions. Lines starting with a hashtag # will be ignored and can be used as a comment. See the Command reference page for this as well. Activating a profileIf a profile has been modified using the CLI as described in the following, the modifications will become only effective, if the profile is activated, i.e. made the running profile. Reading out valuesThe current value of a parameter is displayed by entering the parameter followed by the enter key. If only the section is entered, all subjacent parameters will be displayed. Example: Entering valuesA new value is assigned to a parameter by entering the parameter followed by an equals sign and the new value. Example: Renaming entriesAn entry, such as the name of a profile or container, can be renamed by entering the old name and the new name, separated by a blank.
Example for renaming the profile "quick_start_profile" to "new_profile": Editing listsBesides fix parameters, the router has also endless lists like those for the users. The individual entries of a list are enumerated in sequence and can be addressed using this position number. The user name of the second entry of the user list for example is displayed using the command: Displaying a list sizeThe parameter size displays the number of list entries. Example for the number of users: Adding a list entryThe parameter add adds an entry to the end of a list. From version 2.6, it is possible to specify a number to add multiple list entries with one command. Example for adding another user: Deleting a list entryThe parameter delete=[x] deletes entry number [x] in the list. The parameter delete=all deletes all existing entries in the list. The parameter delete=last deletes the last entry. Example for deleting entry no 3 in the user list: Moving a list entry upwardsThe parameter sort_up=[x]moves entry number [x] by one position upwards in the list (to position [x-1]). Example for moving entry no 3 upwards in the user list: Moving a list entry downwardsThe parameter sort_down=[x] moves entry number [x] by one position downwards in the list (to position [x+1]). Example for moving entry no 3 downwards in the user list: Copying a list entryThe parameter copy=[x] copies entry number [x] in the list. An identical list entry will be appended to the end of the list. Example for copying entry no 3 in the user list: Lists within listsSome router functions require lists within lists. Editing is along the lines of the higher-level lists on the respective sub-section level. Example for querying the connection check interval of the interface on position 2 of the WAN chain on position 1: Multi-line valuesIt is also possible to enter multi-line values within the CLI. This is required to upload certificates, keys, or e-mail and SMS texts for example. These values must then start with -----BEGIN[ID]----- and end with -----END[ID]-----. [ID]can be selected as desired, but must be the same for BEGIN and END. Example for the text of message 1: Displaying status informationThe information displayed in the Status menu of the web interface can also be read out via the CLI. Status information can also be inserted in messages as current values. Example for the display of the voltage at input 1 of the LTE card in slot 2: Displaying the log filesWhen displaying the log files. the logs to be displayed will be entered in the endless list view separated by commas as indices. If no log files are specified, all log files will be output. The last 10 lines of each selected log file will be output. Example: Filtering the log file outputThe program grep is available for filtering the log file output. The parameters available in grep are displayed with the parameter -h. They can also be combined. Displaying event-dependent informationAll available parameters of the event-dependent information can be displayed in an interactive CLI session using auto-complete (using the tabulator key, see syntax above): DebuggingManual triggering of an actionManual triggering of an action serves for testing its effect without having to wait until the configured event occurs. Depending on the action, certain parameters must be set before that are used to execute the action then. Example for closing output 1 of the card in slot 3: Analysis of the network connectionsThe debugging commands are handed over with the parameter tool as value. The six programs ping, ping6, traceroute, traceroute6, nslookup and tcpdump are available for this. The own parameters of the debugging tool will be handed over again behind this. The syntax of the debugging tool will be displayed with the parameter -h. The results are displayed immediately. The execution of the commands can be aborted immediately with Esc or Ctrl + C. Example for sending 3 subsequent pings to the address 192.168.1.111: Executing an AT commandThe command for executing AT commands at_command will be forwarded to the parameter tool as value. This is followed by the used modem and the AT command itself. The results are displayed immediately. Example for identifying the modem chipset in slot 2: AbbreviationsAbbreviations for a (partial) repetition of the last command are available in addition to auto-complete to facilitate the command entry. The : (colon) replaces all sections of the last command until the last full stop. Each . (full stop) replaces one section of the last command at the position of the full stop. Examples: Lua modeFor executing Lua scripts on the router, these can be transmitted in ASCII configuration files or in the CLI.
The Lua mode provides the following commands besides the usual functional scope (see Lua 5.3 Reference Manual): cli, cli_log, lua_log, netmask_to_cidr, cidr_to_netmask, ip_in_net, sleep The Lua mode will be entered and exited with -----LUA-----. The Lua mode allows to execute complex Lua scripts. The Lua function "require" allows to load and execute further Lua libraries within a Lua script. These can be uploaded to the router like a regular ASCII configuration file, but must have the file extension ".lua". Moreover, the Lua mode must be entered with -----LUA----- at the begin of the file. When calling "require", only the file name without the file extension will be handed over. The command cli transfers commands to the CLI within Lua.
The following command sets the location to "Regensburg” for example: The command cli_log makes an entry into the CLI log.
The following command for example writes the string "abc" to the CLI log: The command lua_log makes an entry into the Lua log.
The Lua log will only be created, if entries are made using this command.
The router itself will not write any entries to this log.
The following command for example writes the string "xyz" to the Lua log: The command ip_in_net can be used to query, whether a certain IP address is in a network.
The following command for example can be used to check, whether the IP address 192.168.1.13 is in the network 192.168.1.0 (the network can be specified in CIDR format or with netmask): The command cidr_to_netmask can be used to convert a CIDR notation into a netmask Example: The command netmask_to_cidr can be used to convert a netmask into CIDR notation Example: The command sleep can be used to pause the execution of a Lua script by the number of seconds specified in the argument. The following command for example can delay the execution by 0.7 seconds: The Configuration Guide for the router contain practical examples for working with Lua. Closing the CLI sessionThe CLI session will be closed by entering exit followed by the enter key. |