@aws-cdk/aws-cloudwatch
Version:
The CDK Construct Library for AWS::CloudWatch
310 lines • 35.5 kB
JavaScript
"use strict";
var _a, _b, _c, _d, _e;
Object.defineProperty(exports, "__esModule", { value: true });
exports.LegendPosition = exports.Color = exports.Shading = exports.CustomWidget = exports.SingleValueWidget = exports.GraphWidget = exports.GraphWidgetView = exports.AlarmWidget = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cdk = require("@aws-cdk/core");
const rendering_1 = require("./private/rendering");
const widget_1 = require("./widget");
/**
* Display the metric associated with an alarm, including the alarm line
*/
class AlarmWidget extends widget_1.ConcreteWidget {
constructor(props) {
super(props.width || 6, props.height || 6);
try {
jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_AlarmWidgetProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.constructor);
}
throw error;
}
this.props = props;
}
toJson() {
var _f;
return [{
type: 'metric',
width: this.width,
height: this.height,
x: this.x,
y: this.y,
properties: {
view: 'timeSeries',
title: this.props.title,
region: this.props.region || cdk.Aws.REGION,
annotations: {
alarms: [this.props.alarm.alarmArn],
},
yAxis: {
left: (_f = this.props.leftYAxis) !== null && _f !== void 0 ? _f : undefined,
},
},
}];
}
}
exports.AlarmWidget = AlarmWidget;
_a = JSII_RTTI_SYMBOL_1;
AlarmWidget[_a] = { fqn: "@aws-cdk/aws-cloudwatch.AlarmWidget", version: "1.157.0" };
/**
* Types of view
*/
var GraphWidgetView;
(function (GraphWidgetView) {
/**
* Display as a line graph.
*/
GraphWidgetView["TIME_SERIES"] = "timeSeries";
/**
* Display as a bar graph.
*/
GraphWidgetView["BAR"] = "bar";
/**
* Display as a pie graph.
*/
GraphWidgetView["PIE"] = "pie";
})(GraphWidgetView = exports.GraphWidgetView || (exports.GraphWidgetView = {}));
/**
* A dashboard widget that displays metrics
*/
class GraphWidget extends widget_1.ConcreteWidget {
constructor(props) {
var _f, _g;
super(props.width || 6, props.height || 6);
try {
jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_GraphWidgetProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.constructor);
}
throw error;
}
this.props = props;
this.leftMetrics = (_f = props.left) !== null && _f !== void 0 ? _f : [];
this.rightMetrics = (_g = props.right) !== null && _g !== void 0 ? _g : [];
this.copyMetricWarnings(...this.leftMetrics, ...this.rightMetrics);
}
/**
* Add another metric to the left Y axis of the GraphWidget
*
* @param metric the metric to add
*/
addLeftMetric(metric) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_IMetric(metric);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addLeftMetric);
}
throw error;
}
this.leftMetrics.push(metric);
this.copyMetricWarnings(metric);
}
/**
* Add another metric to the right Y axis of the GraphWidget
*
* @param metric the metric to add
*/
addRightMetric(metric) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_IMetric(metric);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.addRightMetric);
}
throw error;
}
this.rightMetrics.push(metric);
this.copyMetricWarnings(metric);
}
toJson() {
var _f, _g, _h, _j;
const horizontalAnnotations = [
...(this.props.leftAnnotations || []).map(mapAnnotation('left')),
...(this.props.rightAnnotations || []).map(mapAnnotation('right')),
];
const metrics = rendering_1.allMetricsGraphJson(this.leftMetrics, this.rightMetrics);
return [{
type: 'metric',
width: this.width,
height: this.height,
x: this.x,
y: this.y,
properties: {
view: (_f = this.props.view) !== null && _f !== void 0 ? _f : GraphWidgetView.TIME_SERIES,
title: this.props.title,
region: this.props.region || cdk.Aws.REGION,
stacked: this.props.stacked,
metrics: metrics.length > 0 ? metrics : undefined,
annotations: horizontalAnnotations.length > 0 ? { horizontal: horizontalAnnotations } : undefined,
yAxis: {
left: (_g = this.props.leftYAxis) !== null && _g !== void 0 ? _g : undefined,
right: (_h = this.props.rightYAxis) !== null && _h !== void 0 ? _h : undefined,
},
legend: this.props.legendPosition !== undefined ? { position: this.props.legendPosition } : undefined,
liveData: this.props.liveData,
setPeriodToTimeRange: this.props.setPeriodToTimeRange,
period: (_j = this.props.period) === null || _j === void 0 ? void 0 : _j.toSeconds(),
stat: this.props.statistic,
},
}];
}
}
exports.GraphWidget = GraphWidget;
_b = JSII_RTTI_SYMBOL_1;
GraphWidget[_b] = { fqn: "@aws-cdk/aws-cloudwatch.GraphWidget", version: "1.157.0" };
/**
* A dashboard widget that displays the most recent value for every metric
*/
class SingleValueWidget extends widget_1.ConcreteWidget {
constructor(props) {
super(props.width || 6, props.height || 3);
try {
jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_SingleValueWidgetProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.constructor);
}
throw error;
}
this.props = props;
this.copyMetricWarnings(...props.metrics);
}
toJson() {
return [{
type: 'metric',
width: this.width,
height: this.height,
x: this.x,
y: this.y,
properties: {
view: 'singleValue',
title: this.props.title,
region: this.props.region || cdk.Aws.REGION,
metrics: rendering_1.allMetricsGraphJson(this.props.metrics, []),
setPeriodToTimeRange: this.props.setPeriodToTimeRange,
singleValueFullPrecision: this.props.fullPrecision,
},
}];
}
}
exports.SingleValueWidget = SingleValueWidget;
_c = JSII_RTTI_SYMBOL_1;
SingleValueWidget[_c] = { fqn: "@aws-cdk/aws-cloudwatch.SingleValueWidget", version: "1.157.0" };
/**
* A CustomWidget shows the result of a AWS lambda function
*/
class CustomWidget extends widget_1.ConcreteWidget {
constructor(props) {
var _f, _g;
super((_f = props.width) !== null && _f !== void 0 ? _f : 6, (_g = props.height) !== null && _g !== void 0 ? _g : 6);
try {
jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_CustomWidgetProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.constructor);
}
throw error;
}
this.props = props;
}
toJson() {
var _f, _g, _h;
return [{
type: 'custom',
width: this.width,
height: this.height,
x: this.x,
y: this.y,
properties: {
endpoint: this.props.functionArn,
params: this.props.params,
title: this.props.title,
updateOn: {
refresh: (_f = this.props.updateOnRefresh) !== null && _f !== void 0 ? _f : true,
resize: (_g = this.props.updateOnResize) !== null && _g !== void 0 ? _g : true,
timeRange: (_h = this.props.updateOnTimeRangeChange) !== null && _h !== void 0 ? _h : true,
},
},
}];
}
}
exports.CustomWidget = CustomWidget;
_d = JSII_RTTI_SYMBOL_1;
CustomWidget[_d] = { fqn: "@aws-cdk/aws-cloudwatch.CustomWidget", version: "1.157.0" };
/**
* Fill shading options that will be used with an annotation
*/
var Shading;
(function (Shading) {
/**
* Don't add shading
*/
Shading["NONE"] = "none";
/**
* Add shading above the annotation
*/
Shading["ABOVE"] = "above";
/**
* Add shading below the annotation
*/
Shading["BELOW"] = "below";
})(Shading = exports.Shading || (exports.Shading = {}));
/**
* A set of standard colours that can be used in annotations in a GraphWidget.
*/
class Color {
constructor() { }
}
exports.Color = Color;
_e = JSII_RTTI_SYMBOL_1;
Color[_e] = { fqn: "@aws-cdk/aws-cloudwatch.Color", version: "1.157.0" };
/** blue - hex #1f77b4 */
Color.BLUE = '#1f77b4';
/** brown - hex #8c564b */
Color.BROWN = '#8c564b';
/** green - hex #2ca02c */
Color.GREEN = '#2ca02c';
/** grey - hex #7f7f7f */
Color.GREY = '#7f7f7f';
/** orange - hex #ff7f0e */
Color.ORANGE = '#ff7f0e';
/** pink - hex #e377c2 */
Color.PINK = '#e377c2';
/** purple - hex #9467bd */
Color.PURPLE = '#9467bd';
/** red - hex #d62728 */
Color.RED = '#d62728';
/**
* The position of the legend on a GraphWidget.
*/
var LegendPosition;
(function (LegendPosition) {
/**
* Legend appears below the graph (default).
*/
LegendPosition["BOTTOM"] = "bottom";
/**
* Add shading above the annotation
*/
LegendPosition["RIGHT"] = "right";
/**
* Add shading below the annotation
*/
LegendPosition["HIDDEN"] = "hidden";
})(LegendPosition = exports.LegendPosition || (exports.LegendPosition = {}));
function mapAnnotation(yAxis) {
return (a) => {
return { ...a, yAxis };
};
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.js","sourceRoot":"","sources":["graph.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { IAlarm } from './alarm-base';\nimport { IMetric } from './metric-types';\nimport { allMetricsGraphJson } from './private/rendering';\nimport { ConcreteWidget } from './widget';\n\n/**\n * Basic properties for widgets that display metrics\n */\nexport interface MetricWidgetProps {\n  /**\n   * Title for the graph\n   *\n   * @default - None\n   */\n  readonly title?: string;\n\n  /**\n   * The region the metrics of this graph should be taken from\n   *\n   * @default - Current region\n   */\n  readonly region?: string;\n\n  /**\n   * Width of the widget, in a grid of 24 units wide\n   *\n   * @default 6\n   */\n  readonly width?: number;\n\n  /**\n   * Height of the widget\n   *\n   * @default - 6 for Alarm and Graph widgets.\n   *   3 for single value widgets where most recent value of a metric is displayed.\n   */\n  readonly height?: number;\n}\n\n/**\n * Properties for a Y-Axis\n */\nexport interface YAxisProps {\n  /**\n   * The min value\n   *\n   * @default 0\n   */\n  readonly min?: number;\n\n  /**\n   * The max value\n   *\n   * @default - No maximum value\n   */\n  readonly max?: number;\n\n  /**\n   * The label\n   *\n   * @default - No label\n   */\n  readonly label?: string;\n\n  /**\n   * Whether to show units\n   *\n   * @default true\n   */\n  readonly showUnits?: boolean;\n}\n\n/**\n * Properties for an AlarmWidget\n */\nexport interface AlarmWidgetProps extends MetricWidgetProps {\n  /**\n   * The alarm to show\n   */\n  readonly alarm: IAlarm;\n\n  /**\n   * Left Y axis\n   *\n   * @default - No minimum or maximum values for the left Y-axis\n   */\n  readonly leftYAxis?: YAxisProps;\n}\n\n/**\n * Display the metric associated with an alarm, including the alarm line\n */\nexport class AlarmWidget extends ConcreteWidget {\n  private readonly props: AlarmWidgetProps;\n\n  constructor(props: AlarmWidgetProps) {\n    super(props.width || 6, props.height || 6);\n    this.props = props;\n  }\n\n  public toJson(): any[] {\n    return [{\n      type: 'metric',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        view: 'timeSeries',\n        title: this.props.title,\n        region: this.props.region || cdk.Aws.REGION,\n        annotations: {\n          alarms: [this.props.alarm.alarmArn],\n        },\n        yAxis: {\n          left: this.props.leftYAxis ?? undefined,\n        },\n      },\n    }];\n  }\n}\n\n/**\n * Types of view\n */\nexport enum GraphWidgetView {\n  /**\n   * Display as a line graph.\n   */\n  TIME_SERIES = 'timeSeries',\n  /**\n   * Display as a bar graph.\n   */\n  BAR = 'bar',\n  /**\n   * Display as a pie graph.\n   */\n  PIE = 'pie',\n}\n\n/**\n * Properties for a GraphWidget\n */\nexport interface GraphWidgetProps extends MetricWidgetProps {\n  /**\n   * Metrics to display on left Y axis\n   *\n   * @default - No metrics\n   */\n  readonly left?: IMetric[];\n\n  /**\n   * Metrics to display on right Y axis\n   *\n   * @default - No metrics\n   */\n  readonly right?: IMetric[];\n\n  /**\n   * Annotations for the left Y axis\n   *\n   * @default - No annotations\n   */\n  readonly leftAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Annotations for the right Y axis\n   *\n   * @default - No annotations\n   */\n  readonly rightAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Whether the graph should be shown as stacked lines\n   *\n   * @default false\n   */\n  readonly stacked?: boolean;\n\n  /**\n   * Left Y axis\n   *\n   * @default - None\n   */\n  readonly leftYAxis?: YAxisProps;\n\n  /**\n   * Right Y axis\n   *\n   * @default - None\n   */\n  readonly rightYAxis?: YAxisProps;\n\n  /**\n   * Position of the legend\n   *\n   * @default - bottom\n   */\n  readonly legendPosition?: LegendPosition;\n\n  /**\n   * Whether the graph should show live data\n   *\n   * @default false\n   */\n  readonly liveData?: boolean;\n\n  /**\n   * Display this metric\n   *\n   * @default TimeSeries\n   */\n  readonly view?: GraphWidgetView;\n\n  /**\n   * Whether to show the value from the entire time range. Only applicable for Bar and Pie charts.\n   *\n   * If false, values will be from the most recent period of your chosen time range;\n   * if true, shows the value from the entire time range.\n   *\n   * @default false\n   */\n  readonly setPeriodToTimeRange?: boolean;\n\n  /**\n   * The default period for all metrics in this widget.\n   * The period is the length of time represented by one data point on the graph.\n   * This default can be overridden within each metric definition.\n   *\n   * @default cdk.Duration.seconds(300)\n   */\n  readonly period?: cdk.Duration;\n\n  /**\n   * The default statistic to be displayed for each metric.\n   * This default can be overridden within the definition of each individual metric\n   *\n   * @default - The statistic for each metric is used\n   */\n  readonly statistic?: string;\n}\n\n/**\n * A dashboard widget that displays metrics\n */\nexport class GraphWidget extends ConcreteWidget {\n\n  private readonly props: GraphWidgetProps;\n\n  private readonly leftMetrics: IMetric[];\n  private readonly rightMetrics: IMetric[];\n\n  constructor(props: GraphWidgetProps) {\n    super(props.width || 6, props.height || 6);\n    this.props = props;\n    this.leftMetrics = props.left ?? [];\n    this.rightMetrics = props.right ?? [];\n    this.copyMetricWarnings(...this.leftMetrics, ...this.rightMetrics);\n  }\n\n  /**\n   * Add another metric to the left Y axis of the GraphWidget\n   *\n   * @param metric the metric to add\n   */\n  public addLeftMetric(metric: IMetric) {\n    this.leftMetrics.push(metric);\n    this.copyMetricWarnings(metric);\n  }\n\n  /**\n   * Add another metric to the right Y axis of the GraphWidget\n   *\n   * @param metric the metric to add\n   */\n  public addRightMetric(metric: IMetric) {\n    this.rightMetrics.push(metric);\n    this.copyMetricWarnings(metric);\n  }\n\n  public toJson(): any[] {\n    const horizontalAnnotations = [\n      ...(this.props.leftAnnotations || []).map(mapAnnotation('left')),\n      ...(this.props.rightAnnotations || []).map(mapAnnotation('right')),\n    ];\n\n    const metrics = allMetricsGraphJson(this.leftMetrics, this.rightMetrics);\n    return [{\n      type: 'metric',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        view: this.props.view ?? GraphWidgetView.TIME_SERIES,\n        title: this.props.title,\n        region: this.props.region || cdk.Aws.REGION,\n        stacked: this.props.stacked,\n        metrics: metrics.length > 0 ? metrics : undefined,\n        annotations: horizontalAnnotations.length > 0 ? { horizontal: horizontalAnnotations } : undefined,\n        yAxis: {\n          left: this.props.leftYAxis ?? undefined,\n          right: this.props.rightYAxis ?? undefined,\n        },\n        legend: this.props.legendPosition !== undefined ? { position: this.props.legendPosition } : undefined,\n        liveData: this.props.liveData,\n        setPeriodToTimeRange: this.props.setPeriodToTimeRange,\n        period: this.props.period?.toSeconds(),\n        stat: this.props.statistic,\n      },\n    }];\n  }\n}\n\n/**\n * Properties for a SingleValueWidget\n */\nexport interface SingleValueWidgetProps extends MetricWidgetProps {\n  /**\n   * Metrics to display\n   */\n  readonly metrics: IMetric[];\n\n  /**\n   * Whether to show the value from the entire time range.\n   *\n   * @default false\n   */\n  readonly setPeriodToTimeRange?: boolean;\n\n  /**\n   * Whether to show as many digits as can fit, before rounding.\n   *\n   * @default false\n   */\n  readonly fullPrecision?: boolean;\n}\n\n/**\n * A dashboard widget that displays the most recent value for every metric\n */\nexport class SingleValueWidget extends ConcreteWidget {\n  private readonly props: SingleValueWidgetProps;\n\n  constructor(props: SingleValueWidgetProps) {\n    super(props.width || 6, props.height || 3);\n    this.props = props;\n    this.copyMetricWarnings(...props.metrics);\n  }\n\n  public toJson(): any[] {\n    return [{\n      type: 'metric',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        view: 'singleValue',\n        title: this.props.title,\n        region: this.props.region || cdk.Aws.REGION,\n        metrics: allMetricsGraphJson(this.props.metrics, []),\n        setPeriodToTimeRange: this.props.setPeriodToTimeRange,\n        singleValueFullPrecision: this.props.fullPrecision,\n      },\n    }];\n  }\n}\n\n/**\n * The properties for a CustomWidget\n */\nexport interface CustomWidgetProps {\n  /**\n   * The Arn of the AWS Lambda function that returns HTML or JSON that will be displayed in the widget\n   */\n  readonly functionArn: string;\n\n  /**\n   * Width of the widget, in a grid of 24 units wide\n   *\n   * @default 6\n   */\n  readonly width?: number;\n\n  /**\n   * Height of the widget\n   *\n   * @default - 6 for Alarm and Graph widgets.\n   *   3 for single value widgets where most recent value of a metric is displayed.\n   */\n  readonly height?: number;\n\n  /**\n   * The title of the widget\n   */\n  readonly title: string;\n\n  /**\n   * Update the widget on refresh\n   *\n   * @default true\n   */\n  readonly updateOnRefresh?: boolean;\n\n  /**\n   * Update the widget on resize\n   *\n   * @default true\n   */\n  readonly updateOnResize?: boolean;\n\n  /**\n   * Update the widget on time range change\n   *\n   * @default true\n   */\n  readonly updateOnTimeRangeChange?: boolean;\n\n  /**\n   * Parameters passed to the lambda function\n   *\n   * @default - no parameters are passed to the lambda function\n   */\n  readonly params?: any;\n}\n\n/**\n * A CustomWidget shows the result of a AWS lambda function\n */\nexport class CustomWidget extends ConcreteWidget {\n\n  private readonly props: CustomWidgetProps;\n\n  public constructor(props: CustomWidgetProps) {\n    super(props.width ?? 6, props.height ?? 6);\n    this.props = props;\n  }\n\n  public toJson(): any[] {\n    return [{\n      type: 'custom',\n      width: this.width,\n      height: this.height,\n      x: this.x,\n      y: this.y,\n      properties: {\n        endpoint: this.props.functionArn,\n        params: this.props.params,\n        title: this.props.title,\n        updateOn: {\n          refresh: this.props.updateOnRefresh ?? true,\n          resize: this.props.updateOnResize ?? true,\n          timeRange: this.props.updateOnTimeRangeChange ?? true,\n        },\n      },\n    }];\n  }\n}\n\n/**\n * Horizontal annotation to be added to a graph\n */\nexport interface HorizontalAnnotation {\n  /**\n   * The value of the annotation\n   */\n  readonly value: number;\n\n  /**\n   * Label for the annotation\n   *\n   * @default - No label\n   */\n  readonly label?: string;\n\n  /**\n   * The hex color code, prefixed with '#' (e.g. '#00ff00'), to be used for the annotation.\n   * The `Color` class has a set of standard colors that can be used here.\n   *\n   * @default - Automatic color\n   */\n  readonly color?: string;\n\n  /**\n   * Add shading above or below the annotation\n   *\n   * @default No shading\n   */\n  readonly fill?: Shading;\n\n  /**\n   * Whether the annotation is visible\n   *\n   * @default true\n   */\n  readonly visible?: boolean;\n}\n\n/**\n * Fill shading options that will be used with an annotation\n */\nexport enum Shading {\n  /**\n   * Don't add shading\n   */\n  NONE = 'none',\n\n  /**\n   * Add shading above the annotation\n   */\n  ABOVE = 'above',\n\n  /**\n   * Add shading below the annotation\n   */\n  BELOW = 'below'\n}\n\n/**\n * A set of standard colours that can be used in annotations in a GraphWidget.\n */\nexport class Color {\n  /** blue - hex #1f77b4 */\n  public static readonly BLUE = '#1f77b4';\n\n  /** brown - hex #8c564b */\n  public static readonly BROWN = '#8c564b';\n\n  /** green - hex #2ca02c */\n  public static readonly GREEN = '#2ca02c';\n\n  /** grey - hex #7f7f7f */\n  public static readonly GREY = '#7f7f7f';\n\n  /** orange - hex #ff7f0e */\n  public static readonly ORANGE = '#ff7f0e';\n\n  /** pink - hex #e377c2 */\n  public static readonly PINK = '#e377c2';\n\n  /** purple - hex #9467bd */\n  public static readonly PURPLE = '#9467bd';\n\n  /** red - hex #d62728 */\n  public static readonly RED = '#d62728';\n\n  private constructor() {}\n}\n\n/**\n * The position of the legend on a GraphWidget.\n */\nexport enum LegendPosition {\n  /**\n   * Legend appears below the graph (default).\n   */\n  BOTTOM = 'bottom',\n\n  /**\n   * Add shading above the annotation\n   */\n  RIGHT = 'right',\n\n  /**\n   * Add shading below the annotation\n   */\n  HIDDEN = 'hidden'\n}\n\nfunction mapAnnotation(yAxis: string): ((x: HorizontalAnnotation) => any) {\n  return (a: HorizontalAnnotation) => {\n    return { ...a, yAxis };\n  };\n}\n"]}