2019-11-08 19:33:41 +00:00
|
|
|
package pkger
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2019-12-23 22:31:56 +00:00
|
|
|
"regexp"
|
2019-11-08 19:33:41 +00:00
|
|
|
"sort"
|
2019-12-23 22:31:56 +00:00
|
|
|
"strings"
|
2019-11-08 19:33:41 +00:00
|
|
|
|
|
|
|
"github.com/influxdata/influxdb"
|
2019-12-19 01:03:19 +00:00
|
|
|
"github.com/influxdata/influxdb/notification"
|
|
|
|
icheck "github.com/influxdata/influxdb/notification/check"
|
2019-12-16 20:10:45 +00:00
|
|
|
"github.com/influxdata/influxdb/notification/endpoint"
|
2019-12-20 20:51:27 +00:00
|
|
|
"github.com/influxdata/influxdb/notification/rule"
|
2019-11-08 19:33:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// ResourceToClone is a resource that will be cloned.
|
|
|
|
type ResourceToClone struct {
|
|
|
|
Kind Kind `json:"kind"`
|
|
|
|
ID influxdb.ID `json:"id"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// OK validates a resource clone is viable.
|
|
|
|
func (r ResourceToClone) OK() error {
|
|
|
|
if err := r.Kind.OK(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if r.ID == influxdb.ID(0) {
|
|
|
|
return errors.New("must provide an ID")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-11-21 00:38:12 +00:00
|
|
|
func uniqResourcesToClone(resources []ResourceToClone) []ResourceToClone {
|
|
|
|
type key struct {
|
|
|
|
kind Kind
|
|
|
|
id influxdb.ID
|
|
|
|
}
|
|
|
|
m := make(map[key]ResourceToClone)
|
|
|
|
|
|
|
|
for i := range resources {
|
|
|
|
r := resources[i]
|
|
|
|
rKey := key{kind: r.Kind, id: r.ID}
|
|
|
|
kr, ok := m[rKey]
|
|
|
|
switch {
|
|
|
|
case ok && kr.Name == r.Name:
|
|
|
|
case ok && kr.Name != "" && r.Name == "":
|
|
|
|
default:
|
|
|
|
m[rKey] = r
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
out := make([]ResourceToClone, 0, len(resources))
|
|
|
|
for _, r := range m {
|
|
|
|
out = append(out, r)
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2019-11-08 19:33:41 +00:00
|
|
|
func bucketToResource(bkt influxdb.Bucket, name string) Resource {
|
|
|
|
if name == "" {
|
|
|
|
name = bkt.Name
|
|
|
|
}
|
2019-11-21 00:38:12 +00:00
|
|
|
r := Resource{
|
|
|
|
fieldKind: KindBucket.title(),
|
|
|
|
fieldName: name,
|
|
|
|
}
|
2019-12-05 00:17:35 +00:00
|
|
|
assignNonZeroStrings(r, map[string]string{fieldDescription: bkt.Description})
|
2019-11-21 00:38:12 +00:00
|
|
|
if bkt.RetentionPeriod != 0 {
|
2019-11-22 18:41:08 +00:00
|
|
|
r[fieldBucketRetentionRules] = retentionRules{newRetentionRule(bkt.RetentionPeriod)}
|
2019-11-21 00:38:12 +00:00
|
|
|
}
|
|
|
|
return r
|
2019-11-08 19:33:41 +00:00
|
|
|
}
|
|
|
|
|
2019-12-19 01:03:19 +00:00
|
|
|
func checkToResource(ch influxdb.Check, name string) Resource {
|
|
|
|
if name == "" {
|
|
|
|
name = ch.GetName()
|
|
|
|
}
|
|
|
|
r := Resource{
|
|
|
|
fieldName: name,
|
|
|
|
fieldStatus: string(influxdb.TaskStatusActive),
|
|
|
|
}
|
|
|
|
assignNonZeroStrings(r, map[string]string{fieldDescription: ch.GetDescription()})
|
|
|
|
|
|
|
|
assignBase := func(base icheck.Base) {
|
|
|
|
r[fieldQuery] = base.Query.Text
|
|
|
|
r[fieldCheckStatusMessageTemplate] = base.StatusMessageTemplate
|
2019-12-20 20:51:27 +00:00
|
|
|
assignNonZeroFluxDurs(r, map[string]*notification.Duration{
|
|
|
|
fieldEvery: base.Every,
|
|
|
|
fieldOffset: base.Offset,
|
|
|
|
})
|
|
|
|
|
2019-12-19 01:03:19 +00:00
|
|
|
var tags []Resource
|
|
|
|
for _, t := range base.Tags {
|
|
|
|
if t.Valid() != nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
tags = append(tags, Resource{
|
|
|
|
fieldKey: t.Key,
|
|
|
|
fieldValue: t.Value,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
if len(tags) > 0 {
|
|
|
|
r[fieldCheckTags] = tags
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
switch cT := ch.(type) {
|
|
|
|
case *icheck.Deadman:
|
|
|
|
r[fieldKind] = KindCheckDeadman.title()
|
|
|
|
assignBase(cT.Base)
|
2019-12-20 20:51:27 +00:00
|
|
|
assignNonZeroFluxDurs(r, map[string]*notification.Duration{
|
|
|
|
fieldCheckTimeSince: cT.TimeSince,
|
|
|
|
fieldCheckStaleTime: cT.StaleTime,
|
|
|
|
})
|
2019-12-19 19:56:03 +00:00
|
|
|
r[fieldLevel] = cT.Level.String()
|
2019-12-19 01:03:19 +00:00
|
|
|
assignNonZeroBools(r, map[string]bool{fieldCheckReportZero: cT.ReportZero})
|
|
|
|
case *icheck.Threshold:
|
|
|
|
r[fieldKind] = KindCheckThreshold.title()
|
|
|
|
assignBase(cT.Base)
|
|
|
|
var thresholds []Resource
|
|
|
|
for _, th := range cT.Thresholds {
|
|
|
|
thresholds = append(thresholds, convertThreshold(th))
|
|
|
|
}
|
|
|
|
r[fieldCheckThresholds] = thresholds
|
|
|
|
}
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
|
|
|
func convertThreshold(th icheck.ThresholdConfig) Resource {
|
2019-12-19 19:56:03 +00:00
|
|
|
r := Resource{fieldLevel: th.GetLevel().String()}
|
2019-12-19 01:03:19 +00:00
|
|
|
|
2019-12-20 20:51:27 +00:00
|
|
|
assignLesser := func(threshType thresholdType, allValues bool, val float64) {
|
|
|
|
r[fieldType] = string(threshType)
|
|
|
|
assignNonZeroBools(r, map[string]bool{fieldCheckAllValues: allValues})
|
|
|
|
r[fieldValue] = val
|
|
|
|
}
|
|
|
|
|
2019-12-19 01:03:19 +00:00
|
|
|
switch realType := th.(type) {
|
|
|
|
case icheck.Lesser:
|
2019-12-20 20:51:27 +00:00
|
|
|
assignLesser(thresholdTypeLesser, realType.AllValues, realType.Value)
|
|
|
|
case *icheck.Lesser:
|
|
|
|
assignLesser(thresholdTypeLesser, realType.AllValues, realType.Value)
|
2019-12-19 01:03:19 +00:00
|
|
|
case icheck.Greater:
|
2019-12-20 20:51:27 +00:00
|
|
|
assignLesser(thresholdTypeGreater, realType.AllValues, realType.Value)
|
|
|
|
case *icheck.Greater:
|
|
|
|
assignLesser(thresholdTypeGreater, realType.AllValues, realType.Value)
|
2019-12-19 01:03:19 +00:00
|
|
|
case icheck.Range:
|
|
|
|
assignRangeThreshold(r, realType)
|
|
|
|
case *icheck.Range:
|
|
|
|
assignRangeThreshold(r, *realType)
|
|
|
|
}
|
|
|
|
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
|
|
|
func assignRangeThreshold(r Resource, rangeThreshold icheck.Range) {
|
|
|
|
thType := thresholdTypeOutsideRange
|
|
|
|
if rangeThreshold.Within {
|
|
|
|
thType = thresholdTypeInsideRange
|
|
|
|
}
|
|
|
|
r[fieldType] = string(thType)
|
|
|
|
assignNonZeroBools(r, map[string]bool{fieldCheckAllValues: rangeThreshold.AllValues})
|
|
|
|
r[fieldMax] = rangeThreshold.Max
|
|
|
|
r[fieldMin] = rangeThreshold.Min
|
|
|
|
}
|
2019-12-06 17:13:06 +00:00
|
|
|
func convertCellView(cell influxdb.Cell) chart {
|
|
|
|
var name string
|
|
|
|
if cell.View != nil {
|
|
|
|
name = cell.View.Name
|
|
|
|
}
|
2019-11-08 19:33:41 +00:00
|
|
|
ch := chart{
|
2019-12-06 17:13:06 +00:00
|
|
|
Name: name,
|
|
|
|
Height: int(cell.H),
|
|
|
|
Width: int(cell.W),
|
|
|
|
XPos: int(cell.X),
|
|
|
|
YPos: int(cell.Y),
|
2019-11-08 19:33:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
setCommon := func(k chartKind, iColors []influxdb.ViewColor, dec influxdb.DecimalPlaces, iQueries []influxdb.DashboardQuery) {
|
|
|
|
ch.Kind = k
|
|
|
|
ch.Colors = convertColors(iColors)
|
|
|
|
ch.DecimalPlaces = int(dec.Digits)
|
|
|
|
ch.EnforceDecimals = dec.IsEnforced
|
|
|
|
ch.Queries = convertQueries(iQueries)
|
|
|
|
}
|
|
|
|
|
|
|
|
setNoteFixes := func(note string, noteOnEmpty bool, prefix, suffix string) {
|
|
|
|
ch.Note = note
|
|
|
|
ch.NoteOnEmpty = noteOnEmpty
|
|
|
|
ch.Prefix = prefix
|
|
|
|
ch.Suffix = suffix
|
|
|
|
}
|
|
|
|
|
|
|
|
setLegend := func(l influxdb.Legend) {
|
|
|
|
ch.Legend.Orientation = l.Orientation
|
|
|
|
ch.Legend.Type = l.Type
|
|
|
|
}
|
|
|
|
|
2019-12-06 17:13:06 +00:00
|
|
|
props := cell.View.Properties
|
2019-11-08 19:33:41 +00:00
|
|
|
switch p := props.(type) {
|
|
|
|
case influxdb.GaugeViewProperties:
|
|
|
|
setCommon(chartKindGauge, p.ViewColors, p.DecimalPlaces, p.Queries)
|
|
|
|
setNoteFixes(p.Note, p.ShowNoteWhenEmpty, p.Prefix, p.Suffix)
|
2019-11-15 01:05:21 +00:00
|
|
|
case influxdb.HeatmapViewProperties:
|
|
|
|
ch.Kind = chartKindHeatMap
|
|
|
|
ch.Queries = convertQueries(p.Queries)
|
|
|
|
ch.Colors = stringsToColors(p.ViewColors)
|
|
|
|
ch.XCol = p.XColumn
|
|
|
|
ch.YCol = p.YColumn
|
|
|
|
ch.Axes = []axis{
|
|
|
|
{Label: p.XAxisLabel, Prefix: p.XPrefix, Suffix: p.XSuffix, Name: "x", Domain: p.XDomain},
|
|
|
|
{Label: p.YAxisLabel, Prefix: p.YPrefix, Suffix: p.YSuffix, Name: "y", Domain: p.YDomain},
|
|
|
|
}
|
|
|
|
ch.Note = p.Note
|
|
|
|
ch.NoteOnEmpty = p.ShowNoteWhenEmpty
|
|
|
|
ch.BinSize = int(p.BinSize)
|
2019-11-16 20:14:46 +00:00
|
|
|
case influxdb.HistogramViewProperties:
|
|
|
|
ch.Kind = chartKindHistogram
|
|
|
|
ch.Queries = convertQueries(p.Queries)
|
|
|
|
ch.Colors = convertColors(p.ViewColors)
|
|
|
|
ch.XCol = p.XColumn
|
|
|
|
ch.Axes = []axis{{Label: p.XAxisLabel, Name: "x", Domain: p.XDomain}}
|
|
|
|
ch.Note = p.Note
|
|
|
|
ch.NoteOnEmpty = p.ShowNoteWhenEmpty
|
|
|
|
ch.BinCount = p.BinCount
|
|
|
|
ch.Position = p.Position
|
2019-11-15 01:05:21 +00:00
|
|
|
case influxdb.MarkdownViewProperties:
|
|
|
|
ch.Kind = chartKindMarkdown
|
|
|
|
ch.Note = p.Note
|
2019-11-08 19:33:41 +00:00
|
|
|
case influxdb.LinePlusSingleStatProperties:
|
|
|
|
setCommon(chartKindSingleStatPlusLine, p.ViewColors, p.DecimalPlaces, p.Queries)
|
|
|
|
setNoteFixes(p.Note, p.ShowNoteWhenEmpty, p.Prefix, p.Suffix)
|
|
|
|
setLegend(p.Legend)
|
|
|
|
ch.Axes = convertAxes(p.Axes)
|
|
|
|
ch.Shade = p.ShadeBelow
|
|
|
|
ch.XCol = p.XColumn
|
|
|
|
ch.YCol = p.YColumn
|
2019-12-03 22:59:07 +00:00
|
|
|
ch.Position = p.Position
|
2019-11-08 19:33:41 +00:00
|
|
|
case influxdb.SingleStatViewProperties:
|
|
|
|
setCommon(chartKindSingleStat, p.ViewColors, p.DecimalPlaces, p.Queries)
|
|
|
|
setNoteFixes(p.Note, p.ShowNoteWhenEmpty, p.Prefix, p.Suffix)
|
2019-11-15 01:05:21 +00:00
|
|
|
case influxdb.ScatterViewProperties:
|
|
|
|
ch.Kind = chartKindScatter
|
|
|
|
ch.Queries = convertQueries(p.Queries)
|
|
|
|
ch.Colors = stringsToColors(p.ViewColors)
|
|
|
|
ch.XCol = p.XColumn
|
|
|
|
ch.YCol = p.YColumn
|
|
|
|
ch.Axes = []axis{
|
|
|
|
{Label: p.XAxisLabel, Prefix: p.XPrefix, Suffix: p.XSuffix, Name: "x", Domain: p.XDomain},
|
|
|
|
{Label: p.YAxisLabel, Prefix: p.YPrefix, Suffix: p.YSuffix, Name: "y", Domain: p.YDomain},
|
|
|
|
}
|
2019-11-13 21:30:52 +00:00
|
|
|
ch.Note = p.Note
|
2019-11-15 01:05:21 +00:00
|
|
|
ch.NoteOnEmpty = p.ShowNoteWhenEmpty
|
2019-11-08 19:33:41 +00:00
|
|
|
case influxdb.XYViewProperties:
|
|
|
|
setCommon(chartKindXY, p.ViewColors, influxdb.DecimalPlaces{}, p.Queries)
|
|
|
|
setNoteFixes(p.Note, p.ShowNoteWhenEmpty, "", "")
|
|
|
|
setLegend(p.Legend)
|
|
|
|
ch.Axes = convertAxes(p.Axes)
|
|
|
|
ch.Geom = p.Geom
|
|
|
|
ch.Shade = p.ShadeBelow
|
|
|
|
ch.XCol = p.XColumn
|
|
|
|
ch.YCol = p.YColumn
|
2019-12-03 22:59:07 +00:00
|
|
|
ch.Position = p.Position
|
2019-11-08 19:33:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return ch
|
|
|
|
}
|
|
|
|
|
|
|
|
func convertChartToResource(ch chart) Resource {
|
|
|
|
r := Resource{
|
2019-11-09 02:12:48 +00:00
|
|
|
fieldKind: ch.Kind.title(),
|
2019-11-08 19:33:41 +00:00
|
|
|
fieldName: ch.Name,
|
|
|
|
fieldChartQueries: ch.Queries,
|
|
|
|
fieldChartHeight: ch.Height,
|
|
|
|
fieldChartWidth: ch.Width,
|
|
|
|
}
|
|
|
|
if len(ch.Colors) > 0 {
|
|
|
|
r[fieldChartColors] = ch.Colors
|
|
|
|
}
|
|
|
|
if len(ch.Axes) > 0 {
|
|
|
|
r[fieldChartAxes] = ch.Axes
|
|
|
|
}
|
|
|
|
if ch.EnforceDecimals {
|
|
|
|
r[fieldChartDecimalPlaces] = ch.DecimalPlaces
|
|
|
|
}
|
|
|
|
|
|
|
|
if ch.Legend.Type != "" {
|
|
|
|
r[fieldChartLegend] = ch.Legend
|
|
|
|
}
|
|
|
|
|
2019-12-05 00:17:35 +00:00
|
|
|
assignNonZeroBools(r, map[string]bool{
|
2019-11-08 19:33:41 +00:00
|
|
|
fieldChartNoteOnEmpty: ch.NoteOnEmpty,
|
|
|
|
fieldChartShade: ch.Shade,
|
2019-12-05 00:17:35 +00:00
|
|
|
})
|
2019-11-08 19:33:41 +00:00
|
|
|
|
2019-12-05 00:17:35 +00:00
|
|
|
assignNonZeroStrings(r, map[string]string{
|
2019-11-16 20:14:46 +00:00
|
|
|
fieldChartNote: ch.Note,
|
|
|
|
fieldPrefix: ch.Prefix,
|
|
|
|
fieldSuffix: ch.Suffix,
|
|
|
|
fieldChartGeom: ch.Geom,
|
|
|
|
fieldChartXCol: ch.XCol,
|
|
|
|
fieldChartYCol: ch.YCol,
|
|
|
|
fieldChartPosition: ch.Position,
|
2019-12-05 00:17:35 +00:00
|
|
|
})
|
2019-11-08 19:33:41 +00:00
|
|
|
|
2019-12-05 00:17:35 +00:00
|
|
|
assignNonZeroInts(r, map[string]int{
|
2019-11-16 20:14:46 +00:00
|
|
|
fieldChartXPos: ch.XPos,
|
|
|
|
fieldChartYPos: ch.YPos,
|
|
|
|
fieldChartBinCount: ch.BinCount,
|
|
|
|
fieldChartBinSize: ch.BinSize,
|
2019-12-05 00:17:35 +00:00
|
|
|
})
|
2019-11-08 19:33:41 +00:00
|
|
|
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
|
|
|
func convertAxes(iAxes map[string]influxdb.Axis) axes {
|
|
|
|
out := make(axes, 0, len(iAxes))
|
|
|
|
for name, a := range iAxes {
|
|
|
|
out = append(out, axis{
|
|
|
|
Base: a.Base,
|
|
|
|
Label: a.Label,
|
|
|
|
Name: name,
|
|
|
|
Prefix: a.Prefix,
|
|
|
|
Scale: a.Scale,
|
|
|
|
Suffix: a.Suffix,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
|
|
|
func convertColors(iColors []influxdb.ViewColor) colors {
|
|
|
|
out := make(colors, 0, len(iColors))
|
|
|
|
for _, ic := range iColors {
|
|
|
|
out = append(out, &color{
|
|
|
|
Name: ic.Name,
|
|
|
|
Type: ic.Type,
|
|
|
|
Hex: ic.Hex,
|
|
|
|
Value: flt64Ptr(ic.Value),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
|
|
|
func convertQueries(iQueries []influxdb.DashboardQuery) queries {
|
|
|
|
out := make(queries, 0, len(iQueries))
|
|
|
|
for _, iq := range iQueries {
|
|
|
|
out = append(out, query{Query: iq.Text})
|
|
|
|
}
|
|
|
|
return out
|
|
|
|
}
|
|
|
|
|
2020-01-06 17:05:25 +00:00
|
|
|
// DashboardToResource converts an influxdb.Dashboard to a pkger.Resource.
|
|
|
|
func DashboardToResource(dash influxdb.Dashboard, name string) Resource {
|
2019-11-08 19:33:41 +00:00
|
|
|
if name == "" {
|
|
|
|
name = dash.Name
|
|
|
|
}
|
|
|
|
|
2019-12-06 17:13:06 +00:00
|
|
|
sort.Slice(dash.Cells, func(i, j int) bool {
|
|
|
|
ic, jc := dash.Cells[i], dash.Cells[j]
|
2019-11-08 19:33:41 +00:00
|
|
|
if ic.X == jc.X {
|
|
|
|
return ic.Y < jc.Y
|
|
|
|
}
|
|
|
|
return ic.X < jc.X
|
|
|
|
})
|
|
|
|
|
2019-12-06 17:13:06 +00:00
|
|
|
charts := make([]Resource, 0, len(dash.Cells))
|
|
|
|
for _, cell := range dash.Cells {
|
|
|
|
if cell.ID == influxdb.ID(0) {
|
2019-11-08 19:33:41 +00:00
|
|
|
continue
|
|
|
|
}
|
2019-12-06 17:13:06 +00:00
|
|
|
ch := convertCellView(*cell)
|
2019-11-08 19:33:41 +00:00
|
|
|
if !ch.Kind.ok() {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
charts = append(charts, convertChartToResource(ch))
|
|
|
|
}
|
|
|
|
|
|
|
|
return Resource{
|
2019-11-09 02:12:48 +00:00
|
|
|
fieldKind: KindDashboard.title(),
|
2019-11-08 19:33:41 +00:00
|
|
|
fieldName: name,
|
|
|
|
fieldDescription: dash.Description,
|
|
|
|
fieldDashCharts: charts,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func labelToResource(l influxdb.Label, name string) Resource {
|
|
|
|
if name == "" {
|
|
|
|
name = l.Name
|
|
|
|
}
|
2019-11-21 00:38:12 +00:00
|
|
|
r := Resource{
|
|
|
|
fieldKind: KindLabel.title(),
|
|
|
|
fieldName: name,
|
|
|
|
}
|
2019-12-05 00:17:35 +00:00
|
|
|
|
|
|
|
assignNonZeroStrings(r, map[string]string{
|
|
|
|
fieldDescription: l.Properties["description"],
|
|
|
|
fieldLabelColor: l.Properties["color"],
|
|
|
|
})
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2019-12-16 20:10:45 +00:00
|
|
|
func endpointToResource(e influxdb.NotificationEndpoint, name string) Resource {
|
|
|
|
if name == "" {
|
|
|
|
name = e.GetName()
|
|
|
|
}
|
|
|
|
r := Resource{
|
|
|
|
fieldName: name,
|
|
|
|
}
|
|
|
|
assignNonZeroStrings(r, map[string]string{
|
|
|
|
fieldDescription: e.GetDescription(),
|
|
|
|
fieldStatus: string(e.GetStatus()),
|
|
|
|
})
|
|
|
|
|
|
|
|
switch actual := e.(type) {
|
|
|
|
case *endpoint.HTTP:
|
|
|
|
r[fieldKind] = KindNotificationEndpointHTTP.title()
|
|
|
|
r[fieldNotificationEndpointHTTPMethod] = actual.Method
|
|
|
|
r[fieldNotificationEndpointURL] = actual.URL
|
|
|
|
r[fieldType] = actual.AuthMethod
|
|
|
|
assignNonZeroSecrets(r, map[string]influxdb.SecretField{
|
|
|
|
fieldNotificationEndpointPassword: actual.Password,
|
|
|
|
fieldNotificationEndpointToken: actual.Token,
|
|
|
|
fieldNotificationEndpointUsername: actual.Username,
|
|
|
|
})
|
|
|
|
case *endpoint.PagerDuty:
|
|
|
|
r[fieldKind] = KindNotificationEndpointPagerDuty.title()
|
|
|
|
r[fieldNotificationEndpointURL] = actual.ClientURL
|
|
|
|
assignNonZeroSecrets(r, map[string]influxdb.SecretField{
|
|
|
|
fieldNotificationEndpointRoutingKey: actual.RoutingKey,
|
|
|
|
})
|
|
|
|
case *endpoint.Slack:
|
|
|
|
r[fieldKind] = KindNotificationEndpointSlack.title()
|
|
|
|
r[fieldNotificationEndpointURL] = actual.URL
|
|
|
|
assignNonZeroSecrets(r, map[string]influxdb.SecretField{
|
|
|
|
fieldNotificationEndpointToken: actual.Token,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2019-12-20 20:51:27 +00:00
|
|
|
func ruleToResource(iRule influxdb.NotificationRule, endpointName, name string) Resource {
|
|
|
|
if name == "" {
|
|
|
|
name = iRule.GetName()
|
|
|
|
}
|
|
|
|
r := Resource{
|
|
|
|
fieldKind: KindNotificationRule.title(),
|
|
|
|
fieldName: name,
|
|
|
|
fieldNotificationRuleEndpointName: endpointName,
|
|
|
|
}
|
|
|
|
assignNonZeroStrings(r, map[string]string{
|
|
|
|
fieldDescription: iRule.GetDescription(),
|
|
|
|
})
|
|
|
|
|
|
|
|
assignBase := func(base rule.Base) {
|
|
|
|
assignNonZeroFluxDurs(r, map[string]*notification.Duration{
|
|
|
|
fieldEvery: base.Every,
|
|
|
|
fieldOffset: base.Offset,
|
|
|
|
})
|
|
|
|
|
|
|
|
var tagRes []Resource
|
|
|
|
for _, tRule := range base.TagRules {
|
|
|
|
tagRes = append(tagRes, Resource{
|
|
|
|
fieldKey: tRule.Key,
|
|
|
|
fieldValue: tRule.Value,
|
|
|
|
fieldOperator: tRule.Operator.String(),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
if len(tagRes) > 0 {
|
|
|
|
r[fieldNotificationRuleTagRules] = tagRes
|
|
|
|
}
|
|
|
|
|
|
|
|
var statusRuleRes []Resource
|
|
|
|
for _, sRule := range base.StatusRules {
|
|
|
|
sRes := Resource{
|
|
|
|
fieldNotificationRuleCurrentLevel: sRule.CurrentLevel.String(),
|
|
|
|
}
|
|
|
|
if sRule.PreviousLevel != nil {
|
|
|
|
sRes[fieldNotificationRulePreviousLevel] = sRule.PreviousLevel.String()
|
|
|
|
}
|
|
|
|
statusRuleRes = append(statusRuleRes, sRes)
|
|
|
|
}
|
|
|
|
if len(statusRuleRes) > 0 {
|
|
|
|
r[fieldNotificationRuleStatusRules] = statusRuleRes
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
switch t := iRule.(type) {
|
|
|
|
case *rule.HTTP:
|
|
|
|
assignBase(t.Base)
|
|
|
|
case *rule.PagerDuty:
|
|
|
|
assignBase(t.Base)
|
|
|
|
r[fieldNotificationRuleMessageTemplate] = t.MessageTemplate
|
|
|
|
case *rule.Slack:
|
|
|
|
assignBase(t.Base)
|
|
|
|
r[fieldNotificationRuleMessageTemplate] = t.MessageTemplate
|
|
|
|
assignNonZeroStrings(r, map[string]string{fieldNotificationRuleChannel: t.Channel})
|
|
|
|
}
|
|
|
|
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2019-12-23 22:31:56 +00:00
|
|
|
// regex used to rip out the hard coded task option stuffs
|
2019-12-27 22:41:00 +00:00
|
|
|
var taskFluxRegex = regexp.MustCompile(`option task = {(.|\n)*?}`)
|
2019-12-23 22:31:56 +00:00
|
|
|
|
|
|
|
func taskToResource(t influxdb.Task, name string) Resource {
|
|
|
|
if name == "" {
|
|
|
|
name = t.Name
|
|
|
|
}
|
|
|
|
|
2019-12-27 22:41:00 +00:00
|
|
|
query := strings.TrimSpace(taskFluxRegex.ReplaceAllString(t.Flux, ""))
|
2019-12-23 22:31:56 +00:00
|
|
|
|
|
|
|
r := Resource{
|
|
|
|
fieldKind: KindTask.title(),
|
|
|
|
fieldName: name,
|
|
|
|
fieldQuery: query,
|
|
|
|
}
|
|
|
|
assignNonZeroStrings(r, map[string]string{
|
|
|
|
fieldTaskCron: t.Cron,
|
|
|
|
fieldDescription: t.Description,
|
|
|
|
fieldEvery: t.Every,
|
|
|
|
fieldOffset: durToStr(t.Offset),
|
|
|
|
})
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2019-12-05 00:17:35 +00:00
|
|
|
func telegrafToResource(t influxdb.TelegrafConfig, name string) Resource {
|
|
|
|
if name == "" {
|
|
|
|
name = t.Name
|
2019-11-08 19:33:41 +00:00
|
|
|
}
|
2019-12-05 00:17:35 +00:00
|
|
|
r := Resource{
|
|
|
|
fieldKind: KindTelegraf.title(),
|
|
|
|
fieldName: name,
|
2019-12-20 21:20:13 +00:00
|
|
|
fieldTelegrafConfig: t.Config,
|
2019-11-21 00:38:12 +00:00
|
|
|
}
|
2019-12-05 00:17:35 +00:00
|
|
|
assignNonZeroStrings(r, map[string]string{
|
|
|
|
fieldDescription: t.Description,
|
|
|
|
})
|
2019-11-21 00:38:12 +00:00
|
|
|
return r
|
2019-11-08 19:33:41 +00:00
|
|
|
}
|
|
|
|
|
2020-01-06 17:05:25 +00:00
|
|
|
// VariableToResource converts an influxdb.Variable to a pkger.Resource.
|
|
|
|
func VariableToResource(v influxdb.Variable, name string) Resource {
|
2019-11-08 19:33:41 +00:00
|
|
|
if name == "" {
|
|
|
|
name = v.Name
|
|
|
|
}
|
|
|
|
|
|
|
|
r := Resource{
|
2019-11-21 00:38:12 +00:00
|
|
|
fieldKind: KindVariable.title(),
|
|
|
|
fieldName: name,
|
2019-11-08 19:33:41 +00:00
|
|
|
}
|
2019-12-05 00:17:35 +00:00
|
|
|
assignNonZeroStrings(r, map[string]string{fieldDescription: v.Description})
|
2019-11-21 00:38:12 +00:00
|
|
|
|
2019-11-08 19:33:41 +00:00
|
|
|
args := v.Arguments
|
|
|
|
if args == nil {
|
|
|
|
return r
|
|
|
|
}
|
|
|
|
r[fieldType] = args.Type
|
|
|
|
|
|
|
|
switch args.Type {
|
|
|
|
case fieldArgTypeConstant:
|
|
|
|
vals, ok := args.Values.(influxdb.VariableConstantValues)
|
|
|
|
if ok {
|
|
|
|
r[fieldValues] = []string(vals)
|
|
|
|
}
|
|
|
|
case fieldArgTypeMap:
|
|
|
|
vals, ok := args.Values.(influxdb.VariableMapValues)
|
|
|
|
if ok {
|
|
|
|
r[fieldValues] = map[string]string(vals)
|
|
|
|
}
|
|
|
|
case fieldArgTypeQuery:
|
|
|
|
vals, ok := args.Values.(influxdb.VariableQueryValues)
|
|
|
|
if ok {
|
2019-11-22 18:41:08 +00:00
|
|
|
r[fieldLanguage] = vals.Language
|
2019-11-08 19:33:41 +00:00
|
|
|
r[fieldQuery] = vals.Query
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return r
|
|
|
|
}
|
2019-11-15 01:05:21 +00:00
|
|
|
|
2019-12-20 20:51:27 +00:00
|
|
|
func assignNonZeroFluxDurs(r Resource, m map[string]*notification.Duration) {
|
|
|
|
for field, dur := range m {
|
|
|
|
if dur == nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if dur.TimeDuration() == 0 {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
r[field] = dur.TimeDuration().String()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-05 00:17:35 +00:00
|
|
|
func assignNonZeroBools(r Resource, m map[string]bool) {
|
|
|
|
for k, v := range m {
|
|
|
|
if v {
|
|
|
|
r[k] = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func assignNonZeroInts(r Resource, m map[string]int) {
|
|
|
|
for k, v := range m {
|
|
|
|
if v != 0 {
|
|
|
|
r[k] = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func assignNonZeroStrings(r Resource, m map[string]string) {
|
|
|
|
for k, v := range m {
|
|
|
|
if v != "" {
|
|
|
|
r[k] = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-16 20:10:45 +00:00
|
|
|
func assignNonZeroSecrets(r Resource, m map[string]influxdb.SecretField) {
|
|
|
|
for field, secret := range m {
|
|
|
|
if secret.Key == "" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
r[field] = Resource{
|
|
|
|
fieldReferencesSecret: Resource{
|
|
|
|
fieldKey: secret.Key,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-15 01:05:21 +00:00
|
|
|
func stringsToColors(clrs []string) colors {
|
|
|
|
newColors := make(colors, 0)
|
|
|
|
for _, x := range clrs {
|
|
|
|
newColors = append(newColors, &color{Hex: x})
|
|
|
|
}
|
|
|
|
return newColors
|
|
|
|
}
|