Concepts

The Command Line Interface is a set of Perl scripts implemented using ExtraView’s API. These commands provide an alternative to the Browser GUI, for accessing many of ExtraView’s features. Many of the CLI commands can be executed either interactively, where the CLI command prompts for parameters or it can be executed with a single command line, with all the required arguments provided as command line options.

Although the CLI provides access to most of the features that are available through the GUI, a few features are not supported through the CLI. These include:

  • Repeating records may not be added or edited through the CLI
  • Multi-value list fields may not be edited through the CLI. If more than one value for a multi-value list field is specified with the evadd command, only the last value entered will be used. evupdate is not able to modify multi-value list fields at all. The behavior setting CLI_EDIT_MULTI_VALUE_FIELDS should always be set to NO. If this setting has a value of YES, issues containing multi-value field data will lose this data any time those issues are edited with evupdate.

CLI command summary

evadd inserts new records into the ExtraView database
evadd2group adds an existing user to a user role
evaddlist provides an ordered list of fields that are used to insert records
evaddudfvalues add one or more values to a UDF field
evadduser adds a new user to ExtraView
evcheck displays the existing configuration settings
evdebug turns on debug mode
evdefaults fields and values which have a default in the data dictionary
evdelete deletes existing issues from the database
evdeleteuser deactivate an existing user
evdownload downloads a copy of a file from an issue attachment
eveditlist displays a list of fields that are used to update records
evfields displays a list of available fields and their screen names
evfiles retrieves a list of file attachments against a single issue
evget retrieves a single record from the database
evgetfields download a specific field or fields from an existing issue
evheartbeat checks the health of an ExtraView database
evhelp help pages on the CLI
evhist searches for records updated since a given date
evimport imports records into ExtraView
evimportav import allowed value combinations into ExtraView
evimportJIS imports records with Japanese text into ExtraView
evmail the email interface to ExtraView
evmeta retrieves a list of valid metadata for an issue
evpasswd updates a user’s password
evproj allows a user to reset their default area and project
evreport runs a pre-defined ExtraView report or returns a list of reports
evrole sets a user’s role
evsearch provides a general search and retrieval mechanism
evsearchlist displays a list of the available column names and titles
evset sets user details so they do are not entered with each command
evsh a shell optimized to run CLI and system commands
evtemplate produces a template for the evadd and evupdate commands
evupdate updates existing records in the ExtraView database
evupload uploads a file as a new issue attachment
evuserfields displays an ordered list of fields for the user record
evusergroups displays a list of user groups
evusers displays a list of users
evversion displays the version of ExtraView
evxmlc neatly formats XML output in a columnar form

Authentication

CLI commands require an active ExtraView username and password. The CLI provides four different mechanisms for providing this information:

  1. Interactive prompt from the CLI command If neither a username nor a password is provided, the CLI command will prompt for them. If a username is provided with no password, the CLI command will prompt for just the password
  2. Command line options A username, or username and password may be provided as command line options using the -U and -P options, respectively. If only the -U option is provided, the CLI command will prompt for just the password.
  3. evsh The evsh command requests the user to enter their “login” information once, when the command is first run. After authentication, the user may interactively run CLI commands without needing to re-enter their login information each time they run a CLI command. Refer to the evsh man page for complete information
  4. .evrc The evset command may be used to create a configuration file containing the user’s name and password. The most significant drawback to this approach is that this login information is stored in a plain text file, protected only by the operating system’s file permissions. Refer to the evset man page for the complete description. Note that you may use an alternative user ID in place of a user ID. Throughout this document, all command line examples assume that the user name and password are stored in the /.evrc (evrc.txt on Windows) configuration file.

XML Data Returned From CLI Commands

Much of the data returned by a CLI/API call is in XML format. This has some significance to the user of the CLI, in that Extraview’s XML data may embed your own XML within its results. To accommodate this, ExtraView uses Base64 encoding whenever it sees XML data returned from the application to ensure that the XML returned by CLI commands through the API must be well-formed. This means that the contents of a CDATA string must not contain the character string “]]>”, because that is the end sentinel for a CDATA section. So, if the original data contains this string, there must be some way to escape the data.

For easy recognition of an escaped CDATA string, ExtraView prepend the characters %25S to the front of the string. These characters are merely a sentinel and are not part of the output string. The encoding used for the rest of the CDATA string is called Base64, and algorithms for encoding/decoding are widely available. Furthermore, ExtraView ensures that the %25S sentinel string does not appear in the CDATA raw character string by encoding any CDATA raw character string to Base64 as well. It is the responsibility of the receiver, therefore, to test each CDATA section for the sentinel characters %25S at the beginning of the CDATA, and, if present, perform the Base64 decode function on the remainder of the character data to get the raw character values in the field.

Fixed Database Names vs. Display Titles

In order to provide flexibility, many of the CLI commands allow users to refer to fields by either their fixed database names, or by their display titles. Every field defined in the Data Dictionary has both a fixed database name, and a display title. The documentation for the individual CLI commands indicates which naming convention should be used.

The CLI and Image Display Type Fields

As the CLI is a character-based interface, fields with a display type of image are not supported. These fields are ignored in the CLI.

The CLI and Business Rules

When in the ExtraView web-based interface business rules are executed as part of loading screens, making AJAX calls and refreshing screens, as well as when updating the database. When you are working in the CLI, there is no concept of screens, so business rules that are triggered in the web interface for loading and refreshing screens cannot be executed. Rules that are applied pre- and post-update and the email rules are applied however.

Rule Directive Through Web Interface Through CLI
Load Yes No
Onchange / Refresh Yes No
Preupdate Yes Yes
Postupdate Yes Yes
Email Yes Yes

Common CLI Options

Several command line options are common to almost every CLI command. For clarity, these options are not documented on the individual manual pages for the CLI commands.

-F alt-config-file

This option allows the user to specify an alternate evconfig.txt file, for the current CLI command. The full pathname must be specified. When used, this option must be the first option on the command line.

-S servername

Most of the CLI commands support the -s option:

evcommand -s servername

This option allows you to override the servername specified in the evconfig.txt file. evupload and evdownload use a capitalized -S: command -S servername -H or -?

All commands support a -H option (or -?), which prints the documentation for that command.

-U and -P These command line options are used for specifying a username and password on the command line.

-A If ExtraView has been configured to support anonymous logins, this option specifies that the CLI command should be run using the ANONYMOUS_API_USER_ID login. This functionality is enabled when the behavior setting ALLOW_ANONYMOUS_API_ACCESS has a value of YES.

CLI Templates

Templates are stored on the server, and can be used to format the output of CLI commands. The following commands support an optional -T templatefile command line option:

CLI Command API statevar (if using a direct API call)
evadd INSERT
evadduser INSERT_USER
evdelete DELETE
evfiles LIST_ATTACHMENT
evgetuser GET_USER
evpasswd UPDATE_USER_PASSWORD
evget GET
evsearch SEARCH
evupdate UPDATE
evupload ADD_ATTACHMENT

The second column contains statevar parameters that can be used when requests are submitted to ExtraView’s RESTful API through a URL. The URL must include a p_template_file parameter with the name of the template file. The API guide has additional information on the use of templates.

Example usage: evget -T get.html 12341

This will cause ExtraView to look for a file named get.html in the user_templates directory on the server. This directory is at the same level as the …/webapps/evj/WEB-INF/templates directory.

Filling in the template get.html and then displaying the result will complete the output of the evget command. This template will have tags marked like so: __NAME__

These entries are data dictionary names within ExtraView, as returned by evfields or equivalently those names that were placed in get.txt and search.txt by the CLI command evfields -g. Exceptions to this convention are fields with a display type of text area and log area.

These fields are stored within ExtraView with additional information and are used as follows, where DDNAME is replaced with the data dictionary name:

Field name Requiredness Purpose
__DDNAME__ Mandatory No data is returned with this field, but it is required in order that ExtraView can set up the retrieval of the remainder of the fields. If you are designing an HTML template, it is recommended that you include this within a comment, e.g. <!– __DESCRIPTION__ –>
__DDNAME.TEXT__ Optional This field contains the actual text and is normally used in the template
__DDNAME.USER__ Optional The user’s name who created or last updated the text field
__DDNAME.TIMESTAMP__ Optional The timestamp of the last update to the field

An HTML fragment that displays the field named DESCRIPTION may look like this:

<TABLE>
  <TR>
    <TD>Description</TD> <!– __DESCRIPTION__ –>
    <TD>__DESCRIPTION.TEXT__</TD>
  </TR>
</TABLE>

If the requested issue in the evget example command does not exist, we have this result:

ERR_RESULTS Problem #12341 does not exist.

The command evsearch is very similar. The difference is that evsearch may use three template files; a header file (optional), a body file that is used in a repeating fashion for each record returned by the search, and a footer file (optional). For example:

evsearch -T search.html keywords=test q

This will use the files hsearch.html, bsearch.html and fsearch.html for the display. The hsearch.html and fsearch.html files are optional. If there is no file named bsearch.html, ExtraView will search for a file named search.html for the display of each record. If this file is also not found an error is returned to the CLI user.

The tag RECORD_COUNT is available in the header and footer template files. This contains the total record count for the search. The following list describes all the supported template __NAME__ tags, organized by CLI command.

  • evadd

    • The same fields for evget – see above.
    • ERR_RESULTS – “An error occurred while inserting an issue
  • evupdate

    • ID – the ID of the inserted record
    • RESULTS – “Problem #12341 updated.”
    • ERR_RESULTS – “An error occurred while updating the issue.”
  • evdelete

    • ID – the ID of the deleted record
    • RESULTS – “Problem #12341 deleted.”
    • ERR_RESULTS – “You do not have permission to delete.”
  • evadduser

    • RESULTS – “User xxx inserted.”
    • ERR_RESULTS – “Error during adding of user: <error message>”
  • evpasswd

    • RESULTS – “Password changed for xxx.”
    • ERR_RESULTS – “User xxx does not exist.” or “Incorrect old password.” or some other exception
  • evfiles

    • ID – the ID of the record you requested
    • NFILES – the number of attached files
    • DATE_CREATED – repeating field
    • FILE_NAME – repeating field
    • FILE_SIZE – repeating field
    • CREATED_BY_USER – repeating field
    • ATTACHMENT_ID – repeating field
    • FILE_DESC – repeating field
    • Repeating fields are used within a __REPEAT_START__ … __REPEAT_STOP__ block like this:
       

      <TABLE>
        <TR>
          <TD>Date Created</TD>
          <TD>File Name</TD>
          <TD>File Size</TD>
          <TD>Created by User</TD>
          <TD>Attachment ID</TD>
          <TD>File Description</TD>
        </TR>
      __REPEAT_START__
        <TR>
          <TD>__DATE_CREATED__</TD>
          <TD>__FILE_NAME__</TD>
          <TD>__FILE_SIZE__</TD>
          <TD>__CREATED_BY_USER__</TD>
          <TD>__ATTACHMENT_ID__</TD>
          <TD>__FILE_DESC__</TD>
        </TR>
      __REPEAT_STOP__
      </TABLE>
    • ERR_RESULTS “Problem #12341 does not exist.”
  • evupload

    • This uploads the file and then displays the record itself with the template file (see evget). It then prepends an ‘f‘ to the template filename and displays all the attached files (including the one just attached) (see evfiles).

      Either of these can be an empty file but they both must exist. The URL statevar of ADD_ATTACHMENT requires some special care. Here is some sample HTML:
       

      <FORM METHOD=post action=”http://test.extraview.net/evj/ExtraView/ev_api.action?p_user_id=mary&p_password=smith& statevar=add_attachment&id=15948&p_template_file=get.html” enctype=”multipart/form-data”>
      File: <input type=”file” size=”40″ name=”file”>
      <BR />
      Description: <input type=”text” size=”40″ name=”p_attach_desc”>
      <BR />
      <INPUT type=”hidden” name=”p_problem_id” value=”15948″>
      <INPUT type=”hidden” name=”p_called_from” value=”pr_edit_problem”>
      <INPUT type=”hidden” name=”p_user_id” value=”system”>
      <input type=”Submit”>
      </FORM>
      </BODY>
      </HTML>
  • evgetuser

    • There is actually no such API command… This is for internal purposes –- you pass the command get_user with an email address. You are returned the user ID and the company name with that email address.

      • ID – the user ID
      • COMPANY_NAME – the company name
      • ERR_RESULTS – “missing email parameter”

      For all the above commands the name ERR_RESULTS is not displayed using the specified template file. ExtraView will use the template file error.html if it exists or, if it does not, simply displays the string on the output. This obviates the need for normal display templates to deal with error conditions.

      The URL statevar of FILL_IN takes a p_template_file parameter and fills in the template with the other parameters passed. For example:

      http://www.extraview.net/evj/ExtraView/ev_api.action?user_id=myname&password=secret&statevar=fill_in&p_template_file=files.html &ID=1234&NAME=Harriette

      Where files.html contains the tags __ID__ and __NAME__.