src/annotations/graphite.ts (43 lines of code) (raw):
// Copyright (c) 2015 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
import errors = require('../errors');
import type { GrafanaGraphiteAnnotation } from '../grafana';
class Graphite {
state: GrafanaGraphiteAnnotation;
constructor(opts: Partial<GrafanaGraphiteAnnotation> = {}) {
if (!opts.name) {
throw errors.UnfulfilledRequirement.create(
'{component} missing requirement: {unfulfilledArg}',
{
component: 'grafana.annotations.Graphite',
unfulfilledArg: 'name',
}
);
}
if (!opts.target) {
throw errors.UnfulfilledRequirement.create(
'{component} missing requirement: {unfulfilledArg}',
{
component: 'grafana.annotations.Graphite',
unfulfilledArg: 'target',
}
);
}
const defaults: GrafanaGraphiteAnnotation = {
name: 'no name',
datasource: 'graphite',
showLine: true,
iconColor: 'rgb(255, 234, 0)',
lineColor: 'rgba(165, 161, 70, 0.59)',
iconSize: 10,
enable: true,
target: '',
};
this.state = defaults;
// Overwrite defaults with custom values
Object.keys(opts).forEach((opt) => {
this.state[opt] = opts[opt];
});
}
generate() {
return this.state;
}
}
export = Graphite;