/lecli

Seamlessly view recent events, run queries and manage your account from the command line

Primary LanguagePythonMIT LicenseMIT

Logentries Command Line Interface

This document provides an overview of installing and using the Logentries Command Line Interface. The CLI is build on the Logentries REST APIs and provides a tool to interact directly with the Logentries service outside of the UI. It is in beta and currently supports log event querying and account user management. New functionality will be continually added.

Installation

pip install logentries-lecli

or

pip install git+https://github.com/rapid7/lecli

or

pip install <path to project directory>

Note

If there is no lecli configuration file, a dummy config file will be created in config directory at first use of any lecli command. You should edit the file in the provided path on your shell with your API keys and other configurations after this first use.

Depending on your operating system the Lecli config can be located at the following paths:

If you're running on OSX, path to your configuration file should be:

/Users/<username>/Library/Application Support/lecli/config.ini

If you're running on Debian, path to your configuration file should be:

/home/<username>/.config/lecli/config.ini

We are using appdirs library for this and you can always refer to its user_config_dir attribute for locating the configuration file.

Supported Platforms

  • Linux - Tested on Debian 8
  • OSX - Tested on El Capitan

Configuration File

In order to use the CLI you must first setup the configuration file with your API keys. Your account API keys are available at logentries.com. Under the account management section select the API Keys tab. For more information: https://docs.logentries.com/docs/api-keys Here you will get access to your account resource Id and be able to generate your Owner, Read/Write and Read-Only API keys. Note that only the account owner is allowed to generate an Owner API key.

In order to do User and account management via the CLI an owner API key and account resource Id is required. Querying of events and logs can be done using the Read/Write API key.

Copy and paste your API keys into the AUTH section of the CLI configuration file 'config.ini'

[Auth]
account_resource_id = 912345678-aaaa-bbbb-1234-1234cb12345a
owner_api_key_id = 12345678-aaaa-bbbb-1234-1234cb12345b
owner_api_key = 12345678-aaaa-bbbb-1234-1234cb12345c
rw_api_key = 12345678-aaaa-bbbb-1234-1234cb12345d

You will also need to set your log management URL. This defaults to:

https://rest.logentries.com/management

This value can be updated in the URL section of the CLI configuration file:

[Url]
log_management_url=https://<some_url>/management

Query and Events

The event and query functionality of the CLI supports a number of different ways to query events and statistics.

####Recent Events

The 'get recentevents' command allows you to retrieve the most recent log events that have been sent to Logentries. The logs to retrieve events from can be specified in a few ways. The Log IDs can be passed directly as a space separated list of log Ids, or you can take advantage of log sets and CLI Favorites. Log Ids can be obtained from the settings page or logsets page of a log in the Logentries UI (https://logentries.com). CLI favorites can be passed using the '--favorites' '-c' arguments, logset ID can be passed using the '--logset' '-g' arguments. For more information in setting up CLI Favorites and using log sets, see the 'Cli Favorites and Log Sets' section below. By default the 'get recentevents' command will return events for the last 20 minutes. The command also takes an optional time argument that allows you to specify how far back in time you wish to get events from; this is passed using '--last' or '-l' argument. It is also possible to provide '-r' (--relative-range) to use relative time range functionality of the Logentries REST API. Check supported patterns.

Example usage:

lecli get recentevents 12345678-aaaa-bbbb-1234-1234cb123456 -l 200
lecli get recentevents 12345678-aaaa-bbbb-1234-1234cb123456 -r 'last 2 hours'
lecli get recentevents -c mylogalias -l 200
lecli get recentevents --logset 12345678-aaaa-bbbb-1234-1234cb123457 -l 200
lecli get recentevents -g 12345678-aaaa-bbbb-1234-1234cb123457 -r 'last 1 week'

####Events The 'get events' command allows for the retrieval of log events within defined time ranges. As with 'get recentevents', logs can be passed to the 'get events' command as a space separated list of log Ids, or you can take advantage of log sets and CLI Favorites. The 'get events' command accepts time ranges in ISO-8601 human readable time format (YYYY-MM-DD HH:MM:SS); time ranges in this format can be passed using the '--datefrom' and '--dateto' arguments. Note, all time values are in UTC timezone. The command also accepts epoch time with second granularity. Epoch format time parameters can be passed using the '--timefrom' '-f' and '--timeto' '-t' arguments. It is also possible to provide '-r' (--relative-range) to use relative time range functionality of the Logentries REST API. Check supported patterns.

Example usage:

lecli get events 12345678-aaaa-bbbb-1234-1234cb123456 -f 1465370400 -t 1465370500
lecli get events 12345678-aaaa-bbbb-1234-1234cb123456 --datefrom '2016-05-18 11:04:00' --dateto '2016-05-18 11:09:59'
lecli get events 12345678-aaaa-bbbb-1234-1234cb123456 -r 'yesterday'
lecli get events --logset 12345678-aaaa-bbbb-1234-1234cb123457 --datefrom '2016-05-18 11:04:00' --dateto '2016-05-18 11:09:59'
lecli get events --favorites mylogalias --datefrom '2016-05-18 11:04:00' --dateto '2016-05-18 11:09:59'
lecli get events --favorites mylogalias -r 'last 3 weeks'

####Query The 'query' command allows you to run LEQL queries on logs from the command line. Logs can be passed to the 'query' command using a space separated list of log Ids, log sets or CLI Favorites. As with the 'events' command, 'query' accepts time ranges in ISO-8601 human readable time format (YYYY-MM-DD HH:MM:SS); time ranges in this format can be passed using the '--datefrom' and '--dateto' arguments. It also accepts epoch time with second granularity. Epoch format time parameters can be passed using the '--timefrom' '-f' and '--timeto' '-t' arguments. It is also possible to provide '-r' (--relative-range) to use relative time range functionality of the Logentries REST API. Check supported patterns.

Any LEQL query type that can be used in the advanced mode in the Logentries UI can also be used with the 'query' command. The LEQL query is passed as a string using the '--leql' '-l' argument. For detailed information on using LEQL see https://logentries.com/doc/search/ A query can return three types of results. For searches just using a where() and without any calculate or groupby functions then the CLI will print the list of matching log events. Other queries will return either statistical or timeseries data, the CLI will pretty print both of these.

Example usage:

lecli query --logset 12345678-aaaa-bbbb-1234-1234cb123457 --leql 'where(method=GET) calculate(count)' --datefrom '2016-05-18 11:04:00' --dateto '2016-05-18 11:09:59'
lecli query --favorites mylogalias --leql 'where(method=GET) calculate(count)' --datefrom '2016-05-18 11:04:00' --dateto '2016-05-18 11:09:59'

####Supported Relative Time Patterns Logentries REST API also supports relative time ranges instead of absolute start and end dates. All relative times are case insensitive and supported patterns are like these:

  • today
  • yesterday
  • last n timeunits where timeunits can be:
    • min, mins, minute, minutes
    • hr, hrs, hour, hours
    • day, days
    • week, weeks
    • month, months
    • year, years

####Live Tail Logentries REST API supports tailing log events in real time. Lecli makes use of this with tail events command. While logkeys(space separated log keys) is a mandatory argument for this command, --leql, --favorites and --logset options are supported for this command. Another option is --poll-interval or -i, which is the request interval to the live tail API. Defaults to 1.0 seconds. As this may affect api key limits, it should be used carefully.

Example usage:

lecli tail events 12345678-aaaa-bbbb-1234-1234cb123456
lecli tail events 12345678-aaaa-bbbb-1234-1234cb123456 -i 5.0 --leql 'where(event=login)'
lecli tail events 12345678-aaaa-bbbb-1234-1234cb123456 --logset 12345678-aaaa-bbbb-1234-1234cb123457
lecli tail events 12345678-aaaa-bbbb-1234-1234cb123456 --favorites mylogalias

####Running Saved Queries Logentries REST API supports running saved queries with its configurated parameters. Events, recent events, query and live tail commands support running saved queries directly from lecli. If your saved query has the log and time range information, no other information need to be supplied to the command. If any these information are not part of the saved query, they must be supplied in the command as well. In case a redundant parameter has been supplied(log keys, time range or start and end times), REST will return an error response with a message indicating the redundant parameter and lecli will show this information on terminal.

Example usage: First get the saved query id to run with get savedqueries command, then use this id in below command formats:

lecli tail events --saved-query 12345678-aaaa-bbbb-1234-1234cb123456
lecli tail events --saved-query 12345678-aaaa-bbbb-1234-1234cb123456 -r 'last 10 min' // if there is no time range information in saved query
lecli tail events --saved-query 12345678-aaaa-bbbb-1234-1234cb123456 -f 1481558514334 -t 1481562814000 // if there is no time range information in saved query
lecli tail events LOG_KEY_UUID1 LOG_KEY_UUID2... --saved-query SAVED_QUERY_UUID // if there is no log information in saved query
"tail events" command can be replaced with "query", "get events", "get recentevents" as they all support saved queries in the same options format.

CLI favorites and Log Sets

The CLI supports command line favorites (CLI Favorites) for query commands as well as log sets from the Logentries account. This makes searching well known or large lists of logs much simpler as you do not need to pass in lists of log Ids.

CLI Favorites

CLI Favorites allow an alias for a single log or a list of log Ids to be configured, this is done in the 'Cli_Favorites' section of the configuration file.

[Cli_Favorites]
favlog =    12345678-aaaa-bbbb-1234-1234cb123456
favlist =   12345678-aaaa-bbbb-1234-1234cb123456
            12345678-aaaa-bbbb-1234-1234cb123457

Log Sets

The Logset '-g' or '--logset' option allows for a list of log Ids to be used from an existing logset (see below for details on logset management). Where a logset Id is used a request is made on the server to get a list of any log Ids that are present in that logset. That list of log Ids are then used in the command. No information from the logset is retained in the config file.

lecli query --logset 12345678-aaaa-bbbb-1234-1234cb123457 --leql 'calculate(count)' -r 'last 3 days'
lecli query -g 12345678-aaaa-bbbb-1234-1234cb123457 --leql 'calculate(count)' -r 'last 3 days'

User and Account Management

The user and account management functionality of the CLI can only be used with a valid owner API key. The configuration file must contain the account_resource_id, owner_api_key_id and owner_api_key in the Auth section. These are all available from the account management and API keys section at https://logentries.com. It is worth noting that if your account does not have a specific owner set then some user management functions may fail with a 500 error; to check if an owner is set the 'getowner' command below can be used. If no owner is set then you must regenerate the owner API key, at which point you will be asked to set an account owner.

####Get Users The 'get users' command will return a list of all users that have access to the account for which the CLI has been configured. The command will return the users first and last name, email address, user key and the last time they logged in. The 'get users' command does not accept any arguments.

Example usage:

lecli get users

####Add User The 'create user' command allows you to add a user to your account. There are two ways to add users, depending on whether they are a new or existing user. A new user is a user that has no Logentries account.

To add a new user you must provide their first and last name, and email address. If successfully added the CLI will print the users account information, including their newly generated user key. A user added via the CLI must then go to https://logentries.com/user/password-reset/ and enter their email address. They will then be sent a link that they can use to setup the password for their new account.

A new user can be added using the following command

lecli create user -f John -l Smith -e john.smith@email.com

To add an existing user (i.e. a user that already has a Logentries account, even if not associated with your account), you must first obtain their user key. The user can obtain their user key from the account management page of the Logentries application at https://logentries.com

An existing user can be added to your account use the following command

lecli create user -u 12345678-aaaa-bbbb-1234-1234cb123456

####Delete User The 'delete user' command allows for the removal of a user from your account and deletion of the users account from Logentries. If the user is associated with only your account then the users access to your account will be removed and the users account deleted. However, if the user is associated to any other account then access to your account will be removed but the users Logentries account and any association to other accounts will remain.

To delete a user use the following command

lecli delete user -u 12345678-aaaa-bbbb-1234-1234cb123456

####Get Account Owner The 'get owner' command allows you to retrieve the details of the account owner, this is done using the following command

lecli get owner

Team Management

Team management requires a valid read-write API key in your configuration file. The configuration file must contain a valid account_resource_id and rw_api_key in Auth section.

####Get Teams Get all teams associated with this accounts.

 lecli get teams

####Get a Specific Team Get a specific team by providing team UUID.

lecli get team <team id>

####Create a New Team Create a new team with the given name.

lecli create team <new name>

####Delete a Team Delete a team with the given UUID.

lecli delete team <team id>

####Rename a Team Rename a team with the given UUID to given name.

lecli rename team <team id> <team name>

####Add User to a Team Add a new user to a team with the given UUID and user UUID respectively.

lecli update team add_user <team id> <user key>

####Delete User from a Team Add a new user to a team with the given UUID and user UUID respectively.

lecli update team delete_user <team id> <user key>

Account Usage

Account usage can be retrieved using lecli 'get usage' command along with 'start' and 'end' date ranges to be queried. A valid read-write api key in configuration file is required for this operation. Note: 'start' and 'end' dates should be in ISO-8601 format: 'YYYY-MM-DD', example: '2016-01-01'

lecli get usage -s <start date> -e <end date>

Saved Query Management

Saved queries that belong to an account can be managed via lecli. Lecli supports creating(POST), listing(GET ALL), retrieving(GET), deleting(DELETE) and updating(PATCH) saved queries via command line. This operation required read-write api key to be in lecli config file.

####List saved queries Get a list of saved queries belongs to the used account.

Example:

lecli get savedqueries

####Get a saved query Get a specific saved query Mandatory positional argument:

  • UUID of the saved query to be retrieved.

Example:

lecli get savedquery <uuid of the saved query>

####Create a new saved query Create a new saved query with the given arguments:

Mandatory positional arguments:

  • Name: Name of the saved query
  • Statement: LEQL statement of the saved query Optional named arguments:
  • '-f': From timestamp - epoch in milliseconds
  • '-t': To timestamp - epoch in milliseconds
  • '-r': Relative time range(cannot be defined with from and/or to fields)
  • '-l': Logs of the saved query. Multiple logs can be provided with a colon(:) separated logs string.

Examples:

lecli create savedquery 'new_saved_query' 'where(event)'
lecli create savedquery 'new_saved_query' 'where(event)' -l '123456789012345678901234567890123456'
lecli create savedquery 'new_saved_query' 'where(event)' -r 'last 5 min' -l '123456789012345678901234567890123456:123456789012345678901234567890123457'
lecli create savedquery 'new_saved_query' 'where(event)' -f 1481558514334 -t 1481562814000 -l '123456789012345678901234567890123456:123456789012345678901234567890123457'

####Update a saved query Update a saved query with the given arguments.

Mandatory positional argument:

  • UUID of the saved query to be updated.

Optional named arguments:

  • '-n': Name of the saved query
  • '-s': LEQL statement of the saved query
  • '-f': From timestamp - epoch in milliseconds
  • '-t': To timestamp - epoch in milliseconds
  • '-r': Relative time range(cannot be defined with from and/or to fields)
  • '-l': Logs of the saved query. To provide multiple logs, colon(:) separated logs can be used.

Examples:

lecli update savedquery -n 'new_name_for_query' -s 'where(/*/)'
lecli update savedquery -n 'new_name_for_query' -s 'where(/*/)' -r 'last 10 days'
lecli update savedquery -n 'new_name_for_query' -f 1481558514334 -t 1481562814000
lecli update savedquery -n 'new_name_for_query' -l '123456789012345678901234567890123456'

####Delete a saved query Delete a saved query. Mandatory positional argument:

  • UUID of the saved query to be deleted.

Example:

lecli delete savedquery <uuid of the saved query>

Log Management

The CLI allows you to retrieve and manage logs. You can retrieve a specific or all logs, as well as create, delete, replace and rename logs. Retrieving logs requires a valid read-only API key in your configuration file. The remaining actions also require a valid read-write API key.

####Retrieve all logs Retrieve all logs:

Example:

lecli get logs

####Retrieve a specific log Retrieve a log with a given ID.

Mandatory positional argument:

  • UUID of the log to the retrieved.

Example:

lecli get log <log_id>

####Create a new log Create a new log with a given name or from a provided JSON file.

Logs can be created with a given name and default values by providing the name. If you wish to supply additional information, the (relative or full) path to a JSON file can be provided.

Note that only creation of a single log object is supported at this time.

Example JSON:

{
    "name": "log name",
    "logsets_info": [
        {
            "id": "logset id",
            "name": "logset name"
        }
     ]
 }

Example:

lecli create log -n <name>
lecli create log -f <path_to_json_file>

####Rename a log Rename a log with the provided ID.

Mandatory positional arguments:

  • UUID of the log to be renamed
  • New name of the log

Example:

lecli rename log <log_id> <new_name>

####Update a log Add information to a given log.

Mandatory positional arguments:

  • UUID of the log to be updated
  • Full or relative path to a JSON file containing the updated log information

Example:

lecli update log <log_id> <path_to_json_file>

####Delete a log Deletes a log with the provided ID.

Mandatory positional argument:

  • UUID of the log to be deleted

Example:

lecli delete log <log_id>

####Replace a log Replaces a log with the provided log.

Mandatory positional argument:

  • UUID of the log to be replaced
  • Full or relative path to JSON file containing a valid log object

Example:

lecli replace log <log_id> <path_to_json_file>

Logset Management

The CLI allows you to retrieve and manage logsets. You can retrieve all or single logsets as well as create, delete and rename logsets. You can also add or remove a log to a logset. These actions require a valid read-write and read-only API key in your configuration file.

####Retrieve all logsets Retrieve all logsets.

Example:

lecli get logsets

####Retrieve a specific logset

Retrieve a logset with a given ID.

Mandatory positional argument:

  • UUID of the logset to be retrieved.

Example:

lecli get logset <logset_id>

####Create a new logset

Create a new logset with a given name or from a provided json file.

Logsets can be created with a given name and default values by providing the name. If you wish to supply additional information, the (relative or full) path to a JSON file can be provided.

Example JSON:

{
    "name": "logset name",
    "logs_info": [
        {
            "id": "log id",,
            "name": "log name"
        }
    ]
}

Example:

lecli create logset -n <name>
lecli create logset -f <path_to_json_file>

####Rename a logset Rename a logset with the provided ID.

Mandatory positional arguments:

  • UUID of the logset to be renamed
  • New name of the logset

Example:

lecli rename logset <logset_id> <new_name>

####Update a logset Add or remove log information to a given logset.

Mandatory positional arguments:

  • UUID of the logset to be updated
  • UUID of the log to be added or removed

Examples:

lecli update logset add_log <logset_id> <log_id>
lecli update logset delete_log <logset_id> <log_id>

####Delete a logset Deletes a logset with the provided ID.

Mandatory positional argument:

  • UUID of the logset to be deleted

Example:

lecli delete logset <logset_id>

####Replace a logset Replaces a logset with the provided logset.

Mandator positional arguments:

  • UUID of the logset to be replaced
  • Full or relative path to JSON file containing a valid logset object

Example:

lecli replace logset <logset_id> <path_to_json_file>

Api Key Management

Api keys of an account can be managed via lecli. Lecli supports creating(POST), listing(GET ALL), retrieving(GET), deleting(DELETE) and updating(PATCH) api keys via command line.

####List api keys Get a list of api keys belongs to the used account. Uses rw or owner api key.

Note: this does not show owner api key unless --owner option is supplied.

Example:

lecli get apikeys
lecli get apikeys --owner

####Get an api key Get a specific api keys Uses rw api key.

Mandatory positional argument:

  • UUID of the api key to be retrieved.

Example:

lecli get apikey <uuid of the apikey>

####Create a new api key Create a new api key with the given arguments from a provided json file. Uses owner api key.

Example JSON:

{
    "api_key": [
        {
            "acl_type": "ReadOnly",
            "active": true,
        }
    ]
}

Note: If an acl_type of api key exists already, it cannot be created again. It needs to be deleted first to be created.

####Update an api key Update an api key to either disable or enable it. Uses owner api key.

Mandatory positional argument:

  • UUID of the api key to be updated.

Optional named arguments:

  • '--enable': Enable the given api key
  • '--disable': Disable the given api key

Examples:

lecli update apikey <uuid of the api key> --enable
lecli update apikey <uuid of the api key> --disable

####Delete an api key Delete an api key. Uses owner api key.

Mandatory positional argument:

  • UUID of the api key to be deleted.

Example:

lecli delete apikey <uuid of the api key>