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
d26d8c71
Commit
d26d8c71
authored
Mar 16, 2018
by
Marcus Efraimsson
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' into mssql_datasource
parents
06afd24a
1014f7c4
Hide whitespace changes
Inline
Side-by-side
Showing
21 changed files
with
109 additions
and
84 deletions
+109
-84
pkg/services/alerting/notifiers/alertmanager.go
+62
-16
pkg/services/alerting/notifiers/base.go
+6
-0
pkg/services/alerting/notifiers/dingding.go
+0
-4
pkg/services/alerting/notifiers/email.go
+0
-4
pkg/services/alerting/notifiers/hipchat.go
+0
-4
pkg/services/alerting/notifiers/kafka.go
+0
-4
pkg/services/alerting/notifiers/line.go
+0
-4
pkg/services/alerting/notifiers/opsgenie.go
+0
-4
pkg/services/alerting/notifiers/pagerduty.go
+0
-4
pkg/services/alerting/notifiers/pushover.go
+0
-4
pkg/services/alerting/notifiers/sensu.go
+0
-4
pkg/services/alerting/notifiers/slack.go
+0
-4
pkg/services/alerting/notifiers/teams.go
+0
-4
pkg/services/alerting/notifiers/telegram.go
+1
-4
pkg/services/alerting/notifiers/threema.go
+0
-4
pkg/services/alerting/notifiers/victorops.go
+0
-4
pkg/services/alerting/notifiers/webhook.go
+0
-4
public/app/plugins/datasource/prometheus/completer.ts
+20
-6
public/app/plugins/datasource/prometheus/mode-prometheus.js
+3
-0
public/app/plugins/datasource/prometheus/query_ctrl.ts
+1
-1
public/app/plugins/datasource/prometheus/specs/completer_specs.ts
+16
-1
No files found.
pkg/services/alerting/notifiers/alertmanager.go
View file @
d26d8c71
...
...
@@ -46,25 +46,49 @@ type AlertmanagerNotifier struct {
}
func
(
this
*
AlertmanagerNotifier
)
ShouldNotify
(
evalContext
*
alerting
.
EvalContext
)
bool
{
this
.
log
.
Debug
(
"Should notify"
,
"ruleId"
,
evalContext
.
Rule
.
Id
,
"state"
,
evalContext
.
Rule
.
State
,
"previousState"
,
evalContext
.
PrevAlertState
)
// Do not notify when we become OK for the first time.
if
(
evalContext
.
PrevAlertState
==
m
.
AlertStatePending
)
&&
(
evalContext
.
Rule
.
State
==
m
.
AlertStateOK
)
{
return
false
}
// Notify on Alerting -> OK to resolve before alertmanager timeout.
if
(
evalContext
.
PrevAlertState
==
m
.
AlertStateAlerting
)
&&
(
evalContext
.
Rule
.
State
==
m
.
AlertStateOK
)
{
return
true
}
return
evalContext
.
Rule
.
State
==
m
.
AlertStateAlerting
}
func
(
this
*
AlertmanagerNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
alerts
:=
make
([]
interface
{},
0
)
for
_
,
match
:=
range
evalContext
.
EvalMatches
{
alertJSON
:=
simplejson
.
New
()
alertJSON
.
Set
(
"startsAt"
,
evalContext
.
StartTime
.
UTC
()
.
Format
(
time
.
RFC3339
))
if
ruleUrl
,
err
:=
evalContext
.
GetRuleUrl
();
err
==
nil
{
alertJSON
.
Set
(
"generatorURL"
,
ruleUrl
)
}
func
(
this
*
AlertmanagerNotifier
)
createAlert
(
evalContext
*
alerting
.
EvalContext
,
match
*
alerting
.
EvalMatch
,
ruleUrl
string
)
*
simplejson
.
Json
{
alertJSON
:=
simplejson
.
New
()
alertJSON
.
Set
(
"startsAt"
,
evalContext
.
StartTime
.
UTC
()
.
Format
(
time
.
RFC3339
))
if
evalContext
.
Rule
.
State
==
m
.
AlertStateOK
{
alertJSON
.
Set
(
"endsAt"
,
time
.
Now
()
.
UTC
()
.
Format
(
time
.
RFC3339
))
}
alertJSON
.
Set
(
"generatorURL"
,
ruleUrl
)
if
evalContext
.
Rule
.
Message
!=
""
{
alertJSON
.
SetPath
([]
string
{
"annotations"
,
"description"
},
evalContext
.
Rule
.
Message
)
// Annotations (summary and description are very commonly used).
alertJSON
.
SetPath
([]
string
{
"annotations"
,
"summary"
},
evalContext
.
Rule
.
Name
)
description
:=
""
if
evalContext
.
Rule
.
Message
!=
""
{
description
+=
evalContext
.
Rule
.
Message
}
if
evalContext
.
Error
!=
nil
{
if
description
!=
""
{
description
+=
"
\n
"
}
description
+=
"Error: "
+
evalContext
.
Error
.
Error
()
}
if
description
!=
""
{
alertJSON
.
SetPath
([]
string
{
"annotations"
,
"description"
},
description
)
}
if
evalContext
.
ImagePublicUrl
!=
""
{
alertJSON
.
SetPath
([]
string
{
"annotations"
,
"image"
},
evalContext
.
ImagePublicUrl
)
}
tags
:=
make
(
map
[
string
]
string
)
// Labels (from metrics tags + mandatory alertname).
tags
:=
make
(
map
[
string
]
string
)
if
match
!=
nil
{
if
len
(
match
.
Tags
)
==
0
{
tags
[
"metric"
]
=
match
.
Metric
}
else
{
...
...
@@ -72,10 +96,32 @@ func (this *AlertmanagerNotifier) Notify(evalContext *alerting.EvalContext) erro
tags
[
k
]
=
v
}
}
tags
[
"alertname"
]
=
evalContext
.
Rule
.
Name
alertJSON
.
Set
(
"labels"
,
tags
)
}
tags
[
"alertname"
]
=
evalContext
.
Rule
.
Name
alertJSON
.
Set
(
"labels"
,
tags
)
return
alertJSON
}
func
(
this
*
AlertmanagerNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Sending Alertmanager alert"
,
"ruleId"
,
evalContext
.
Rule
.
Id
,
"notification"
,
this
.
Name
)
ruleUrl
,
err
:=
evalContext
.
GetRuleUrl
()
if
err
!=
nil
{
this
.
log
.
Error
(
"Failed get rule link"
,
"error"
,
err
)
return
err
}
// Send one alert per matching series.
alerts
:=
make
([]
interface
{},
0
)
for
_
,
match
:=
range
evalContext
.
EvalMatches
{
alert
:=
this
.
createAlert
(
evalContext
,
match
,
ruleUrl
)
alerts
=
append
(
alerts
,
alert
)
}
alerts
=
append
(
alerts
,
alertJSON
)
// This happens on ExecutionError or NoData
if
len
(
alerts
)
==
0
{
alert
:=
this
.
createAlert
(
evalContext
,
nil
,
ruleUrl
)
alerts
=
append
(
alerts
,
alert
)
}
bodyJSON
:=
simplejson
.
NewFromAny
(
alerts
)
...
...
pkg/services/alerting/notifiers/base.go
View file @
d26d8c71
...
...
@@ -27,15 +27,21 @@ func NewNotifierBase(id int64, isDefault bool, name, notifierType string, model
}
func
defaultShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
// Only notify on state change.
if
context
.
PrevAlertState
==
context
.
Rule
.
State
{
return
false
}
// Do not notify when we become OK for the first time.
if
(
context
.
PrevAlertState
==
m
.
AlertStatePending
)
&&
(
context
.
Rule
.
State
==
m
.
AlertStateOK
)
{
return
false
}
return
true
}
func
(
n
*
NotifierBase
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
n
*
NotifierBase
)
GetType
()
string
{
return
n
.
Type
}
...
...
pkg/services/alerting/notifiers/dingding.go
View file @
d26d8c71
...
...
@@ -38,10 +38,6 @@ func NewDingDingNotifier(model *m.AlertNotification) (alerting.Notifier, error)
},
nil
}
func
(
this
*
DingDingNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
type
DingDingNotifier
struct
{
NotifierBase
Url
string
...
...
pkg/services/alerting/notifiers/email.go
View file @
d26d8c71
...
...
@@ -58,10 +58,6 @@ func NewEmailNotifier(model *m.AlertNotification) (alerting.Notifier, error) {
},
nil
}
func
(
this
*
EmailNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
EmailNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Sending alert notification to"
,
"addresses"
,
this
.
Addresses
)
...
...
pkg/services/alerting/notifiers/hipchat.go
View file @
d26d8c71
...
...
@@ -75,10 +75,6 @@ type HipChatNotifier struct {
log
log
.
Logger
}
func
(
this
*
HipChatNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
HipChatNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Executing hipchat notification"
,
"ruleId"
,
evalContext
.
Rule
.
Id
,
"notification"
,
this
.
Name
)
...
...
pkg/services/alerting/notifiers/kafka.go
View file @
d26d8c71
...
...
@@ -57,10 +57,6 @@ type KafkaNotifier struct {
log
log
.
Logger
}
func
(
this
*
KafkaNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
KafkaNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
state
:=
evalContext
.
Rule
.
State
...
...
pkg/services/alerting/notifiers/line.go
View file @
d26d8c71
...
...
@@ -51,10 +51,6 @@ type LineNotifier struct {
log
log
.
Logger
}
func
(
this
*
LineNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
LineNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Executing line notification"
,
"ruleId"
,
evalContext
.
Rule
.
Id
,
"notification"
,
this
.
Name
)
...
...
pkg/services/alerting/notifiers/opsgenie.go
View file @
d26d8c71
...
...
@@ -72,10 +72,6 @@ type OpsGenieNotifier struct {
log
log
.
Logger
}
func
(
this
*
OpsGenieNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
OpsGenieNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
var
err
error
...
...
pkg/services/alerting/notifiers/pagerduty.go
View file @
d26d8c71
...
...
@@ -65,10 +65,6 @@ type PagerdutyNotifier struct {
log
log
.
Logger
}
func
(
this
*
PagerdutyNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
PagerdutyNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
if
evalContext
.
Rule
.
State
==
m
.
AlertStateOK
&&
!
this
.
AutoResolve
{
...
...
pkg/services/alerting/notifiers/pushover.go
View file @
d26d8c71
...
...
@@ -123,10 +123,6 @@ type PushoverNotifier struct {
log
log
.
Logger
}
func
(
this
*
PushoverNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
PushoverNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
ruleUrl
,
err
:=
evalContext
.
GetRuleUrl
()
if
err
!=
nil
{
...
...
pkg/services/alerting/notifiers/sensu.go
View file @
d26d8c71
...
...
@@ -71,10 +71,6 @@ type SensuNotifier struct {
log
log
.
Logger
}
func
(
this
*
SensuNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
SensuNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Sending sensu result"
)
...
...
pkg/services/alerting/notifiers/slack.go
View file @
d26d8c71
...
...
@@ -98,10 +98,6 @@ type SlackNotifier struct {
log
log
.
Logger
}
func
(
this
*
SlackNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
SlackNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Executing slack notification"
,
"ruleId"
,
evalContext
.
Rule
.
Id
,
"notification"
,
this
.
Name
)
...
...
pkg/services/alerting/notifiers/teams.go
View file @
d26d8c71
...
...
@@ -47,10 +47,6 @@ type TeamsNotifier struct {
log
log
.
Logger
}
func
(
this
*
TeamsNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
TeamsNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Executing teams notification"
,
"ruleId"
,
evalContext
.
Rule
.
Id
,
"notification"
,
this
.
Name
)
...
...
pkg/services/alerting/notifiers/telegram.go
View file @
d26d8c71
...
...
@@ -208,6 +208,7 @@ func generateImageCaption(evalContext *alerting.EvalContext, ruleUrl string, met
return
message
}
func
appendIfPossible
(
message
string
,
extra
string
,
sizeLimit
int
)
string
{
if
len
(
extra
)
+
len
(
message
)
<=
sizeLimit
{
return
message
+
extra
...
...
@@ -216,10 +217,6 @@ func appendIfPossible(message string, extra string, sizeLimit int) string {
return
message
}
func
(
this
*
TelegramNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
TelegramNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
var
cmd
*
m
.
SendWebhookSync
if
evalContext
.
ImagePublicUrl
==
""
&&
this
.
UploadImage
==
true
{
...
...
pkg/services/alerting/notifiers/threema.go
View file @
d26d8c71
...
...
@@ -114,10 +114,6 @@ func NewThreemaNotifier(model *m.AlertNotification) (alerting.Notifier, error) {
},
nil
}
func
(
this
*
ThreemaNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
notifier
*
ThreemaNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
notifier
.
log
.
Info
(
"Sending alert notification from"
,
"threema_id"
,
notifier
.
GatewayID
)
notifier
.
log
.
Info
(
"Sending alert notification to"
,
"threema_id"
,
notifier
.
RecipientID
)
...
...
pkg/services/alerting/notifiers/victorops.go
View file @
d26d8c71
...
...
@@ -68,10 +68,6 @@ type VictoropsNotifier struct {
log
log
.
Logger
}
func
(
this
*
VictoropsNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
// Notify sends notification to Victorops via POST to URL endpoint
func
(
this
*
VictoropsNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Executing victorops notification"
,
"ruleId"
,
evalContext
.
Rule
.
Id
,
"notification"
,
this
.
Name
)
...
...
pkg/services/alerting/notifiers/webhook.go
View file @
d26d8c71
...
...
@@ -65,10 +65,6 @@ type WebhookNotifier struct {
log
log
.
Logger
}
func
(
this
*
WebhookNotifier
)
ShouldNotify
(
context
*
alerting
.
EvalContext
)
bool
{
return
defaultShouldNotify
(
context
)
}
func
(
this
*
WebhookNotifier
)
Notify
(
evalContext
*
alerting
.
EvalContext
)
error
{
this
.
log
.
Info
(
"Sending webhook"
)
...
...
public/app/plugins/datasource/prometheus/completer.ts
View file @
d26d8c71
...
...
@@ -5,32 +5,46 @@ export class PromCompleter {
labelQueryCache
:
any
;
labelNameCache
:
any
;
labelValueCache
:
any
;
templateVariableCompletions
:
any
;
identifierRegexps
=
[
/
\[
/
,
/
[
a-zA-Z0-9_:
]
/
];
constructor
(
private
datasource
:
PrometheusDatasource
)
{
constructor
(
private
datasource
:
PrometheusDatasource
,
private
templateSrv
)
{
this
.
labelQueryCache
=
{};
this
.
labelNameCache
=
{};
this
.
labelValueCache
=
{};
this
.
templateVariableCompletions
=
this
.
templateSrv
.
variables
.
map
(
variable
=>
{
return
{
caption
:
'$'
+
variable
.
name
,
value
:
'$'
+
variable
.
name
,
meta
:
'variable'
,
score
:
Number
.
MAX_VALUE
,
};
});
}
getCompletions
(
editor
,
session
,
pos
,
prefix
,
callback
)
{
let
wrappedCallback
=
(
err
,
completions
)
=>
{
completions
=
completions
.
concat
(
this
.
templateVariableCompletions
);
return
callback
(
err
,
completions
);
};
let
token
=
session
.
getTokenAt
(
pos
.
row
,
pos
.
column
);
switch
(
token
.
type
)
{
case
'entity.name.tag.label-matcher'
:
this
.
getCompletionsForLabelMatcherName
(
session
,
pos
).
then
(
completions
=>
{
c
allback
(
null
,
completions
);
wrappedC
allback
(
null
,
completions
);
});
return
;
case
'string.quoted.label-matcher'
:
this
.
getCompletionsForLabelMatcherValue
(
session
,
pos
).
then
(
completions
=>
{
c
allback
(
null
,
completions
);
wrappedC
allback
(
null
,
completions
);
});
return
;
case
'entity.name.tag.label-list-matcher'
:
this
.
getCompletionsForBinaryOperator
(
session
,
pos
).
then
(
completions
=>
{
c
allback
(
null
,
completions
);
wrappedC
allback
(
null
,
completions
);
});
return
;
}
...
...
@@ -59,14 +73,14 @@ export class PromCompleter {
meta
:
'range vector'
,
});
c
allback
(
null
,
vectors
);
wrappedC
allback
(
null
,
vectors
);
return
;
}
var
query
=
prefix
;
return
this
.
datasource
.
performSuggestQuery
(
query
,
true
).
then
(
metricNames
=>
{
c
allback
(
wrappedC
allback
(
null
,
metricNames
.
map
(
name
=>
{
let
value
=
name
;
...
...
public/app/plugins/datasource/prometheus/mode-prometheus.js
View file @
d26d8c71
...
...
@@ -51,6 +51,9 @@ var PrometheusHighlightRules = function() {
regex
:
"by|without|on|ignoring|group_left|group_right"
,
next
:
"start-label-list-matcher"
},
{
token
:
"variable"
,
regex
:
"
\\
$[A-Za-z0-9_]+"
},
{
token
:
keywordMapper
,
regex
:
"[a-zA-Z_:][a-zA-Z0-9_:]*"
},
{
...
...
public/app/plugins/datasource/prometheus/query_ctrl.ts
View file @
d26d8c71
...
...
@@ -43,7 +43,7 @@ class PrometheusQueryCtrl extends QueryCtrl {
}
getCompleter
(
query
)
{
return
new
PromCompleter
(
this
.
datasource
);
return
new
PromCompleter
(
this
.
datasource
,
this
.
templateSrv
);
}
getDefaultFormat
()
{
...
...
public/app/plugins/datasource/prometheus/specs/completer_specs.ts
View file @
d26d8c71
import
{
describe
,
it
,
sinon
,
expect
}
from
'test/lib/common'
;
import
helpers
from
'test/specs/helpers'
;
import
{
PromCompleter
}
from
'../completer'
;
import
{
PrometheusDatasource
}
from
'../datasource'
;
describe
(
'Prometheus editor completer'
,
function
()
{
var
ctx
=
new
helpers
.
ServiceTestContext
();
beforeEach
(
ctx
.
providePhase
([
'templateSrv'
]));
function
getSessionStub
(
data
)
{
return
{
getTokenAt
:
sinon
.
stub
().
returns
(
data
.
currentToken
),
...
...
@@ -39,7 +43,18 @@ describe('Prometheus editor completer', function() {
.
returns
(
Promise
.
resolve
([
'node_cpu'
])),
};
let
completer
=
new
PromCompleter
(
datasourceStub
);
let
templateSrv
=
{
variables
:
[
{
name
:
'var_name'
,
options
:
[
{
text
:
'foo'
,
value
:
'foo'
,
selected
:
false
},
{
text
:
'bar'
,
value
:
'bar'
,
selected
:
true
}
]
}
]
};
let
completer
=
new
PromCompleter
(
datasourceStub
,
templateSrv
);
describe
(
'When inside brackets'
,
()
=>
{
it
(
'Should return range vectors'
,
()
=>
{
...
...
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