UNPKG

@aws-cdk/aws-cloudwatch

Version:

The CDK Construct Library for AWS::CloudWatch

305 lines 35 kB
"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, AlarmWidget); } throw error; } this.props = props; } toJson() { 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: this.props.leftYAxis ?? undefined, }, }, }]; } } exports.AlarmWidget = AlarmWidget; _a = JSII_RTTI_SYMBOL_1; AlarmWidget[_a] = { fqn: "@aws-cdk/aws-cloudwatch.AlarmWidget", version: "1.198.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) { 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, GraphWidget); } throw error; } this.props = props; this.leftMetrics = props.left ?? []; this.rightMetrics = props.right ?? []; 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() { 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: this.props.view ?? 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: this.props.leftYAxis ?? undefined, right: this.props.rightYAxis ?? undefined, }, legend: this.props.legendPosition !== undefined ? { position: this.props.legendPosition } : undefined, liveData: this.props.liveData, setPeriodToTimeRange: this.props.setPeriodToTimeRange, period: this.props.period?.toSeconds(), stat: this.props.statistic, }, }]; } } exports.GraphWidget = GraphWidget; _b = JSII_RTTI_SYMBOL_1; GraphWidget[_b] = { fqn: "@aws-cdk/aws-cloudwatch.GraphWidget", version: "1.198.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, SingleValueWidget); } 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.198.0" }; /** * A CustomWidget shows the result of a AWS lambda function */ class CustomWidget extends widget_1.ConcreteWidget { constructor(props) { super(props.width ?? 6, props.height ?? 6); try { jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_CustomWidgetProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, CustomWidget); } throw error; } this.props = props; } toJson() { 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: this.props.updateOnRefresh ?? true, resize: this.props.updateOnResize ?? true, timeRange: this.props.updateOnTimeRangeChange ?? true, }, }, }]; } } exports.CustomWidget = CustomWidget; _d = JSII_RTTI_SYMBOL_1; CustomWidget[_d] = { fqn: "@aws-cdk/aws-cloudwatch.CustomWidget", version: "1.198.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.198.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"]}