Skip to main content

Client for Pingdom Services

Project description

https://img.shields.io/pypi/v/pypingdom.svg https://img.shields.io/pypi/l/pypingdom.svg https://img.shields.io/pypi/pyversions/pypingdom.svg https://travis-ci.org/sekipaolo/pypingdom.svg?branch=master

Python library for interacting with Pingdom services (REST API and maintenance windows).

Features

  • Support for Multi-User Authentication

  • Check management: create, delete, update, list

  • Maintenance windows: create, delete, list

  • Fetching outage summaries

Requirements

  • Pingdom account

  • requests (0.10.8 or newer)

Installation

pip install pypingdom

Usage

The client object will allow you to interact both with the REST API and the GUI (for maintenance windows).

>>> import pypingdom
>>> client = pypingdom.Client(username="username@example.com",
                        password="your_password",
                        apikey="your_api_key",
                        email="your_email")

the email parameter is required for Multiuser Authentication.

Checks

Since Pingdom does not treat the check name as identifier (as we probably want to do) the client object will retrieve the check list from the API and cache it as a dictionary ( check_name => check_instance). You can access it through the checks attribute:

>>> client.checks["my awesome check"]
pingdom.Check <1895866>
  autoresolve: 0
  alert_policy: 2118909
  name: example_com
  created: 1448565930
  lasterrortime: 1489325292
  resolution: 1
  lastresponsetime: 558
  lasttesttime: 1489847772
  alert_policy_name: Production Systems
  paused: False
  host: hostname.example.com
  acktimeout: 0
  ipv6: False
  use_legacy_notifications: False
  type: http
  tags: []

a better way to retrieve a check would be:

>>> client.get_check("my awesome check")

that will return None if the check doesn’t exists

List checks with production and frontend tags:

>>> client.get_checks(filters={"tags": ["production", "frontend"]})

Create a check:

>>> check_definition = {
        "name": "My awesome check",
        "paused": True,
        "alert_policy": 201745,
        "type": "http",
        "host": "www.google.com",
        "url": "/",
        "requestheaders": {
            'XCustom': 'my header value'
        },
        "tags": [{"name": "pypingdom-test"}, {"name": "custom-tag"}],
        "encryption": False
    }
>>> client.create_check(check_definition)

Refers to this page for the list of options.

When you create or modify a check some related entity need to be referenced by id:

Integrations

To enable/disable an integration plugins (like webhooks) use the field integrationids (array with integer ids to set or “null” tring to remove it)

Alert policies

To bind an alerting policy use the field alert_policy (numeric id to set it or string “null” to disable alerts)

Update a check:

>>> client.update_check(check, {"paused": True})

this will return True if an effective change was sent to the API and False otherwise (useful for idempotent usage, like ansible modules)

Delete a check:

>>> client.delete_check(check)

Maintenance windows

Retreive maintenance windows for production websites in the last 7 days:

>>> import datetime
>>> checks = client.get_checks(filters={"tags": ["production", "frontend"]})
>>> start = datetime.datetime.now() - datetime.timedelta(days=7)
>>> client.get_maintenances(filters={"checks": checks, "after": start})

Create a 1 hour maintenance window for production websites:

>>> start = datetime.datetime.now() + datetime.timedelta(minutes=10)
>>> end = start + datetime.timedelta(hours=1)

>>> window = client.create_maintenance({"checks": checks, "name": "pypingdom test maintenance", "start": start, "stop": end})

Delete future maintenance windows:

>>> windows = client.get_maintenances(filters={"checks": checks, "after": datetime.datetime.now()}):
>>> for m in maintenances:
    client.delete_maintenance(m)

Reporting/summary

Retrieve average response time and uptime summaries:

>>> checkid = client.get_check("my awesome check")._id
>>> start = int(time.time()) - 30*24*60*60 # 30 days back
>>> end = time.time()
>>> client.get_summary_average(checkid, start, end, include_uptime="true")

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pypingdom-0.2.2.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

pypingdom-0.2.2-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

Details for the file pypingdom-0.2.2.tar.gz.

File metadata

  • Download URL: pypingdom-0.2.2.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.6.5

File hashes

Hashes for pypingdom-0.2.2.tar.gz
Algorithm Hash digest
SHA256 6269a18f286d0a806a8409003a48a4f52e16f91fae998d267dde2e3b5edcc86c
MD5 c290bec17ad7de8e795ea4bbde71f0f2
BLAKE2b-256 101d79b1f3af2ef0c22f612914a87c4800c6e24c67dc62a17e3fc50eec317ed6

See more details on using hashes here.

File details

Details for the file pypingdom-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: pypingdom-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 10.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.6.5

File hashes

Hashes for pypingdom-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c467b54fe615dd42718f4b311f49ddaba0148a8153a1363ece481ee4f5b55497
MD5 313eef1e9f72419e720c3ec439b2c832
BLAKE2b-256 98c5def25496f8038045a612a6f8bf1f8bfc8ac21995e254f66c39f6525455fd

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page