You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Looking at webscript, seems like we'd need to utilize the counter functionality.
So every time a webhook is sent for an incident when the state is triggered/acknowledged/resolved it would need to update the appropriate counter and then update the correct widget via the Dashing API.
So imagine this lifecycle:
Incident is created, the current status is "triggered", the triggered counter is incremented and an API request is sent to the correct widget with the counter value.
Incident is acknowledged, the triggered counter is decremented, the acknowledged counter is incremented and an API request is sent to the correct widget with the acknowledged counter value.
Incident is resolved, the acknowledge counter is decrement and an API request is sent to the correct widge with the acknowledged counter value.
With this type of setup I think the pagerduty_incidents.rb job could just go away.
I will say that I think there some actions which are best suited for polling, such at the daily/weekly/monthly queries, that's what the incidents per time api is for.
I like where this is headed though. Also, looks like I should try out some Lua :)
The only issue there is that you have to trust the webscripts.io script to maintain the right count. What I'm thinking is that jobs are normally scheduled for a long interval (say, 5m), but any time there's an inbound webhook, it runs the incidents.rb job right then. If webhooks fail for some reason, the widgets will still get the data through polling.
Just added a sample of this to pagerdashing.herokuapp.com/combo. The widget code is:
Pretty much, what I want to do is:
Use this to translate a PD webhook into a dashing event: https://gist.github.com/dshack/2446ffdf9eb5a17f6c21
Then have that run the pagerduty_incidents.rb job, so that it's not polling until/unless there's an incoming incident.
The text was updated successfully, but these errors were encountered: