Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

pagerduty-pdjs

Package Overview
Dependencies
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

pagerduty-pdjs

JavaScript wrapper for the PagerDuty API, maintained by PagerDuty

  • 1.1.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
9
increased by800%
Maintainers
1
Weekly downloads
 
Created
Source

PDJS (PagerDuty based JavaScript API)

This is a simple client-side JavaScript wrapper to the PagerDuty API.

Making an API request

Setup PDJSobj

  1. First, you'll need the following dependencies included in your project to utilize PDJS.
    • pdjs.js -- you can download it and manually add it to your project. Or, npm i pagerduty-pdjs.
  2. Create a PDJSobj object, setting values for the subdomain, token, and api_version fields on the object.
var PDJS = new PDJSobj({
  subdomain: 'webdemo',
  token: 'rcgtBVpizBZQjDzE3Hub',    
  api_version: 'v1',
  logging: true
});
  • subdomain -- for this example we're using the webdemo, but you would want to put in your subdomain.
  • token -- your API token. The one above is to provide read-only access to the webdemo account. You can decide what kind of access your token will provide when you create it.
  • api_version -- By default, PDJS uses version 2 of the PagerDuty REST and Events API. To request version 1, the api version needs to be specified here. The api_version parameter is optional.

Call API:

The most basic way to make an API call with PDJS is to use the PDJS.api() function.

PDJS.api({
  res: 'services',
  data: {
    limit: 20,
  },
  success: function (data) {
    console.log(data)
  },
})
  • res -- the API endpoint and path you're calling*
  • data -- the query-string parameters that can be appended to the endpoint. This parameter is optional.
  • success -- the callback function that is called when the API call completes successfully. This is required.
  • error -- the callback function that is called when there is an error with the API call. This parameter is optional, though recommended.

*In additino to specififying the endpoint, the res parameter may have an ID in it. For example, here's how to get the notes for an incident with the ID of PNCII2E.

PDJS.api({
  res: 'incidents/PNCII2E/notes',
  success: function (data) {
    alert(JSON.stringify(data))
  },
})

PUT and POST

POST and PUT requests are also supported.

For instance, the following snippet adds a contact_method for user: test@example.com, and then adding a notification rule to alert that email address after 900 minutes:

add_contact_method = function(user_id) {
  PDJS.api({
    res: `users/${user_id}/contact_methods`,
    type: 'POST',
    data: {
      contact_method: {
        type:'email_contact_method',
        address:'test4@example.com',
        label: 'Added from PDJS',
      }
    },
    success: function (data) {
      console.log('New contact method ID: ' + data.contact_method.id)
      add_notification_rule(user_id, data.contact_method, 900)
    }
  })
}

add_notification_rule = function(user_id, contact_method, start_delay_in_minutes) {
  PDJS.api({
    res: `users/${user_id}/notification_rules`,
    type: 'POST',
    data: {
      notification_rule: {
          type: "assignment_notification_rule",
          contact_method: contact_method,
          start_delay_in_minutes: start_delay_in_minutes,
          urgency: "high"
      }
    },
    success: function (data) {
      console.log(data)
      console.log('New notification rule ID: ' + data.notification_rule.id)
    }
  })
}

add_contact_method('PRJRF7T');

To see this code in action go to the add_contact_method example.

The api_all helper

In addition to PDJS.api() there's also PDJS.api_all() which is a helper method that will handle limits and offsets for lists longer than 100 elements:

PDJS.api_all({
  res: 'incidents',
  data: {
    since: '2013-08-01T09:53:17-07:00',
    until: '2013-08-14T09:53:17-07:00',
    status: 'resolved',
    fields: 'incident_number,status,created_on,service'
  },
  final_success: function(data) {
    console.log(data.total + ' objects!');
    console.log(data);
  },
  incremental_success: function(data) {
    console.log('Got data');
  }
})

It works the same as PDJS.api(), except you'll need to specify one or more of:

  • a function to run on final_success at the end
  • a function to run on each incremental_success

That's kind of nifty.

Examples

To get an idea for how PDJS works, there's an examples directory:

  • examples/incidents.html polls the incidents api and displays the triggered & acknowledged incidents
  • examples/report.html shows off api_all by looping through all the events on my webdemo account for the last 30 days and prints them out as a CSV-esque thing that you could paste into a CSV file

Compiling the Base Script:

PDJS is written in CoffeeScript. To make changes to the library, you'll edit the coffee/pdjsbase.coffee file and compile it by running the command below from the pdjs directory to produce the JavaScript.

coffee --output js/pdjs.js --compile --watch coffee/

More info

This project is for client-side JavaScript. If you're looking for a Node library, we recommend the node-pagerduty library.

Are you using this library or have questions? Let us know by posting to the PagerDuty Community Developer Forum.

You might notice that PDJS sends along some extra parameters, nothing scary, we use those to track QoS across our language-specific libraries.

Keywords

FAQs

Package last updated on 22 May 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc