Skip to content

trakerr-com/trakerr-python

Repository files navigation

Trakerr - Python API client

Build Status

Get your application events and errors to Trakerr via the Trakerr API.

You can send both errors and non-errors (plain log statements, for example) to Trakerr with this API.

Overview

The 3-minute integration guide is primarily oriented around sending errors or warnings and does not allow you to specify additional parameters. The logging handler also has the ability to specify the log level that then controls whether infos or debugs are also sent.

For sending additional parameters, Option-4 in the detailed integration guide describes how you could send non-errors along with additional parameters.

The SDK takes performance impact seriously and all communication between the SDK <=> Trakerr avoids blocking the calling function. The SDK also applies asynchronous patterns where applicable.

A Trakerr Event can consist of various parameters as described here in AppEvent. Some of these parameters are populated by default and others are optional and can be supplied by you.

Since some of these parameters are common across all event's, the API has the option of setting these on the TrakerrClient instance (described towards the bottom) and offers a factory API for creating AppEvent's.

Key AppEvent Properties

Log Level, Event Type and Classification

  • Log Level This enum specifies the logging level to be used for this event ('debug','info','warning','error' or 'fatal')
  • Event Type This defines the type of event or logger name. This is automatically set for errors.
  • Classification This is a user settable property that controls how the events are grouped. Defaults to 'Issue'. Set this to a different value to group this event in a different group.

Event User, Event Session and Correlation ID

  • Event User This is the user that is associated with this event. This can be any user data or could be encrypted if privacy is required.
  • Event Session This is any session specific information associated with this event.
  • Cross App Correlation ID This is an additional ID that can be used for cross-application correlation of the same event.

Operation Time

  • Operation Time This property in milliseconds measures the operation time for this specific event.

Custom properties and segments

In addition to the above, you can use custom properties and segments to send custom event, performance data. These can then be visualized in Trakerr's dashboards.

Requirements

Python 2.7.9+ and 3.4+

3-minute Integration Guide

If you're already using the python logger in some capacity, you can integrate with Trakerr quickly. First, issue a pip install to get the latest version:

To install from master, simply use:

pip install git+https://github.com/trakerr-com/trakerr-python.git

(you may need to run pip with root permission: sudo -H pip install git+https://github.com/trakerr-com/trakerr-python.git)

or upgrade an installation with a command from the advanced pip commands section.

Once installation is complete, add this import from wherever you instantiate your loggers.

import logging #Your previous logging import here
from trakerr import TrakerrHandler #New import.

And then you'll need to create a handler and a logger object and attach them before you can use them later on.

#Your original logger.
logger = logging.getLogger("Logger name")

#Instantiate Trakerr's logger handler. By default the handler will only log WARNING and above.
th = TrakerrHandler("<api-key>", "App Version number here", "Deployment stage here")

#Attach our handler to the root logger.
logging.getLogger('').addHandler(th)

#Alternatively attach our handler to your logger for a single logger instance.
logger.addHandler(th)

Follow the shutdown section when you are closing your app to ensure a graceful shutdown.

The handler's full constructor signature is as follows:

def __init__(self, api_key=None, app_version="1.0", context_deployment_stage="deployment",
                 client=None, level=logging.WARNING):

The parameters are as follows

  • api_key: should be your api key from trakerr.
  • app_version: should be your code's app version.
  • deployment_stage: is the stage of the codebase you are pulling events from (production, test, development, ect).
  • client: allows you to pass in a preconfigured TrakerrClient instance, which allows you to provide a client with custom values. If you provide a client, the values of the first three parameters do not matter.
  • level: Allows you to set the level of events that this handler can emit. By default, TrakerrHandler will send warnings and above to trakerr. This way, if you're using more than one handler, you can set the logger to log all events, and set trakerr to log only warnings and above, while sending infos and above with another handler.

You should be able to now send basic events and information to trakerr. If you are only using trakerr to log, or want to send more in depth events, read on below.

TrakerrClient Shutdown

When cleaning up your application, or implementing a shutdown, be sure to call:

TrakerrClient.shutdown()

This will close the perfomange monitoring thread gracefully. You only need to call this once, no matter how many loggers you have. Add it to any cleanup function you have for your program.

Detailed Integration Guide

By using the pip command above, you can also use trakerr in a multitude of different ways.

Option-1: Attaching Trakerr to an exsisting logger

Follow the instructions in the three minute integration guide to attach trakerr to a logger you've already written.

Option-2: Creating a new logger for Trakerr

Along with your imports, add:

from trakerr import Trakerr

And then you can get a python logger object that ties in to trakerr to handle the various levels of errors, giving the appropriate data as strings.

def main(argv=None):
    if argv is None:
        argv = sys.argv
    
    logger = Trakerr.get_logger("<api-key>", "App Version number here", "Logger Name")

    try:
        raise FloatingPointError()
    except:
       logger.exception("Bad math.")

    return 0

Option-3: Sending an error(or non-error) quickly without using the logger

You can quickly send a simple event with partial custom data from the log function of the TrakerrClient. Add these imports:

from trakerr import TrakerrClient

you can then send call log simply to send a quick error to Trakerr.

client = TrakerrClient("<api-key>", "App Version number")

client.log({"user":"[email protected]", "session":"25", "eventtype":"user logon issue",
            "eventmessage":"User refreshed the page."}, "info", "logon script", False)

The full signature of log is as follows:

def log(self, arg_dict, log_level="error", classification="issue", exc_info=True):

If exc_info is True, it will poll sys.exc_info() for the latest error stack information. If this is false, then the event will not generate a stack trace. If exc_info is is a tuple of exc_info, then the event will be created using that exc_info.

arg_dict is a dictionary which makes it simple to pass in basic AppEvent information without using the more extensive methods below. The items arg_dict looks for are as follows:

  • "eventtype":(maps to string) The name of the event. This will autmatically be filled if nothing is passed in when you are sending and event with a stacktrace.
  • "eventmessage":(maps to string) The message of the event. This will autmatically be filled if nothing is passed in when you are sending and event with a stacktrace.
  • "user":(maps to string) User that triggered the event
  • "session":(maps to string) Session that triggered the event
  • "time":(maps to string) Time that the operation took (usually in miliseconds)
  • "url":(maps to string) URL of the page the error occurred on
  • "corrid":(maps to string) The correlation id
  • "device":(maps to string) The machine name or type you are targeting

You can of course leave out anything you don't need, or pass in an empty dictionary to arg_dict if you don't wish to give any data

Option-4: Add Custom Data

You can send custom data as part of your error event if you need to. This circumvents the python handler. Add these imports:

from trakerr import TrakerrClient
from trakerr_client.models import CustomData, CustomStringData

You'll then need to initialize custom properties once you create the event. Note that you can use the second call commented out to instead create an app event without a stacktrace.

def main(argv=None):
    if argv is None:
        argv = sys.argv

    client = TrakerrClient("<api-key>", "App Version number")

    try:
        raise IndexError("Bad Math")
    except:
        appevent = client.create_new_app_event("FATAL", exc_info=True)

        #Populate any field with your own data, or send your own custom data
        appevent.context_app_browser = "Chrome"
        appevent.context_app_browser_version = "67.x"

        #Can support multiple ways to input data
        appevent.custom_properties = CustomData("Custom Data holder!")
        appevent.custom_properties.string_data = CustomStringData("Custom String Data 1",
                                                                  "Custom String Data 2")
        appevent.custom_properties.string_data.custom_data3 = "More Custom Data!"
        appevent.event_user = "[email protected]"
        appevent.event_session = "6"

        appevent.context_operation_time_millis = 1000
        appevent.context_device = "pc"
        appevent.context_app_sku = "mobile"
        appevent.context_tags = ["client, frontend"]

        #Send it to trakerr
        client.send_event_async(appevent)

    return 0

create_new_app_event's full signature is as follows:

create_new_app_event(self, log_level="error", classification="issue", event_type="unknown",
                     event_message="unknown", exc_info=False):

exc_info can be set to True to get the latest exception traces from sys.exc_info or simply passed in.

If you are using Django, we recommend that you look at django user agents as a simple and quick way of getting the browser's name and version rather than parsing the user agent yourself. The library also allows you to check the client browser in the template, allowing you to modify the front end to the error accordingly. Please note that this library is not maintained by or related to Trakerr in any way.

An in-depth look at TrakerrClient's properties

TrakerrClient's constructor initalizes the default values to all of TrakerrClient's properties.

def __init__(self, api_key, context_app_version="1.0",
             context_deployment_stage="development", application_sku="", tags=[],
             threads=4, connnections=4):

The threads parameter specify the number of max_workers in the thread pool. This only matters if you are using send_event_async in python 3.2+. The connections parameter specificies the number of connections in the connection pool. If there are more threads than connections, the connection pool will block the derivitive async calls until it can serve a connection.

The TrakerrClient class however has a lot of exposed properties. The benefit to setting these immediately after after you create the TrakerrClient is that AppEvent will default it's values with the TrakerrClient instance that created it. This way if there is a value that all your AppEvents uses, and the constructor default value currently doesn't suit you; it may be easier to change it in the TrakerrClient instance as it will become the default value for all AppEvents created after. A lot of these are populated by default value by the constructor, but you can populate them with whatever string data you want. The following table provides an in depth look at each of those.

If you're populating an app event directly, you'll want to take a look at the AppEvent properties as they contain properties unique to each AppEvent which do not have defaults you may set in the client.

Name Type Description Notes
api_key string API key generated for the application.
context_app_version string Application version information. Default value: 1.0
context_development_stage string One of development, staging, production; or a custom string. Default Value: development
context_env_anguage string Constant string representing the language the application is in. Default value: python
context_env_name string Name of the interpreter the program is run on. Default Value: platform.python_implementation()
context_env_version string Version of python this program is running on. Default Value: platform.python_version()
context_env_hostname string Hostname or ID of environment. Default value: platform.node()
context_app_os string OS the application is running on. Default value: platform.system() + platform.release() on Windows, platform.system() on all other platforms
context_appos_version string OS Version the application is running on. Default value: platform.version() on Windows, platform.release() on all other platforms
context_appbrowser string An optional string browser name the application is running on. Defaults to None
context_appbrowser_version string An optional string browser version the application is running on. Defaults to None
context_data_center string Data center the application is running on or connected to. Defaults to None
context_data_center_region string Data center region. Defaults to None
context_app_sku string (optional) Application SKU Defaults to None
context_tags List[Strings] (optional) List of strings tags to classify the loggers purpose (IE: modules, submodules, ect) Defaults to []

Advanced pip install commands for Trakerr

You can run the following command to update an exsisting installation to the latest commit on master:

pip install git+https://github.com/trakerr-com/trakerr-python.git --upgrade

You can install from a branch for development or testing a new feature (Not recommended for production use):

pip install git+https://github.com/trakerr-com/trakerr-python.git@<branch_name_here>

Documentation For Models

Author

RM