Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
nexpie-grafana-theme
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Registry
Registry
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kornkitt Poolsup
nexpie-grafana-theme
Commits
eb34855a
Commit
eb34855a
authored
Nov 08, 2016
by
bergquist
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
feat(pagerduty): add support for auto resolve
closes #6513
parent
0d729ae3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
65 additions
and
43 deletions
+65
-43
pkg/services/alerting/notifiers/pagerduty.go
+52
-40
public/app/features/alerting/notification_edit_ctrl.ts
+2
-1
public/app/features/alerting/partials/notification_edit.html
+11
-2
No files found.
pkg/services/alerting/notifiers/pagerduty.go
View file @
eb34855a
package
notifiers
package
notifiers
import
(
import
(
"strconv"
"github.com/grafana/grafana/pkg/bus"
"github.com/grafana/grafana/pkg/bus"
"github.com/grafana/grafana/pkg/components/simplejson"
"github.com/grafana/grafana/pkg/components/simplejson"
"github.com/grafana/grafana/pkg/log"
"github.com/grafana/grafana/pkg/log"
...
@@ -18,6 +20,7 @@ var (
...
@@ -18,6 +20,7 @@ var (
)
)
func
NewPagerdutyNotifier
(
model
*
m
.
AlertNotification
)
(
alerting
.
Notifier
,
error
)
{
func
NewPagerdutyNotifier
(
model
*
m
.
AlertNotification
)
(
alerting
.
Notifier
,
error
)
{
autoResolve
:=
model
.
Settings
.
Get
(
"autoResolve"
)
.
MustBool
(
true
)
key
:=
model
.
Settings
.
Get
(
"integrationKey"
)
.
MustString
()
key
:=
model
.
Settings
.
Get
(
"integrationKey"
)
.
MustString
()
if
key
==
""
{
if
key
==
""
{
return
nil
,
alerting
.
ValidationError
{
Reason
:
"Could not find integration key property in settings"
}
return
nil
,
alerting
.
ValidationError
{
Reason
:
"Could not find integration key property in settings"
}
...
@@ -26,57 +29,66 @@ func NewPagerdutyNotifier(model *m.AlertNotification) (alerting.Notifier, error)
...
@@ -26,57 +29,66 @@ func NewPagerdutyNotifier(model *m.AlertNotification) (alerting.Notifier, error)
return
&
PagerdutyNotifier
{
return
&
PagerdutyNotifier
{
NotifierBase
:
NewNotifierBase
(
model
.
Id
,
model
.
IsDefault
,
model
.
Name
,
model
.
Type
,
model
.
Settings
),
NotifierBase
:
NewNotifierBase
(
model
.
Id
,
model
.
IsDefault
,
model
.
Name
,
model
.
Type
,
model
.
Settings
),
Key
:
key
,
Key
:
key
,
AutoResolve
:
autoResolve
,
log
:
log
.
New
(
"alerting.notifier.pagerduty"
),
log
:
log
.
New
(
"alerting.notifier.pagerduty"
),
},
nil
},
nil
}
}
type
PagerdutyNotifier
struct
{
type
PagerdutyNotifier
struct
{
NotifierBase
NotifierBase
Key
string
Key
string
log
log
.
Logger
AutoResolve
bool
log
log
.
Logger
}
}
func
(
this
*
PagerdutyNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
func
(
this
*
PagerdutyNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Notifying Pagerduty"
)
metrics
.
M_Alerting_Notification_Sent_PagerDuty
.
Inc
(
1
)
metrics
.
M_Alerting_Notification_Sent_PagerDuty
.
Inc
(
1
)
if
evalContext
.
Rule
.
State
==
m
.
AlertStateAlerting
{
if
evalContext
.
Rule
.
State
==
m
.
AlertStateOK
&&
!
this
.
AutoResolve
{
bodyJSON
:=
simplejson
.
New
()
this
.
log
.
Info
(
"Not sending a trigger to Pagerduty"
,
"state"
,
evalContext
.
Rule
.
State
,
"auto resolve"
,
this
.
AutoResolve
)
bodyJSON
.
Set
(
"service_key"
,
this
.
Key
)
return
nil
bodyJSON
.
Set
(
"description"
,
evalContext
.
Rule
.
Name
+
" - "
+
evalContext
.
Rule
.
Message
)
}
bodyJSON
.
Set
(
"client"
,
"Grafana"
)
bodyJSON
.
Set
(
"event_type"
,
"trigger"
)
eventType
:=
"trigger"
if
evalContext
.
Rule
.
State
==
m
.
AlertStateOK
{
ruleUrl
,
err
:=
evalContext
.
GetRuleUrl
()
eventType
=
"resolve"
if
err
!=
nil
{
}
this
.
log
.
Error
(
"Failed get rule link"
,
"error"
,
err
)
return
err
this
.
log
.
Info
(
"Notifying Pagerduty"
,
"event_type"
,
eventType
)
}
bodyJSON
.
Set
(
"client_url"
,
ruleUrl
)
bodyJSON
:=
simplejson
.
New
()
bodyJSON
.
Set
(
"service_key"
,
this
.
Key
)
if
evalContext
.
ImagePublicUrl
!=
""
{
bodyJSON
.
Set
(
"description"
,
evalContext
.
Rule
.
Name
+
" - "
+
evalContext
.
Rule
.
Message
)
contexts
:=
make
([]
interface
{},
1
)
bodyJSON
.
Set
(
"client"
,
"Grafana"
)
imageJSON
:=
simplejson
.
New
()
bodyJSON
.
Set
(
"event_type"
,
eventType
)
imageJSON
.
Set
(
"type"
,
"image"
)
bodyJSON
.
Set
(
"incident_key"
,
"alertId-"
+
strconv
.
FormatInt
(
evalContext
.
Rule
.
Id
,
10
))
imageJSON
.
Set
(
"src"
,
evalContext
.
ImagePublicUrl
)
contexts
[
0
]
=
imageJSON
ruleUrl
,
err
:=
evalContext
.
GetRuleUrl
()
bodyJSON
.
Set
(
"contexts"
,
contexts
)
if
err
!=
nil
{
}
this
.
log
.
Error
(
"Failed get rule link"
,
"error"
,
err
)
return
err
body
,
_
:=
bodyJSON
.
MarshalJSON
()
}
bodyJSON
.
Set
(
"client_url"
,
ruleUrl
)
cmd
:=
&
m
.
SendWebhookSync
{
Url
:
pagerdutyEventApiUrl
,
if
evalContext
.
ImagePublicUrl
!=
""
{
Body
:
string
(
body
),
contexts
:=
make
([]
interface
{},
1
)
HttpMethod
:
"POST"
,
imageJSON
:=
simplejson
.
New
()
}
imageJSON
.
Set
(
"type"
,
"image"
)
imageJSON
.
Set
(
"src"
,
evalContext
.
ImagePublicUrl
)
if
err
:=
bus
.
DispatchCtx
(
evalContext
.
Ctx
,
cmd
);
err
!=
nil
{
contexts
[
0
]
=
imageJSON
this
.
log
.
Error
(
"Failed to send notification to Pagerduty"
,
"error"
,
err
,
"body"
,
string
(
body
))
bodyJSON
.
Set
(
"contexts"
,
contexts
)
}
}
}
else
{
body
,
_
:=
bodyJSON
.
MarshalJSON
()
this
.
log
.
Info
(
"Not sending a trigger to Pagerduty"
,
"state"
,
evalContext
.
Rule
.
State
)
cmd
:=
&
m
.
SendWebhookSync
{
Url
:
pagerdutyEventApiUrl
,
Body
:
string
(
body
),
HttpMethod
:
"POST"
,
}
if
err
:=
bus
.
DispatchCtx
(
evalContext
.
Ctx
,
cmd
);
err
!=
nil
{
this
.
log
.
Error
(
"Failed to send notification to Pagerduty"
,
"error"
,
err
,
"body"
,
string
(
body
))
}
}
return
nil
return
nil
...
...
public/app/features/alerting/notification_edit_ctrl.ts
View file @
eb34855a
...
@@ -18,7 +18,8 @@ export class AlertNotificationEditCtrl {
...
@@ -18,7 +18,8 @@ export class AlertNotificationEditCtrl {
this
.
model
=
{
this
.
model
=
{
type
:
'email'
,
type
:
'email'
,
settings
:
{
settings
:
{
httpMethod
:
'POST'
httpMethod
:
'POST'
,
autoResolve
:
true
,
},
},
isDefault
:
false
isDefault
:
false
};
};
...
...
public/app/features/alerting/partials/notification_edit.html
View file @
eb34855a
...
@@ -100,8 +100,17 @@
...
@@ -100,8 +100,17 @@
<div
class=
"gf-form-group"
ng-if=
"ctrl.model.type === 'pagerduty'"
>
<div
class=
"gf-form-group"
ng-if=
"ctrl.model.type === 'pagerduty'"
>
<h3
class=
"page-heading"
>
Pagerduty settings
</h3>
<h3
class=
"page-heading"
>
Pagerduty settings
</h3>
<div
class=
"gf-form"
>
<div
class=
"gf-form"
>
<span
class=
"gf-form-label width-12"
>
Integration Key
</span>
<span
class=
"gf-form-label width-14"
>
Integration Key
</span>
<input
type=
"text"
required
class=
"gf-form-input max-width-30"
ng-model=
"ctrl.model.settings.integrationKey"
placeholder=
"Pagerduty integeration Key"
></input>
<input
type=
"text"
required
class=
"gf-form-input max-width-22"
ng-model=
"ctrl.model.settings.integrationKey"
placeholder=
"Pagerduty integeration Key"
></input>
</div>
<div
class=
"gf-form"
>
<gf-form-switch
class=
"gf-form"
label=
"Auto resolve incidents"
label-class=
"width-14"
checked=
"ctrl.model.settings.autoResolve"
tooltip=
"Resolve incidents in pagerduty once the alert goes back to ok."
>
</gf-form-switch>
</div>
</div>
</div>
</div>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment