Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-cloudwatch

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-cloudwatch - npm Package Compare versions

Comparing version 0.28.0 to 0.29.0

4

lib/alarm.d.ts

@@ -1,2 +0,2 @@

import { Construct } from '@aws-cdk/cdk';
import { Construct, Resource } from '@aws-cdk/cdk';
import { HorizontalAnnotation } from './graph';

@@ -49,3 +49,3 @@ import { Dimension, Metric, MetricAlarmProps, Statistic, Unit } from './metric';

*/
export declare class Alarm extends Construct {
export declare class Alarm extends Resource {
/**

@@ -52,0 +52,0 @@ * ARN of this alarm

@@ -47,13 +47,25 @@ "use strict";

*/
class Alarm extends cdk_1.Construct {
class Alarm extends cdk_1.Resource {
constructor(scope, id, props) {
super(scope, id);
const comparisonOperator = props.comparisonOperator || ComparisonOperator.GreaterThanOrEqualToThreshold;
const alarm = new cloudwatch_generated_1.CfnAlarm(this, 'Resource', Object.assign({
const alarm = new cloudwatch_generated_1.CfnAlarm(this, 'Resource', {
// Meta
alarmDescription: props.alarmDescription, alarmName: props.alarmName,
alarmDescription: props.alarmDescription,
alarmName: props.alarmName,
// Evaluation
comparisonOperator, threshold: props.threshold, datapointsToAlarm: props.datapointsToAlarm, evaluateLowSampleCountPercentile: props.evaluateLowSampleCountPercentile, evaluationPeriods: props.evaluationPeriods, treatMissingData: props.treatMissingData,
comparisonOperator,
threshold: props.threshold,
datapointsToAlarm: props.datapointsToAlarm,
evaluateLowSampleCountPercentile: props.evaluateLowSampleCountPercentile,
evaluationPeriods: props.evaluationPeriods,
treatMissingData: props.treatMissingData,
// Actions
actionsEnabled: props.actionsEnabled, alarmActions: new cdk_1.Token(() => this.alarmActionArns).toList(), insufficientDataActions: new cdk_1.Token(() => this.insufficientDataActionArns).toList(), okActions: new cdk_1.Token(() => this.okActionArns).toList() }, metricJson(props.metric)));
actionsEnabled: props.actionsEnabled,
alarmActions: new cdk_1.Token(() => this.alarmActionArns).toList(),
insufficientDataActions: new cdk_1.Token(() => this.insufficientDataActionArns).toList(),
okActions: new cdk_1.Token(() => this.okActionArns).toList(),
// Metric
...metricJson(props.metric)
});
this.alarmArn = alarm.alarmArn;

@@ -155,2 +167,2 @@ this.alarmName = alarm.alarmName;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarm.js","sourceRoot":"","sources":["alarm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, Token } from '@aws-cdk/cdk';\nimport { CfnAlarm } from './cloudwatch.generated';\nimport { HorizontalAnnotation } from './graph';\nimport { Dimension, Metric, MetricAlarmProps, Statistic, Unit } from './metric';\nimport { parseStatistic } from './util.statistic';\n\n/**\n * Properties for Alarms\n */\nexport interface AlarmProps extends MetricAlarmProps {\n  /**\n   * The metric to add the alarm on\n   *\n   * Metric objects can be obtained from most resources, or you can construct\n   * custom Metric objects by instantiating one.\n   */\n  readonly metric: Metric;\n}\n\n/**\n * Comparison operator for evaluating alarms\n */\nexport enum ComparisonOperator {\n  GreaterThanOrEqualToThreshold = 'GreaterThanOrEqualToThreshold',\n  GreaterThanThreshold = 'GreaterThanThreshold',\n  LessThanThreshold = 'LessThanThreshold',\n  LessThanOrEqualToThreshold = 'LessThanOrEqualToThreshold',\n}\n\nconst OPERATOR_SYMBOLS: {[key: string]: string} = {\n  GreaterThanOrEqualToThreshold: '>=',\n  GreaterThanThreshold: '>',\n  LessThanThreshold: '<',\n  LessThanOrEqualToThreshold: '>=',\n};\n\n/**\n * Specify how missing data points are treated during alarm evaluation\n */\nexport enum TreatMissingData {\n  /**\n   * Missing data points are treated as breaching the threshold\n   */\n  Breaching = 'breaching',\n\n  /**\n   * Missing data points are treated as being within the threshold\n   */\n  NotBreaching = 'notBreaching',\n\n  /**\n   * The current alarm state is maintained\n   */\n  Ignore = 'ignore',\n\n  /**\n   * The alarm does not consider missing data points when evaluating whether to change state\n   */\n  Missing = 'missing'\n}\n\n/**\n * An alarm on a CloudWatch metric\n */\nexport class Alarm extends Construct {\n  /**\n   * ARN of this alarm\n   */\n  public readonly alarmArn: string;\n\n  /**\n   * Name of this alarm.\n   */\n  public readonly alarmName: string;\n\n  /**\n   * The metric object this alarm was based on\n   */\n  public readonly metric: Metric;\n\n  private alarmActionArns?: string[];\n  private insufficientDataActionArns?: string[];\n  private okActionArns?: string[];\n\n  /**\n   * This metric as an annotation\n   */\n  private readonly annotation: HorizontalAnnotation;\n\n  constructor(scope: Construct, id: string, props: AlarmProps) {\n    super(scope, id);\n\n    const comparisonOperator = props.comparisonOperator || ComparisonOperator.GreaterThanOrEqualToThreshold;\n\n    const alarm = new CfnAlarm(this, 'Resource', {\n      // Meta\n      alarmDescription: props.alarmDescription,\n      alarmName: props.alarmName,\n\n      // Evaluation\n      comparisonOperator,\n      threshold: props.threshold,\n      datapointsToAlarm: props.datapointsToAlarm,\n      evaluateLowSampleCountPercentile: props.evaluateLowSampleCountPercentile,\n      evaluationPeriods: props.evaluationPeriods,\n      treatMissingData: props.treatMissingData,\n\n      // Actions\n      actionsEnabled: props.actionsEnabled,\n      alarmActions: new Token(() => this.alarmActionArns).toList(),\n      insufficientDataActions: new Token(() => this.insufficientDataActionArns).toList(),\n      okActions: new Token(() => this.okActionArns).toList(),\n\n      // Metric\n      ...metricJson(props.metric)\n    });\n\n    this.alarmArn = alarm.alarmArn;\n    this.alarmName = alarm.alarmName;\n    this.metric = props.metric;\n    this.annotation = {\n      // tslint:disable-next-line:max-line-length\n      label: `${this.metric.label || this.metric.metricName} ${OPERATOR_SYMBOLS[comparisonOperator]} ${props.threshold} for ${props.evaluationPeriods} datapoints within ${describePeriod(props.evaluationPeriods * props.metric.periodSec)}`,\n      value: props.threshold,\n    };\n  }\n\n  /**\n   * Trigger this action if the alarm fires\n   *\n   * Typically the ARN of an SNS topic or ARN of an AutoScaling policy.\n   */\n  public onAlarm(...actions: IAlarmAction[]) {\n    if (this.alarmActionArns === undefined) {\n      this.alarmActionArns = [];\n    }\n\n    this.alarmActionArns.push(...actions.map(a => a.alarmActionArn));\n  }\n\n  /**\n   * Trigger this action if there is insufficient data to evaluate the alarm\n   *\n   * Typically the ARN of an SNS topic or ARN of an AutoScaling policy.\n   */\n  public onInsufficientData(...actions: IAlarmAction[]) {\n    if (this.insufficientDataActionArns === undefined) {\n      this.insufficientDataActionArns = [];\n    }\n\n    this.insufficientDataActionArns.push(...actions.map(a => a.alarmActionArn));\n  }\n\n  /**\n   * Trigger this action if the alarm returns from breaching state into ok state\n   *\n   * Typically the ARN of an SNS topic or ARN of an AutoScaling policy.\n   */\n  public onOk(...actions: IAlarmAction[]) {\n    if (this.okActionArns === undefined) {\n      this.okActionArns = [];\n    }\n\n    this.okActionArns.push(...actions.map(a => a.alarmActionArn));\n  }\n\n  /**\n   * Turn this alarm into a horizontal annotation\n   *\n   * This is useful if you want to represent an Alarm in a non-AlarmWidget.\n   * An `AlarmWidget` can directly show an alarm, but it can only show a\n   * single alarm and no other metrics. Instead, you can convert the alarm to\n   * a HorizontalAnnotation and add it as an annotation to another graph.\n   *\n   * This might be useful if:\n   *\n   * - You want to show multiple alarms inside a single graph, for example if\n   *   you have both a \"small margin/long period\" alarm as well as a\n   *   \"large margin/short period\" alarm.\n   *\n   * - You want to show an Alarm line in a graph with multiple metrics in it.\n   */\n  public toAnnotation(): HorizontalAnnotation {\n    return this.annotation;\n  }\n}\n\n/**\n * Return a human readable string for this period\n *\n * We know the seconds are always one of a handful of allowed values.\n */\nfunction describePeriod(seconds: number) {\n  if (seconds === 60) { return '1 minute'; }\n  if (seconds === 1) { return '1 second'; }\n  if (seconds > 60) { return (seconds / 60) + ' minutes'; }\n  return seconds + ' seconds';\n}\n\n/**\n * Interface for objects that can be the targets of CloudWatch alarm actions\n */\nexport interface IAlarmAction {\n  /**\n   * Return the ARN that should be used for a CloudWatch Alarm action\n   */\n  readonly alarmActionArn: string;\n}\n\n/**\n * Return the JSON structure which represents the given metric in an alarm.\n */\nfunction metricJson(metric: Metric): AlarmMetricJson {\n  const stat = parseStatistic(metric.statistic);\n\n  const dims = metric.dimensionsAsList();\n\n  return {\n    dimensions: dims.length > 0 ? dims : undefined,\n    namespace: metric.namespace,\n    metricName: metric.metricName,\n    period: metric.periodSec,\n    statistic: stat.type === 'simple' ? stat.statistic : undefined,\n    extendedStatistic: stat.type === 'percentile' ? 'p' + stat.percentile : undefined,\n    unit: metric.unit\n  };\n}\n\n/**\n * Properties used to construct the Metric identifying part of an Alarm\n */\nexport interface AlarmMetricJson {\n  /**\n   * The dimensions to apply to the alarm\n   */\n  readonly dimensions?: Dimension[];\n\n  /**\n   * Namespace of the metric\n   */\n  readonly namespace: string;\n\n  /**\n   * Name of the metric\n   */\n  readonly metricName: string;\n\n  /**\n   * How many seconds to aggregate over\n   */\n  readonly period: number;\n\n  /**\n   * Simple aggregation function to use\n   */\n  readonly statistic?: Statistic;\n\n  /**\n   * Percentile aggregation function to use\n   */\n  readonly extendedStatistic?: string;\n\n  /**\n   * The unit of the alarm\n   */\n  readonly unit?: Unit;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarm.js","sourceRoot":"","sources":["alarm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct, Resource, Token } from '@aws-cdk/cdk';\nimport { CfnAlarm } from './cloudwatch.generated';\nimport { HorizontalAnnotation } from './graph';\nimport { Dimension, Metric, MetricAlarmProps, Statistic, Unit } from './metric';\nimport { parseStatistic } from './util.statistic';\n\n/**\n * Properties for Alarms\n */\nexport interface AlarmProps extends MetricAlarmProps {\n  /**\n   * The metric to add the alarm on\n   *\n   * Metric objects can be obtained from most resources, or you can construct\n   * custom Metric objects by instantiating one.\n   */\n  readonly metric: Metric;\n}\n\n/**\n * Comparison operator for evaluating alarms\n */\nexport enum ComparisonOperator {\n  GreaterThanOrEqualToThreshold = 'GreaterThanOrEqualToThreshold',\n  GreaterThanThreshold = 'GreaterThanThreshold',\n  LessThanThreshold = 'LessThanThreshold',\n  LessThanOrEqualToThreshold = 'LessThanOrEqualToThreshold',\n}\n\nconst OPERATOR_SYMBOLS: {[key: string]: string} = {\n  GreaterThanOrEqualToThreshold: '>=',\n  GreaterThanThreshold: '>',\n  LessThanThreshold: '<',\n  LessThanOrEqualToThreshold: '>=',\n};\n\n/**\n * Specify how missing data points are treated during alarm evaluation\n */\nexport enum TreatMissingData {\n  /**\n   * Missing data points are treated as breaching the threshold\n   */\n  Breaching = 'breaching',\n\n  /**\n   * Missing data points are treated as being within the threshold\n   */\n  NotBreaching = 'notBreaching',\n\n  /**\n   * The current alarm state is maintained\n   */\n  Ignore = 'ignore',\n\n  /**\n   * The alarm does not consider missing data points when evaluating whether to change state\n   */\n  Missing = 'missing'\n}\n\n/**\n * An alarm on a CloudWatch metric\n */\nexport class Alarm extends Resource {\n  /**\n   * ARN of this alarm\n   */\n  public readonly alarmArn: string;\n\n  /**\n   * Name of this alarm.\n   */\n  public readonly alarmName: string;\n\n  /**\n   * The metric object this alarm was based on\n   */\n  public readonly metric: Metric;\n\n  private alarmActionArns?: string[];\n  private insufficientDataActionArns?: string[];\n  private okActionArns?: string[];\n\n  /**\n   * This metric as an annotation\n   */\n  private readonly annotation: HorizontalAnnotation;\n\n  constructor(scope: Construct, id: string, props: AlarmProps) {\n    super(scope, id);\n\n    const comparisonOperator = props.comparisonOperator || ComparisonOperator.GreaterThanOrEqualToThreshold;\n\n    const alarm = new CfnAlarm(this, 'Resource', {\n      // Meta\n      alarmDescription: props.alarmDescription,\n      alarmName: props.alarmName,\n\n      // Evaluation\n      comparisonOperator,\n      threshold: props.threshold,\n      datapointsToAlarm: props.datapointsToAlarm,\n      evaluateLowSampleCountPercentile: props.evaluateLowSampleCountPercentile,\n      evaluationPeriods: props.evaluationPeriods,\n      treatMissingData: props.treatMissingData,\n\n      // Actions\n      actionsEnabled: props.actionsEnabled,\n      alarmActions: new Token(() => this.alarmActionArns).toList(),\n      insufficientDataActions: new Token(() => this.insufficientDataActionArns).toList(),\n      okActions: new Token(() => this.okActionArns).toList(),\n\n      // Metric\n      ...metricJson(props.metric)\n    });\n\n    this.alarmArn = alarm.alarmArn;\n    this.alarmName = alarm.alarmName;\n    this.metric = props.metric;\n    this.annotation = {\n      // tslint:disable-next-line:max-line-length\n      label: `${this.metric.label || this.metric.metricName} ${OPERATOR_SYMBOLS[comparisonOperator]} ${props.threshold} for ${props.evaluationPeriods} datapoints within ${describePeriod(props.evaluationPeriods * props.metric.periodSec)}`,\n      value: props.threshold,\n    };\n  }\n\n  /**\n   * Trigger this action if the alarm fires\n   *\n   * Typically the ARN of an SNS topic or ARN of an AutoScaling policy.\n   */\n  public onAlarm(...actions: IAlarmAction[]) {\n    if (this.alarmActionArns === undefined) {\n      this.alarmActionArns = [];\n    }\n\n    this.alarmActionArns.push(...actions.map(a => a.alarmActionArn));\n  }\n\n  /**\n   * Trigger this action if there is insufficient data to evaluate the alarm\n   *\n   * Typically the ARN of an SNS topic or ARN of an AutoScaling policy.\n   */\n  public onInsufficientData(...actions: IAlarmAction[]) {\n    if (this.insufficientDataActionArns === undefined) {\n      this.insufficientDataActionArns = [];\n    }\n\n    this.insufficientDataActionArns.push(...actions.map(a => a.alarmActionArn));\n  }\n\n  /**\n   * Trigger this action if the alarm returns from breaching state into ok state\n   *\n   * Typically the ARN of an SNS topic or ARN of an AutoScaling policy.\n   */\n  public onOk(...actions: IAlarmAction[]) {\n    if (this.okActionArns === undefined) {\n      this.okActionArns = [];\n    }\n\n    this.okActionArns.push(...actions.map(a => a.alarmActionArn));\n  }\n\n  /**\n   * Turn this alarm into a horizontal annotation\n   *\n   * This is useful if you want to represent an Alarm in a non-AlarmWidget.\n   * An `AlarmWidget` can directly show an alarm, but it can only show a\n   * single alarm and no other metrics. Instead, you can convert the alarm to\n   * a HorizontalAnnotation and add it as an annotation to another graph.\n   *\n   * This might be useful if:\n   *\n   * - You want to show multiple alarms inside a single graph, for example if\n   *   you have both a \"small margin/long period\" alarm as well as a\n   *   \"large margin/short period\" alarm.\n   *\n   * - You want to show an Alarm line in a graph with multiple metrics in it.\n   */\n  public toAnnotation(): HorizontalAnnotation {\n    return this.annotation;\n  }\n}\n\n/**\n * Return a human readable string for this period\n *\n * We know the seconds are always one of a handful of allowed values.\n */\nfunction describePeriod(seconds: number) {\n  if (seconds === 60) { return '1 minute'; }\n  if (seconds === 1) { return '1 second'; }\n  if (seconds > 60) { return (seconds / 60) + ' minutes'; }\n  return seconds + ' seconds';\n}\n\n/**\n * Interface for objects that can be the targets of CloudWatch alarm actions\n */\nexport interface IAlarmAction {\n  /**\n   * Return the ARN that should be used for a CloudWatch Alarm action\n   */\n  readonly alarmActionArn: string;\n}\n\n/**\n * Return the JSON structure which represents the given metric in an alarm.\n */\nfunction metricJson(metric: Metric): AlarmMetricJson {\n  const stat = parseStatistic(metric.statistic);\n\n  const dims = metric.dimensionsAsList();\n\n  return {\n    dimensions: dims.length > 0 ? dims : undefined,\n    namespace: metric.namespace,\n    metricName: metric.metricName,\n    period: metric.periodSec,\n    statistic: stat.type === 'simple' ? stat.statistic : undefined,\n    extendedStatistic: stat.type === 'percentile' ? 'p' + stat.percentile : undefined,\n    unit: metric.unit\n  };\n}\n\n/**\n * Properties used to construct the Metric identifying part of an Alarm\n */\nexport interface AlarmMetricJson {\n  /**\n   * The dimensions to apply to the alarm\n   */\n  readonly dimensions?: Dimension[];\n\n  /**\n   * Namespace of the metric\n   */\n  readonly namespace: string;\n\n  /**\n   * Name of the metric\n   */\n  readonly metricName: string;\n\n  /**\n   * How many seconds to aggregate over\n   */\n  readonly period: number;\n\n  /**\n   * Simple aggregation function to use\n   */\n  readonly statistic?: Statistic;\n\n  /**\n   * Percentile aggregation function to use\n   */\n  readonly extendedStatistic?: string;\n\n  /**\n   * The unit of the alarm\n   */\n  readonly unit?: Unit;\n}\n"]}

@@ -1,3 +0,7 @@

import { Construct } from "@aws-cdk/cdk";
import { Construct, Resource } from "@aws-cdk/cdk";
import { IWidget } from "./widget";
export declare enum PeriodOverride {
Auto = "auto",
Inherit = "inherit"
}
export interface DashboardProps {

@@ -10,2 +14,29 @@ /**

readonly dashboardName?: string;
/**
* The start of the time range to use for each widget on the dashboard.
* You can specify start without specifying end to specify a relative time range that ends with the current time.
* In this case, the value of start must begin with -P, and you can use M, H, D, W and M as abbreviations for
* minutes, hours, days, weeks and months. For example, -PT8H shows the last 8 hours and -P3M shows the last three months.
* You can also use start along with an end field, to specify an absolute time range.
* When specifying an absolute time range, use the ISO 8601 format. For example, 2018-12-17T06:00:00.000Z.
*
* @default When the dashboard loads, the start time will be the default time range.
*/
readonly start?: string;
/**
* The end of the time range to use for each widget on the dashboard when the dashboard loads.
* If you specify a value for end, you must also specify a value for start.
* Specify an absolute time in the ISO 8601 format. For example, 2018-12-17T06:00:00.000Z.
*
* @default When the dashboard loads, the end date will be the current time.
*/
readonly end?: string;
/**
* Use this field to specify the period for the graphs when the dashboard loads.
* Specifying `Auto` causes the period of all graphs on the dashboard to automatically adapt to the time range of the dashboard.
* Specifying `Inherit` ensures that the period set for each graph is always obeyed.
*
* @default Auto
*/
readonly periodOverride?: PeriodOverride;
}

@@ -15,5 +46,4 @@ /**

*/
export declare class Dashboard extends Construct {
export declare class Dashboard extends Resource {
private readonly rows;
private readonly dashboard;
constructor(scope: Construct, id: string, props?: DashboardProps);

@@ -30,6 +60,2 @@ /**

add(...widgets: IWidget[]): void;
/**
* Generate a unique dashboard name in case the user didn't supply one
*/
private generateDashboardName;
}

@@ -6,20 +6,25 @@ "use strict";

const layout_1 = require("./layout");
var PeriodOverride;
(function (PeriodOverride) {
PeriodOverride["Auto"] = "auto";
PeriodOverride["Inherit"] = "inherit";
})(PeriodOverride = exports.PeriodOverride || (exports.PeriodOverride = {}));
/**
* A CloudWatch dashboard
*/
class Dashboard extends cdk_1.Construct {
class Dashboard extends cdk_1.Resource {
constructor(scope, id, props) {
super(scope, id);
this.rows = [];
// WORKAROUND -- Dashboard cannot be updated if the DashboardName is missing.
// This is a bug in CloudFormation, but we don't want CDK users to have a bad
// experience. We'll generate a name here if you did not supply one.
// See: https://github.com/awslabs/aws-cdk/issues/213
const dashboardName = (props && props.dashboardName) || new cdk_1.Token(() => this.generateDashboardName()).toString();
this.dashboard = new cloudwatch_generated_1.CfnDashboard(this, 'Resource', {
dashboardName,
new cloudwatch_generated_1.CfnDashboard(this, 'Resource', {
dashboardName: (props && props.dashboardName) || undefined,
dashboardBody: new cdk_1.Token(() => {
const column = new layout_1.Column(...this.rows);
column.position(0, 0);
return this.node.stringifyJson({ widgets: column.toJson() });
return this.node.stringifyJson({
start: props ? props.start : undefined,
end: props ? props.end : undefined,
periodOverride: props ? props.periodOverride : undefined,
widgets: column.toJson(),
});
}).toString()

@@ -44,11 +49,4 @@ });

}
/**
* Generate a unique dashboard name in case the user didn't supply one
*/
generateDashboardName() {
// Combination of stack name and LogicalID, which are guaranteed to be unique.
return this.node.stack.name + '-' + this.dashboard.logicalId;
}
}
exports.Dashboard = Dashboard;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGFzaGJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZGFzaGJvYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQWdEO0FBQ2hELGlFQUFzRDtBQUN0RCxxQ0FBdUM7QUFZdkM7O0dBRUc7QUFDSCxNQUFhLFNBQVUsU0FBUSxlQUFTO0lBSXRDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBc0I7UUFDOUQsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUpGLFNBQUksR0FBYyxFQUFFLENBQUM7UUFNcEMsNkVBQTZFO1FBQzdFLDZFQUE2RTtRQUM3RSxvRUFBb0U7UUFDcEUscURBQXFEO1FBQ3JELE1BQU0sYUFBYSxHQUFHLENBQUMsS0FBSyxJQUFJLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBRWpILElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxtQ0FBWSxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDbEQsYUFBYTtZQUNiLGFBQWEsRUFBRSxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUU7Z0JBQzVCLE1BQU0sTUFBTSxHQUFHLElBQUksZUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUN4QyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztnQkFDdEIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxFQUFFLE9BQU8sRUFBRSxNQUFNLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQy9ELENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRTtTQUNkLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRDs7Ozs7Ozs7T0FRRztJQUNJLEdBQUcsQ0FBQyxHQUFHLE9BQWtCO1FBQzlCLElBQUksT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDeEIsT0FBTztTQUNSO1FBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksWUFBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwQixDQUFDO0lBRUQ7O09BRUc7SUFDSyxxQkFBcUI7UUFDM0IsOEVBQThFO1FBQzlFLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQztJQUMvRCxDQUFDO0NBQ0Y7QUFoREQsOEJBZ0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0LCBUb2tlbiB9IGZyb20gXCJAYXdzLWNkay9jZGtcIjtcbmltcG9ydCB7IENmbkRhc2hib2FyZCB9IGZyb20gJy4vY2xvdWR3YXRjaC5nZW5lcmF0ZWQnO1xuaW1wb3J0IHsgQ29sdW1uLCBSb3cgfSBmcm9tIFwiLi9sYXlvdXRcIjtcbmltcG9ydCB7IElXaWRnZXQgfSBmcm9tIFwiLi93aWRnZXRcIjtcblxuZXhwb3J0IGludGVyZmFjZSBEYXNoYm9hcmRQcm9wcyB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBkYXNoYm9hcmRcbiAgICpcbiAgICogQGRlZmF1bHQgQXV0b21hdGljYWxseSBnZW5lcmF0ZWQgbmFtZVxuICAgKi9cbiAgcmVhZG9ubHkgZGFzaGJvYXJkTmFtZT86IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIENsb3VkV2F0Y2ggZGFzaGJvYXJkXG4gKi9cbmV4cG9ydCBjbGFzcyBEYXNoYm9hcmQgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwcml2YXRlIHJlYWRvbmx5IHJvd3M6IElXaWRnZXRbXSA9IFtdO1xuICBwcml2YXRlIHJlYWRvbmx5IGRhc2hib2FyZDogQ2ZuRGFzaGJvYXJkO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogRGFzaGJvYXJkUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgLy8gV09SS0FST1VORCAtLSBEYXNoYm9hcmQgY2Fubm90IGJlIHVwZGF0ZWQgaWYgdGhlIERhc2hib2FyZE5hbWUgaXMgbWlzc2luZy5cbiAgICAvLyBUaGlzIGlzIGEgYnVnIGluIENsb3VkRm9ybWF0aW9uLCBidXQgd2UgZG9uJ3Qgd2FudCBDREsgdXNlcnMgdG8gaGF2ZSBhIGJhZFxuICAgIC8vIGV4cGVyaWVuY2UuIFdlJ2xsIGdlbmVyYXRlIGEgbmFtZSBoZXJlIGlmIHlvdSBkaWQgbm90IHN1cHBseSBvbmUuXG4gICAgLy8gU2VlOiBodHRwczovL2dpdGh1Yi5jb20vYXdzbGFicy9hd3MtY2RrL2lzc3Vlcy8yMTNcbiAgICBjb25zdCBkYXNoYm9hcmROYW1lID0gKHByb3BzICYmIHByb3BzLmRhc2hib2FyZE5hbWUpIHx8IG5ldyBUb2tlbigoKSA9PiB0aGlzLmdlbmVyYXRlRGFzaGJvYXJkTmFtZSgpKS50b1N0cmluZygpO1xuXG4gICAgdGhpcy5kYXNoYm9hcmQgPSBuZXcgQ2ZuRGFzaGJvYXJkKHRoaXMsICdSZXNvdXJjZScsIHtcbiAgICAgIGRhc2hib2FyZE5hbWUsXG4gICAgICBkYXNoYm9hcmRCb2R5OiBuZXcgVG9rZW4oKCkgPT4ge1xuICAgICAgICBjb25zdCBjb2x1bW4gPSBuZXcgQ29sdW1uKC4uLnRoaXMucm93cyk7XG4gICAgICAgIGNvbHVtbi5wb3NpdGlvbigwLCAwKTtcbiAgICAgICAgcmV0dXJuIHRoaXMubm9kZS5zdHJpbmdpZnlKc29uKHsgd2lkZ2V0czogY29sdW1uLnRvSnNvbigpIH0pO1xuICAgICAgfSkudG9TdHJpbmcoKVxuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhIHdpZGdldCB0byB0aGUgZGFzaGJvYXJkLlxuICAgKlxuICAgKiBXaWRnZXRzIGdpdmVuIGluIG11bHRpcGxlIGNhbGxzIHRvIGFkZCgpIHdpbGwgYmUgbGFpZCBvdXQgc3RhY2tlZCBvblxuICAgKiB0b3Agb2YgZWFjaCBvdGhlci5cbiAgICpcbiAgICogTXVsdGlwbGUgd2lkZ2V0cyBhZGRlZCBpbiB0aGUgc2FtZSBjYWxsIHRvIGFkZCgpIHdpbGwgYmUgbGFpZCBvdXQgbmV4dFxuICAgKiB0byBlYWNoIG90aGVyLlxuICAgKi9cbiAgcHVibGljIGFkZCguLi53aWRnZXRzOiBJV2lkZ2V0W10pIHtcbiAgICBpZiAod2lkZ2V0cy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCB3ID0gd2lkZ2V0cy5sZW5ndGggPiAxID8gbmV3IFJvdyguLi53aWRnZXRzKSA6IHdpZGdldHNbMF07XG4gICAgdGhpcy5yb3dzLnB1c2godyk7XG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGUgYSB1bmlxdWUgZGFzaGJvYXJkIG5hbWUgaW4gY2FzZSB0aGUgdXNlciBkaWRuJ3Qgc3VwcGx5IG9uZVxuICAgKi9cbiAgcHJpdmF0ZSBnZW5lcmF0ZURhc2hib2FyZE5hbWUoKTogc3RyaW5nIHtcbiAgICAvLyBDb21iaW5hdGlvbiBvZiBzdGFjayBuYW1lIGFuZCBMb2dpY2FsSUQsIHdoaWNoIGFyZSBndWFyYW50ZWVkIHRvIGJlIHVuaXF1ZS5cbiAgICByZXR1cm4gdGhpcy5ub2RlLnN0YWNrLm5hbWUgKyAnLScgKyB0aGlzLmRhc2hib2FyZC5sb2dpY2FsSWQ7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGFzaGJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiZGFzaGJvYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsc0NBQTBEO0FBQzFELGlFQUFzRDtBQUN0RCxxQ0FBdUM7QUFHdkMsSUFBWSxjQUdYO0FBSEQsV0FBWSxjQUFjO0lBQ3hCLCtCQUFhLENBQUE7SUFDYixxQ0FBbUIsQ0FBQTtBQUNyQixDQUFDLEVBSFcsY0FBYyxHQUFkLHNCQUFjLEtBQWQsc0JBQWMsUUFHekI7QUF5Q0Q7O0dBRUc7QUFDSCxNQUFhLFNBQVUsU0FBUSxjQUFRO0lBR3JDLFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBc0I7UUFDOUQsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUhGLFNBQUksR0FBYyxFQUFFLENBQUM7UUFLcEMsSUFBSSxtQ0FBWSxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDakMsYUFBYSxFQUFFLENBQUMsS0FBSyxJQUFJLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSSxTQUFTO1lBQzFELGFBQWEsRUFBRSxJQUFJLFdBQUssQ0FBQyxHQUFHLEVBQUU7Z0JBQzVCLE1BQU0sTUFBTSxHQUFHLElBQUksZUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUN4QyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztnQkFDdEIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQztvQkFDN0IsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUztvQkFDdEMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsU0FBUztvQkFDbEMsY0FBYyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsU0FBUztvQkFDeEQsT0FBTyxFQUFFLE1BQU0sQ0FBQyxNQUFNLEVBQUU7aUJBQ3pCLENBQUMsQ0FBQztZQUNMLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRTtTQUNkLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRDs7Ozs7Ozs7T0FRRztJQUNJLEdBQUcsQ0FBQyxHQUFHLE9BQWtCO1FBQzlCLElBQUksT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDeEIsT0FBTztTQUNSO1FBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksWUFBRyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwQixDQUFDO0NBQ0Y7QUF0Q0QsOEJBc0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0LCBSZXNvdXJjZSwgVG9rZW4gfSBmcm9tIFwiQGF3cy1jZGsvY2RrXCI7XG5pbXBvcnQgeyBDZm5EYXNoYm9hcmQgfSBmcm9tICcuL2Nsb3Vkd2F0Y2guZ2VuZXJhdGVkJztcbmltcG9ydCB7IENvbHVtbiwgUm93IH0gZnJvbSBcIi4vbGF5b3V0XCI7XG5pbXBvcnQgeyBJV2lkZ2V0IH0gZnJvbSBcIi4vd2lkZ2V0XCI7XG5cbmV4cG9ydCBlbnVtIFBlcmlvZE92ZXJyaWRlIHtcbiAgQXV0byA9ICdhdXRvJyxcbiAgSW5oZXJpdCA9ICdpbmhlcml0Jyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEYXNoYm9hcmRQcm9wcyB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBkYXNoYm9hcmRcbiAgICpcbiAgICogQGRlZmF1bHQgQXV0b21hdGljYWxseSBnZW5lcmF0ZWQgbmFtZVxuICAgKi9cbiAgcmVhZG9ubHkgZGFzaGJvYXJkTmFtZT86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIHN0YXJ0IG9mIHRoZSB0aW1lIHJhbmdlIHRvIHVzZSBmb3IgZWFjaCB3aWRnZXQgb24gdGhlIGRhc2hib2FyZC5cbiAgICogWW91IGNhbiBzcGVjaWZ5IHN0YXJ0IHdpdGhvdXQgc3BlY2lmeWluZyBlbmQgdG8gc3BlY2lmeSBhIHJlbGF0aXZlIHRpbWUgcmFuZ2UgdGhhdCBlbmRzIHdpdGggdGhlIGN1cnJlbnQgdGltZS5cbiAgICogSW4gdGhpcyBjYXNlLCB0aGUgdmFsdWUgb2Ygc3RhcnQgbXVzdCBiZWdpbiB3aXRoIC1QLCBhbmQgeW91IGNhbiB1c2UgTSwgSCwgRCwgVyBhbmQgTSBhcyBhYmJyZXZpYXRpb25zIGZvclxuICAgKiBtaW51dGVzLCBob3VycywgZGF5cywgd2Vla3MgYW5kIG1vbnRocy4gRm9yIGV4YW1wbGUsIC1QVDhIIHNob3dzIHRoZSBsYXN0IDggaG91cnMgYW5kIC1QM00gc2hvd3MgdGhlIGxhc3QgdGhyZWUgbW9udGhzLlxuICAgKiBZb3UgY2FuIGFsc28gdXNlIHN0YXJ0IGFsb25nIHdpdGggYW4gZW5kIGZpZWxkLCB0byBzcGVjaWZ5IGFuIGFic29sdXRlIHRpbWUgcmFuZ2UuXG4gICAqIFdoZW4gc3BlY2lmeWluZyBhbiBhYnNvbHV0ZSB0aW1lIHJhbmdlLCB1c2UgdGhlIElTTyA4NjAxIGZvcm1hdC4gRm9yIGV4YW1wbGUsIDIwMTgtMTItMTdUMDY6MDA6MDAuMDAwWi5cbiAgICpcbiAgICogQGRlZmF1bHQgV2hlbiB0aGUgZGFzaGJvYXJkIGxvYWRzLCB0aGUgc3RhcnQgdGltZSB3aWxsIGJlIHRoZSBkZWZhdWx0IHRpbWUgcmFuZ2UuXG4gICAqL1xuICByZWFkb25seSBzdGFydD86IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIGVuZCBvZiB0aGUgdGltZSByYW5nZSB0byB1c2UgZm9yIGVhY2ggd2lkZ2V0IG9uIHRoZSBkYXNoYm9hcmQgd2hlbiB0aGUgZGFzaGJvYXJkIGxvYWRzLlxuICAgKiBJZiB5b3Ugc3BlY2lmeSBhIHZhbHVlIGZvciBlbmQsIHlvdSBtdXN0IGFsc28gc3BlY2lmeSBhIHZhbHVlIGZvciBzdGFydC5cbiAgICogU3BlY2lmeSBhbiBhYnNvbHV0ZSB0aW1lIGluIHRoZSBJU08gODYwMSBmb3JtYXQuIEZvciBleGFtcGxlLCAyMDE4LTEyLTE3VDA2OjAwOjAwLjAwMFouXG4gICAqXG4gICAqIEBkZWZhdWx0IFdoZW4gdGhlIGRhc2hib2FyZCBsb2FkcywgdGhlIGVuZCBkYXRlIHdpbGwgYmUgdGhlIGN1cnJlbnQgdGltZS5cbiAgICovXG4gIHJlYWRvbmx5IGVuZD86IHN0cmluZztcblxuICAvKipcbiAgICogVXNlIHRoaXMgZmllbGQgdG8gc3BlY2lmeSB0aGUgcGVyaW9kIGZvciB0aGUgZ3JhcGhzIHdoZW4gdGhlIGRhc2hib2FyZCBsb2Fkcy5cbiAgICogU3BlY2lmeWluZyBgQXV0b2AgY2F1c2VzIHRoZSBwZXJpb2Qgb2YgYWxsIGdyYXBocyBvbiB0aGUgZGFzaGJvYXJkIHRvIGF1dG9tYXRpY2FsbHkgYWRhcHQgdG8gdGhlIHRpbWUgcmFuZ2Ugb2YgdGhlIGRhc2hib2FyZC5cbiAgICogU3BlY2lmeWluZyBgSW5oZXJpdGAgZW5zdXJlcyB0aGF0IHRoZSBwZXJpb2Qgc2V0IGZvciBlYWNoIGdyYXBoIGlzIGFsd2F5cyBvYmV5ZWQuXG4gICAqXG4gICAqIEBkZWZhdWx0IEF1dG9cbiAgICovXG4gIHJlYWRvbmx5IHBlcmlvZE92ZXJyaWRlPzogUGVyaW9kT3ZlcnJpZGU7XG59XG5cbi8qKlxuICogQSBDbG91ZFdhdGNoIGRhc2hib2FyZFxuICovXG5leHBvcnQgY2xhc3MgRGFzaGJvYXJkIGV4dGVuZHMgUmVzb3VyY2Uge1xuICBwcml2YXRlIHJlYWRvbmx5IHJvd3M6IElXaWRnZXRbXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzPzogRGFzaGJvYXJkUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgbmV3IENmbkRhc2hib2FyZCh0aGlzLCAnUmVzb3VyY2UnLCB7XG4gICAgICBkYXNoYm9hcmROYW1lOiAocHJvcHMgJiYgcHJvcHMuZGFzaGJvYXJkTmFtZSkgfHwgdW5kZWZpbmVkLFxuICAgICAgZGFzaGJvYXJkQm9keTogbmV3IFRva2VuKCgpID0+IHtcbiAgICAgICAgY29uc3QgY29sdW1uID0gbmV3IENvbHVtbiguLi50aGlzLnJvd3MpO1xuICAgICAgICBjb2x1bW4ucG9zaXRpb24oMCwgMCk7XG4gICAgICAgIHJldHVybiB0aGlzLm5vZGUuc3RyaW5naWZ5SnNvbih7XG4gICAgICAgICAgc3RhcnQ6IHByb3BzID8gcHJvcHMuc3RhcnQgOiB1bmRlZmluZWQsXG4gICAgICAgICAgZW5kOiBwcm9wcyA/IHByb3BzLmVuZCA6IHVuZGVmaW5lZCxcbiAgICAgICAgICBwZXJpb2RPdmVycmlkZTogcHJvcHMgPyBwcm9wcy5wZXJpb2RPdmVycmlkZSA6IHVuZGVmaW5lZCxcbiAgICAgICAgICB3aWRnZXRzOiBjb2x1bW4udG9Kc29uKCksXG4gICAgICAgIH0pO1xuICAgICAgfSkudG9TdHJpbmcoKVxuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhIHdpZGdldCB0byB0aGUgZGFzaGJvYXJkLlxuICAgKlxuICAgKiBXaWRnZXRzIGdpdmVuIGluIG11bHRpcGxlIGNhbGxzIHRvIGFkZCgpIHdpbGwgYmUgbGFpZCBvdXQgc3RhY2tlZCBvblxuICAgKiB0b3Agb2YgZWFjaCBvdGhlci5cbiAgICpcbiAgICogTXVsdGlwbGUgd2lkZ2V0cyBhZGRlZCBpbiB0aGUgc2FtZSBjYWxsIHRvIGFkZCgpIHdpbGwgYmUgbGFpZCBvdXQgbmV4dFxuICAgKiB0byBlYWNoIG90aGVyLlxuICAgKi9cbiAgcHVibGljIGFkZCguLi53aWRnZXRzOiBJV2lkZ2V0W10pIHtcbiAgICBpZiAod2lkZ2V0cy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCB3ID0gd2lkZ2V0cy5sZW5ndGggPiAxID8gbmV3IFJvdyguLi53aWRnZXRzKSA6IHdpZGdldHNbMF07XG4gICAgdGhpcy5yb3dzLnB1c2godyk7XG4gIH1cbn1cbiJdfQ==

@@ -110,3 +110,3 @@ "use strict";

return (a) => {
return Object.assign({}, a, { yAxis });
return { ...a, yAxis };
};

@@ -140,2 +140,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.js","sourceRoot":"","sources":["graph.ts"],"names":[],"mappings":"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","sourcesContent":["import cdk = require('@aws-cdk/cdk');\nimport { Alarm } from \"./alarm\";\nimport { Metric } from \"./metric\";\nimport { parseStatistic } from './util.statistic';\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  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 Depends on the type of widget\n   */\n  readonly height?: number;\n}\n\n/**\n * Properties for an AlarmWidget\n */\nexport interface AlarmWidgetProps extends MetricWidgetProps {\n  /**\n   * The alarm to show\n   */\n  readonly alarm: Alarm;\n\n  /**\n   * Range of left Y axis\n   *\n   * @default 0..automatic\n   */\n  readonly leftAxisRange?: YAxisRange;\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.leftAxisRange !== undefined ? this.props.leftAxisRange : { min: 0 }\n        }\n      }\n    }];\n  }\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  readonly left?: Metric[];\n\n  /**\n   * Metrics to display on right Y axis\n   */\n  readonly right?: Metric[];\n\n  /**\n   * Annotations for the left Y axis\n   */\n  readonly leftAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Annotations for the right Y axis\n   */\n  readonly rightAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Whether the graph should be shown as stacked lines\n   */\n  readonly stacked?: boolean;\n\n  /**\n   * Range of left Y axis\n   *\n   * @default 0..automatic\n   */\n  readonly leftAxisRange?: YAxisRange;\n\n  /**\n   * Range of right Y axis\n   *\n   * @default 0..automatic\n   */\n  readonly rightAxisRange?: YAxisRange;\n}\n\n/**\n * A dashboard widget that displays metrics\n */\nexport class GraphWidget extends ConcreteWidget {\n  private readonly props: GraphWidgetProps;\n\n  constructor(props: GraphWidgetProps) {\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        metrics: (this.props.left || []).map(m => metricJson(m, 'left')).concat(\n             (this.props.right || []).map(m => metricJson(m, 'right'))),\n        annotations: {\n          horizontal: (this.props.leftAnnotations || []).map(mapAnnotation('left')).concat(\n                (this.props.rightAnnotations || []).map(mapAnnotation('right')))\n        },\n        yAxis: {\n          left: this.props.leftAxisRange !== undefined ? this.props.leftAxisRange : { min: 0 },\n          right: this.props.rightAxisRange !== undefined ? this.props.rightAxisRange : { min: 0 },\n        }\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: Metric[];\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  }\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: this.props.metrics.map(m => metricJson(m, 'left'))\n      }\n    }];\n  }\n}\n\n/**\n * A minimum and maximum value for either the left or right Y axis\n */\nexport interface YAxisRange {\n  /**\n   * The minimum value\n   *\n   * @default Automatic\n   */\n  readonly min?: number;\n\n  /**\n   * The maximum value\n   *\n   * @default Automatic\n   */\n  readonly max?: number;\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   * Hex color code to be used for the annotation\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\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\nfunction mapAnnotation(yAxis: string): ((x: HorizontalAnnotation) => any) {\n  return (a: HorizontalAnnotation) => {\n    return { ...a, yAxis };\n  };\n}\n\n/**\n * Return the JSON structure which represents this metric in a graph\n *\n * This will be called by GraphWidget, no need for clients to call this.\n */\nfunction metricJson(metric: Metric, yAxis: string): any[] {\n  // Namespace and metric Name\n  const ret: any[] = [\n    metric.namespace,\n    metric.metricName,\n  ];\n\n  // Dimensions\n  for (const dim of metric.dimensionsAsList()) {\n    ret.push(dim.name, dim.value);\n  }\n\n  // Options\n  const stat = parseStatistic(metric.statistic);\n  ret.push({\n    yAxis,\n    label: metric.label,\n    color: metric.color,\n    period: metric.periodSec,\n    stat: stat.type === 'simple' ? stat.statistic : 'p' + stat.percentile.toString(),\n  });\n\n  return ret;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.js","sourceRoot":"","sources":["graph.ts"],"names":[],"mappings":"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","sourcesContent":["import cdk = require('@aws-cdk/cdk');\nimport { Alarm } from \"./alarm\";\nimport { Metric } from \"./metric\";\nimport { parseStatistic } from './util.statistic';\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  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 Depends on the type of widget\n   */\n  readonly height?: number;\n}\n\n/**\n * Properties for an AlarmWidget\n */\nexport interface AlarmWidgetProps extends MetricWidgetProps {\n  /**\n   * The alarm to show\n   */\n  readonly alarm: Alarm;\n\n  /**\n   * Range of left Y axis\n   *\n   * @default 0..automatic\n   */\n  readonly leftAxisRange?: YAxisRange;\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.leftAxisRange !== undefined ? this.props.leftAxisRange : { min: 0 }\n        }\n      }\n    }];\n  }\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  readonly left?: Metric[];\n\n  /**\n   * Metrics to display on right Y axis\n   */\n  readonly right?: Metric[];\n\n  /**\n   * Annotations for the left Y axis\n   */\n  readonly leftAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Annotations for the right Y axis\n   */\n  readonly rightAnnotations?: HorizontalAnnotation[];\n\n  /**\n   * Whether the graph should be shown as stacked lines\n   */\n  readonly stacked?: boolean;\n\n  /**\n   * Range of left Y axis\n   *\n   * @default 0..automatic\n   */\n  readonly leftAxisRange?: YAxisRange;\n\n  /**\n   * Range of right Y axis\n   *\n   * @default 0..automatic\n   */\n  readonly rightAxisRange?: YAxisRange;\n}\n\n/**\n * A dashboard widget that displays metrics\n */\nexport class GraphWidget extends ConcreteWidget {\n  private readonly props: GraphWidgetProps;\n\n  constructor(props: GraphWidgetProps) {\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        metrics: (this.props.left || []).map(m => metricJson(m, 'left')).concat(\n             (this.props.right || []).map(m => metricJson(m, 'right'))),\n        annotations: {\n          horizontal: (this.props.leftAnnotations || []).map(mapAnnotation('left')).concat(\n                (this.props.rightAnnotations || []).map(mapAnnotation('right')))\n        },\n        yAxis: {\n          left: this.props.leftAxisRange !== undefined ? this.props.leftAxisRange : { min: 0 },\n          right: this.props.rightAxisRange !== undefined ? this.props.rightAxisRange : { min: 0 },\n        }\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: Metric[];\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  }\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: this.props.metrics.map(m => metricJson(m, 'left'))\n      }\n    }];\n  }\n}\n\n/**\n * A minimum and maximum value for either the left or right Y axis\n */\nexport interface YAxisRange {\n  /**\n   * The minimum value\n   *\n   * @default Automatic\n   */\n  readonly min?: number;\n\n  /**\n   * The maximum value\n   *\n   * @default Automatic\n   */\n  readonly max?: number;\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   * Hex color code to be used for the annotation\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\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\nfunction mapAnnotation(yAxis: string): ((x: HorizontalAnnotation) => any) {\n  return (a: HorizontalAnnotation) => {\n    return { ...a, yAxis };\n  };\n}\n\n/**\n * Return the JSON structure which represents this metric in a graph\n *\n * This will be called by GraphWidget, no need for clients to call this.\n */\nfunction metricJson(metric: Metric, yAxis: string): any[] {\n  // Namespace and metric Name\n  const ret: any[] = [\n    metric.namespace,\n    metric.metricName,\n  ];\n\n  // Dimensions\n  for (const dim of metric.dimensionsAsList()) {\n    ret.push(dim.name, dim.value);\n  }\n\n  // Options\n  const stat = parseStatistic(metric.statistic);\n  ret.push({\n    yAxis,\n    label: metric.label,\n    color: metric.color,\n    period: metric.periodSec,\n    stat: stat.type === 'simple' ? stat.statistic : 'p' + stat.percentile.toString(),\n  });\n\n  return ret;\n}\n"]}

@@ -98,3 +98,3 @@ import iam = require('@aws-cdk/aws-iam');

*/
with(props: MetricCustomization): Metric;
with(props: MetricOptions): Metric;
/**

@@ -170,3 +170,3 @@ * Make a new Alarm for this metric

*/
export interface MetricCustomization {
export interface MetricOptions {
/**

@@ -173,0 +173,0 @@ * Dimensions of the metric

@@ -154,2 +154,2 @@ "use strict";

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metric.js","sourceRoot":"","sources":["metric.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/cdk');\nimport { Alarm, ComparisonOperator, TreatMissingData } from './alarm';\nimport { normalizeStatistic } from './util.statistic';\n\nexport type DimensionHash = {[dim: string]: any};\n\n/**\n * Properties for a metric\n */\nexport interface MetricProps {\n  /**\n   * Dimensions of the metric\n   *\n   * @default No dimensions\n   */\n  readonly dimensions?: DimensionHash;\n\n  /**\n   * Namespace of the metric.\n   */\n  readonly namespace: string;\n\n  /**\n   * Name of the metric.\n   */\n  readonly metricName: string;\n\n  /**\n   * The period over which the specified statistic is applied.\n   *\n   * Specify time in seconds, in multiples of 60.\n   *\n   * @default 300\n   */\n  readonly periodSec?: number;\n\n  /**\n   * What function to use for aggregating.\n   *\n   * Can be one of the following (case insensitive)\n   *\n   * - \"minimum\" | \"min\"\n   * - \"maximum\" | \"max\"\n   * - \"average\" | \"avg\"\n   * - \"sum\"\n   * - \"samplecount | \"n\"\n   * - \"pNN.NN\"\n   *\n   * @default Average\n   */\n  readonly statistic?: string;\n\n  /**\n   * Unit for the metric that is associated with the alarm\n   */\n  readonly unit?: Unit;\n\n  /**\n   * Label for this metric when added to a Graph in a Dashboard\n   */\n  readonly label?: string;\n\n  /**\n   * Color for this metric when added to a Graph in a Dashboard\n   */\n  readonly color?: string;\n}\n\n/**\n * A metric emitted by a service\n *\n * The metric is a combination of a metric identifier (namespace, name and dimensions)\n * and an aggregation function (statistic, period and unit).\n *\n * It also contains metadata which is used only in graphs, such as color and label.\n * It makes sense to embed this in here, so that compound constructs can attach\n * that metadata to metrics they expose.\n *\n * This class does not represent a resource, so hence is not a construct. Instead,\n * Metric is an abstraction that makes it easy to specify metrics for use in both\n * alarms and graphs.\n */\nexport class Metric {\n  /**\n   * Grant permissions to the given identity to write metrics.\n   *\n   * @param grantee The IAM identity to give permissions to.\n   */\n  public static grantPutMetricData(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['cloudwatch:PutMetricData'],\n      resourceArns: ['*']\n    });\n  }\n\n  public readonly dimensions?: DimensionHash;\n  public readonly namespace: string;\n  public readonly metricName: string;\n  public readonly periodSec: number;\n  public readonly statistic: string;\n  public readonly unit?: Unit;\n  public readonly label?: string;\n  public readonly color?: string;\n\n  constructor(props: MetricProps) {\n    if (props.periodSec !== undefined\n      && props.periodSec !== 1 && props.periodSec !== 5 && props.periodSec !== 10 && props.periodSec !== 30\n      && props.periodSec % 60 !== 0) {\n      throw new Error(\"'periodSec' must be 1, 5, 10, 30, or a multiple of 60\");\n    }\n\n    this.dimensions = props.dimensions;\n    this.namespace = props.namespace;\n    this.metricName = props.metricName;\n    this.periodSec = props.periodSec !== undefined ? props.periodSec : 300;\n    // Try parsing, this will throw if it's not a valid stat\n    this.statistic = normalizeStatistic(props.statistic || \"Average\");\n    this.label = props.label;\n    this.color = props.color;\n    this.unit = props.unit;\n  }\n\n  /**\n   * Return a copy of Metric with properties changed.\n   *\n   * All properties except namespace and metricName can be changed.\n   *\n   * @param props The set of properties to change.\n   */\n  public with(props: MetricCustomization): Metric {\n    return new Metric({\n      dimensions: ifUndefined(props.dimensions, this.dimensions),\n      namespace: this.namespace,\n      metricName: this.metricName,\n      periodSec: ifUndefined(props.periodSec, this.periodSec),\n      statistic: ifUndefined(props.statistic, this.statistic),\n      unit: ifUndefined(props.unit, this.unit),\n      label: ifUndefined(props.label, this.label),\n      color: ifUndefined(props.color, this.color)\n    });\n  }\n\n  /**\n   * Make a new Alarm for this metric\n   *\n   * Combines both properties that may adjust the metric (aggregation) as well\n   * as alarm properties.\n   */\n  public newAlarm(scope: cdk.Construct, id: string, props: MetricAlarmProps): Alarm {\n    return new Alarm(scope, id, {\n      metric: this.with({\n        statistic: props.statistic,\n        periodSec: props.periodSec,\n      }),\n      alarmName: props.alarmName,\n      alarmDescription: props.alarmDescription,\n      comparisonOperator: props.comparisonOperator,\n      datapointsToAlarm: props.datapointsToAlarm,\n      threshold: props.threshold,\n      evaluationPeriods: props.evaluationPeriods,\n      evaluateLowSampleCountPercentile: props.evaluateLowSampleCountPercentile,\n      treatMissingData: props.treatMissingData,\n      actionsEnabled: props.actionsEnabled,\n    });\n  }\n\n  /**\n   * Return the dimensions of this Metric as a list of Dimension.\n   */\n  public dimensionsAsList(): Dimension[] {\n    const dims = this.dimensions;\n\n    if (dims === undefined) {\n      return [];\n    }\n\n    const list = Object.keys(dims).map(key => ({ name: key, value: dims[key] }));\n\n    return list;\n  }\n}\n\n/**\n * Metric dimension\n */\nexport interface Dimension {\n  /**\n   * Name of the dimension\n   */\n  readonly name: string;\n\n  /**\n   * Value of the dimension\n   */\n  readonly value: any;\n}\n\n/**\n * Statistic to use over the aggregation period\n */\nexport enum Statistic {\n  SampleCount = 'SampleCount',\n  Average = 'Average',\n  Sum = 'Sum',\n  Minimum = 'Minimum',\n  Maximum = 'Maximum',\n}\n\n/**\n * Unit for metric\n */\nexport enum Unit {\n  Seconds = 'Seconds',\n  Microseconds = 'Microseconds',\n  Milliseconds = 'Milliseconds',\n  Bytes_ = 'Bytes',\n  Kilobytes = 'Kilobytes',\n  Megabytes = 'Megabytes',\n  Gigabytes = 'Gigabytes',\n  Terabytes = 'Terabytes',\n  Bits = 'Bits',\n  Kilobits = 'Kilobits',\n  Megabits = 'Megabits',\n  Gigabits = 'Gigabits',\n  Terabits = 'Terabits',\n  Percent = 'Percent',\n  Count = 'Count',\n  BytesPerSecond = 'Bytes/Second',\n  KilobytesPerSecond = 'Kilobytes/Second',\n  MegabytesPerSecond = 'Megabytes/Second',\n  GigabytesPerSecond = 'Gigabytes/Second',\n  TerabytesPerSecond = 'Terabytes/Second',\n  BitsPerSecond = 'Bits/Second',\n  KilobitsPerSecond = 'Kilobits/Second',\n  MegabitsPerSecond = 'Megabits/Second',\n  GigabitsPerSecond = 'Gigabits/Second',\n  TerabitsPerSecond = 'Terabits/Second',\n  CountPerSecond = 'Count/Second',\n  None = 'None'\n}\n\n/**\n * Properties of a metric that can be changed\n */\nexport interface MetricCustomization {\n  /**\n   * Dimensions of the metric\n   *\n   * @default No dimensions\n   */\n  readonly dimensions?: DimensionHash;\n\n  /**\n   * The period over which the specified statistic is applied.\n   *\n   * Specify time in seconds, in multiples of 60.\n   *\n   * @default 300\n   */\n  readonly periodSec?: number;\n\n  /**\n   * What function to use for aggregating.\n   *\n   * Can be one of the following:\n   *\n   * - \"Minimum\" | \"min\"\n   * - \"Maximum\" | \"max\"\n   * - \"Average\" | \"avg\"\n   * - \"Sum\" | \"sum\"\n   * - \"SampleCount | \"n\"\n   * - \"pNN.NN\"\n   *\n   * @default Average\n   */\n  readonly statistic?: string;\n\n  /**\n   * Unit for the metric that is associated with the alarm\n   */\n  readonly unit?: Unit;\n\n  /**\n   * Label for this metric when added to a Graph in a Dashboard\n   */\n  readonly label?: string;\n\n  /**\n   * Color for this metric when added to a Graph in a Dashboard\n   */\n  readonly color?: string;\n}\n\n/**\n * Properties needed to make an alarm from a metric\n */\nexport interface MetricAlarmProps {\n  /**\n   * The period over which the specified statistic is applied.\n   *\n   * Specify time in seconds, in multiples of 60.\n   *\n   * @default 300\n   */\n  readonly periodSec?: number;\n\n  /**\n   * What function to use for aggregating.\n   *\n   * Can be one of the following:\n   *\n   * - \"Minimum\" | \"min\"\n   * - \"Maximum\" | \"max\"\n   * - \"Average\" | \"avg\"\n   * - \"Sum\" | \"sum\"\n   * - \"SampleCount | \"n\"\n   * - \"pNN.NN\"\n   *\n   * @default Average\n   */\n  readonly statistic?: string;\n\n  /**\n   * Name of the alarm\n   *\n   * @default Automatically generated name\n   */\n  readonly alarmName?: string;\n\n  /**\n   * Description for the alarm\n   *\n   * @default No description\n   */\n  readonly alarmDescription?: string;\n\n  /**\n   * Comparison to use to check if metric is breaching\n   *\n   * @default GreaterThanOrEqualToThreshold\n   */\n  readonly comparisonOperator?: ComparisonOperator;\n\n  /**\n   * The value against which the specified statistic is compared.\n   */\n  readonly threshold: number;\n\n  /**\n   * The number of periods over which data is compared to the specified threshold.\n   */\n  readonly evaluationPeriods: number;\n\n  /**\n   * Specifies whether to evaluate the data and potentially change the alarm state if there are too few data points to be statistically significant.\n   *\n   * Used only for alarms that are based on percentiles.\n   */\n  readonly evaluateLowSampleCountPercentile?: string;\n\n  /**\n   * Sets how this alarm is to handle missing data points.\n   *\n   * @default TreatMissingData.Missing\n   */\n  readonly treatMissingData?: TreatMissingData;\n\n  /**\n   * Whether the actions for this alarm are enabled\n   *\n   * @default true\n   */\n  readonly actionsEnabled?: boolean;\n\n  /**\n   * The number of datapoints that must be breaching to trigger the alarm. This is used only if you are setting an \"M\n   * out of N\" alarm. In that case, this value is the M. For more information, see Evaluating an Alarm in the Amazon\n   * CloudWatch User Guide.\n   *\n   * @default ``evaluationPeriods``\n   *\n   * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarm-evaluation\n   */\n  readonly datapointsToAlarm?: number;\n}\n\nfunction ifUndefined<T>(x: T | undefined, def: T | undefined): T | undefined {\n  if (x !== undefined) {\n    return x;\n  }\n  return def;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metric.js","sourceRoot":"","sources":["metric.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport cdk = require('@aws-cdk/cdk');\nimport { Alarm, ComparisonOperator, TreatMissingData } from './alarm';\nimport { normalizeStatistic } from './util.statistic';\n\nexport type DimensionHash = {[dim: string]: any};\n\n/**\n * Properties for a metric\n */\nexport interface MetricProps {\n  /**\n   * Dimensions of the metric\n   *\n   * @default No dimensions\n   */\n  readonly dimensions?: DimensionHash;\n\n  /**\n   * Namespace of the metric.\n   */\n  readonly namespace: string;\n\n  /**\n   * Name of the metric.\n   */\n  readonly metricName: string;\n\n  /**\n   * The period over which the specified statistic is applied.\n   *\n   * Specify time in seconds, in multiples of 60.\n   *\n   * @default 300\n   */\n  readonly periodSec?: number;\n\n  /**\n   * What function to use for aggregating.\n   *\n   * Can be one of the following (case insensitive)\n   *\n   * - \"minimum\" | \"min\"\n   * - \"maximum\" | \"max\"\n   * - \"average\" | \"avg\"\n   * - \"sum\"\n   * - \"samplecount | \"n\"\n   * - \"pNN.NN\"\n   *\n   * @default Average\n   */\n  readonly statistic?: string;\n\n  /**\n   * Unit for the metric that is associated with the alarm\n   */\n  readonly unit?: Unit;\n\n  /**\n   * Label for this metric when added to a Graph in a Dashboard\n   */\n  readonly label?: string;\n\n  /**\n   * Color for this metric when added to a Graph in a Dashboard\n   */\n  readonly color?: string;\n}\n\n/**\n * A metric emitted by a service\n *\n * The metric is a combination of a metric identifier (namespace, name and dimensions)\n * and an aggregation function (statistic, period and unit).\n *\n * It also contains metadata which is used only in graphs, such as color and label.\n * It makes sense to embed this in here, so that compound constructs can attach\n * that metadata to metrics they expose.\n *\n * This class does not represent a resource, so hence is not a construct. Instead,\n * Metric is an abstraction that makes it easy to specify metrics for use in both\n * alarms and graphs.\n */\nexport class Metric {\n  /**\n   * Grant permissions to the given identity to write metrics.\n   *\n   * @param grantee The IAM identity to give permissions to.\n   */\n  public static grantPutMetricData(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['cloudwatch:PutMetricData'],\n      resourceArns: ['*']\n    });\n  }\n\n  public readonly dimensions?: DimensionHash;\n  public readonly namespace: string;\n  public readonly metricName: string;\n  public readonly periodSec: number;\n  public readonly statistic: string;\n  public readonly unit?: Unit;\n  public readonly label?: string;\n  public readonly color?: string;\n\n  constructor(props: MetricProps) {\n    if (props.periodSec !== undefined\n      && props.periodSec !== 1 && props.periodSec !== 5 && props.periodSec !== 10 && props.periodSec !== 30\n      && props.periodSec % 60 !== 0) {\n      throw new Error(\"'periodSec' must be 1, 5, 10, 30, or a multiple of 60\");\n    }\n\n    this.dimensions = props.dimensions;\n    this.namespace = props.namespace;\n    this.metricName = props.metricName;\n    this.periodSec = props.periodSec !== undefined ? props.periodSec : 300;\n    // Try parsing, this will throw if it's not a valid stat\n    this.statistic = normalizeStatistic(props.statistic || \"Average\");\n    this.label = props.label;\n    this.color = props.color;\n    this.unit = props.unit;\n  }\n\n  /**\n   * Return a copy of Metric with properties changed.\n   *\n   * All properties except namespace and metricName can be changed.\n   *\n   * @param props The set of properties to change.\n   */\n  public with(props: MetricOptions): Metric {\n    return new Metric({\n      dimensions: ifUndefined(props.dimensions, this.dimensions),\n      namespace: this.namespace,\n      metricName: this.metricName,\n      periodSec: ifUndefined(props.periodSec, this.periodSec),\n      statistic: ifUndefined(props.statistic, this.statistic),\n      unit: ifUndefined(props.unit, this.unit),\n      label: ifUndefined(props.label, this.label),\n      color: ifUndefined(props.color, this.color)\n    });\n  }\n\n  /**\n   * Make a new Alarm for this metric\n   *\n   * Combines both properties that may adjust the metric (aggregation) as well\n   * as alarm properties.\n   */\n  public newAlarm(scope: cdk.Construct, id: string, props: MetricAlarmProps): Alarm {\n    return new Alarm(scope, id, {\n      metric: this.with({\n        statistic: props.statistic,\n        periodSec: props.periodSec,\n      }),\n      alarmName: props.alarmName,\n      alarmDescription: props.alarmDescription,\n      comparisonOperator: props.comparisonOperator,\n      datapointsToAlarm: props.datapointsToAlarm,\n      threshold: props.threshold,\n      evaluationPeriods: props.evaluationPeriods,\n      evaluateLowSampleCountPercentile: props.evaluateLowSampleCountPercentile,\n      treatMissingData: props.treatMissingData,\n      actionsEnabled: props.actionsEnabled,\n    });\n  }\n\n  /**\n   * Return the dimensions of this Metric as a list of Dimension.\n   */\n  public dimensionsAsList(): Dimension[] {\n    const dims = this.dimensions;\n\n    if (dims === undefined) {\n      return [];\n    }\n\n    const list = Object.keys(dims).map(key => ({ name: key, value: dims[key] }));\n\n    return list;\n  }\n}\n\n/**\n * Metric dimension\n */\nexport interface Dimension {\n  /**\n   * Name of the dimension\n   */\n  readonly name: string;\n\n  /**\n   * Value of the dimension\n   */\n  readonly value: any;\n}\n\n/**\n * Statistic to use over the aggregation period\n */\nexport enum Statistic {\n  SampleCount = 'SampleCount',\n  Average = 'Average',\n  Sum = 'Sum',\n  Minimum = 'Minimum',\n  Maximum = 'Maximum',\n}\n\n/**\n * Unit for metric\n */\nexport enum Unit {\n  Seconds = 'Seconds',\n  Microseconds = 'Microseconds',\n  Milliseconds = 'Milliseconds',\n  Bytes_ = 'Bytes',\n  Kilobytes = 'Kilobytes',\n  Megabytes = 'Megabytes',\n  Gigabytes = 'Gigabytes',\n  Terabytes = 'Terabytes',\n  Bits = 'Bits',\n  Kilobits = 'Kilobits',\n  Megabits = 'Megabits',\n  Gigabits = 'Gigabits',\n  Terabits = 'Terabits',\n  Percent = 'Percent',\n  Count = 'Count',\n  BytesPerSecond = 'Bytes/Second',\n  KilobytesPerSecond = 'Kilobytes/Second',\n  MegabytesPerSecond = 'Megabytes/Second',\n  GigabytesPerSecond = 'Gigabytes/Second',\n  TerabytesPerSecond = 'Terabytes/Second',\n  BitsPerSecond = 'Bits/Second',\n  KilobitsPerSecond = 'Kilobits/Second',\n  MegabitsPerSecond = 'Megabits/Second',\n  GigabitsPerSecond = 'Gigabits/Second',\n  TerabitsPerSecond = 'Terabits/Second',\n  CountPerSecond = 'Count/Second',\n  None = 'None'\n}\n\n/**\n * Properties of a metric that can be changed\n */\nexport interface MetricOptions {\n  /**\n   * Dimensions of the metric\n   *\n   * @default No dimensions\n   */\n  readonly dimensions?: DimensionHash;\n\n  /**\n   * The period over which the specified statistic is applied.\n   *\n   * Specify time in seconds, in multiples of 60.\n   *\n   * @default 300\n   */\n  readonly periodSec?: number;\n\n  /**\n   * What function to use for aggregating.\n   *\n   * Can be one of the following:\n   *\n   * - \"Minimum\" | \"min\"\n   * - \"Maximum\" | \"max\"\n   * - \"Average\" | \"avg\"\n   * - \"Sum\" | \"sum\"\n   * - \"SampleCount | \"n\"\n   * - \"pNN.NN\"\n   *\n   * @default Average\n   */\n  readonly statistic?: string;\n\n  /**\n   * Unit for the metric that is associated with the alarm\n   */\n  readonly unit?: Unit;\n\n  /**\n   * Label for this metric when added to a Graph in a Dashboard\n   */\n  readonly label?: string;\n\n  /**\n   * Color for this metric when added to a Graph in a Dashboard\n   */\n  readonly color?: string;\n}\n\n/**\n * Properties needed to make an alarm from a metric\n */\nexport interface MetricAlarmProps {\n  /**\n   * The period over which the specified statistic is applied.\n   *\n   * Specify time in seconds, in multiples of 60.\n   *\n   * @default 300\n   */\n  readonly periodSec?: number;\n\n  /**\n   * What function to use for aggregating.\n   *\n   * Can be one of the following:\n   *\n   * - \"Minimum\" | \"min\"\n   * - \"Maximum\" | \"max\"\n   * - \"Average\" | \"avg\"\n   * - \"Sum\" | \"sum\"\n   * - \"SampleCount | \"n\"\n   * - \"pNN.NN\"\n   *\n   * @default Average\n   */\n  readonly statistic?: string;\n\n  /**\n   * Name of the alarm\n   *\n   * @default Automatically generated name\n   */\n  readonly alarmName?: string;\n\n  /**\n   * Description for the alarm\n   *\n   * @default No description\n   */\n  readonly alarmDescription?: string;\n\n  /**\n   * Comparison to use to check if metric is breaching\n   *\n   * @default GreaterThanOrEqualToThreshold\n   */\n  readonly comparisonOperator?: ComparisonOperator;\n\n  /**\n   * The value against which the specified statistic is compared.\n   */\n  readonly threshold: number;\n\n  /**\n   * The number of periods over which data is compared to the specified threshold.\n   */\n  readonly evaluationPeriods: number;\n\n  /**\n   * Specifies whether to evaluate the data and potentially change the alarm state if there are too few data points to be statistically significant.\n   *\n   * Used only for alarms that are based on percentiles.\n   */\n  readonly evaluateLowSampleCountPercentile?: string;\n\n  /**\n   * Sets how this alarm is to handle missing data points.\n   *\n   * @default TreatMissingData.Missing\n   */\n  readonly treatMissingData?: TreatMissingData;\n\n  /**\n   * Whether the actions for this alarm are enabled\n   *\n   * @default true\n   */\n  readonly actionsEnabled?: boolean;\n\n  /**\n   * The number of datapoints that must be breaching to trigger the alarm. This is used only if you are setting an \"M\n   * out of N\" alarm. In that case, this value is the M. For more information, see Evaluating an Alarm in the Amazon\n   * CloudWatch User Guide.\n   *\n   * @default ``evaluationPeriods``\n   *\n   * @see https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/AlarmThatSendsEmail.html#alarm-evaluation\n   */\n  readonly datapointsToAlarm?: number;\n}\n\nfunction ifUndefined<T>(x: T | undefined, def: T | undefined): T | undefined {\n  if (x !== undefined) {\n    return x;\n  }\n  return def;\n}\n"]}
{
"name": "@aws-cdk/aws-cloudwatch",
"version": "0.28.0",
"version": "0.29.0",
"description": "CDK Constructs for AWS CloudWatch",

@@ -32,3 +32,4 @@ "main": "lib/index.js",

"type": "git",
"url": "https://github.com/awslabs/aws-cdk.git"
"url": "https://github.com/awslabs/aws-cdk.git",
"directory": "packages/@aws-cdk/aws-cloudwatch"
},

@@ -62,16 +63,16 @@ "scripts": {

"devDependencies": {
"@aws-cdk/assert": "^0.28.0",
"cdk-build-tools": "^0.28.0",
"cdk-integ-tools": "^0.28.0",
"cfn2ts": "^0.28.0",
"pkglint": "^0.28.0"
"@aws-cdk/assert": "^0.29.0",
"cdk-build-tools": "^0.29.0",
"cdk-integ-tools": "^0.29.0",
"cfn2ts": "^0.29.0",
"pkglint": "^0.29.0"
},
"dependencies": {
"@aws-cdk/aws-iam": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0"
"@aws-cdk/aws-iam": "^0.29.0",
"@aws-cdk/cdk": "^0.29.0"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-iam": "^0.28.0",
"@aws-cdk/cdk": "^0.28.0"
"@aws-cdk/aws-iam": "^0.29.0",
"@aws-cdk/cdk": "^0.29.0"
},

@@ -81,2 +82,2 @@ "engines": {

}
}
}

@@ -106,8 +106,2 @@ ## Metrics

> Warning! Due to a bug in CloudFormation, you cannot update a Dashboard after
> initially creating it if you let its name automatically be generated. You
> must set `dashboardName` if you intend to update the dashboard after creation.
>
> (This note will be removed once the bug is fixed).
### Graph widget

@@ -114,0 +108,0 @@

@@ -37,3 +37,3 @@ {

[
"{\"widgets\":[{\"type\":\"text\",\"width\":6,\"height\":2,\"x\":0,\"y\":0,\"properties\":{\"markdown\":\"# This is my dashboard\"}},{\"type\":\"text\",\"width\":6,\"height\":2,\"x\":6,\"y\":0,\"properties\":{\"markdown\":\"you like?\"}},{\"type\":\"metric\",\"width\":6,\"height\":6,\"x\":0,\"y\":2,\"properties\":{\"view\":\"timeSeries\",\"title\":\"Messages in queue\",\"region\":\"",
"{\"start\":\"-9H\",\"end\":\"2018-12-17T06:00:00.000Z\",\"periodOverride\":\"inherit\",\"widgets\":[{\"type\":\"text\",\"width\":6,\"height\":2,\"x\":0,\"y\":0,\"properties\":{\"markdown\":\"# This is my dashboard\"}},{\"type\":\"text\",\"width\":6,\"height\":2,\"x\":6,\"y\":0,\"properties\":{\"markdown\":\"you like?\"}},{\"type\":\"metric\",\"width\":6,\"height\":6,\"x\":0,\"y\":2,\"properties\":{\"view\":\"timeSeries\",\"title\":\"Messages in queue\",\"region\":\"",
{

@@ -75,3 +75,3 @@ "Ref": "AWS::Region"

},
"DashboardName": "aws-cdk-cloudwatch-DashCCD7F836"
"DashboardName": "MyCustomDashboardName"
}

@@ -78,0 +78,0 @@ }

@@ -10,2 +10,3 @@ "use strict";

const cloudwatch = require("../lib");
const lib_1 = require("../lib");
const app = new cdk.App();

@@ -24,3 +25,8 @@ const stack = new cdk.Stack(app, `aws-cdk-cloudwatch`);

});
const dashboard = new cloudwatch.Dashboard(stack, 'Dash');
const dashboard = new cloudwatch.Dashboard(stack, 'Dash', {
dashboardName: 'MyCustomDashboardName',
start: '-9H',
end: '2018-12-17T06:00:00.000Z',
periodOverride: lib_1.PeriodOverride.Inherit
});
dashboard.add(new cloudwatch.TextWidget({ markdown: '# This is my dashboard' }), new cloudwatch.TextWidget({ markdown: 'you like?' }));

@@ -41,2 +47,2 @@ dashboard.add(new cloudwatch.AlarmWidget({

app.run();
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYWxhcm0tYW5kLWRhc2hib2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmFsYXJtLWFuZC1kYXNoYm9hcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDJGQUEyRjtBQUMzRixFQUFFO0FBQ0Ysb0dBQW9HO0FBQ3BHLDhGQUE4RjtBQUM5RixtQkFBbUI7O0FBRW5CLG9DQUFxQztBQUNyQyxxQ0FBc0M7QUFFdEMsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUM7QUFFMUIsTUFBTSxLQUFLLEdBQUcsSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO0FBRXZELE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUUsSUFBSSxFQUFFLGlCQUFpQixFQUFFLENBQUMsQ0FBQztBQUUvRSxNQUFNLE1BQU0sR0FBRyxJQUFJLFVBQVUsQ0FBQyxNQUFNLENBQUM7SUFDbkMsU0FBUyxFQUFFLFNBQVM7SUFDcEIsVUFBVSxFQUFFLG9DQUFvQztJQUNoRCxVQUFVLEVBQUUsRUFBRSxTQUFTLEVBQUUsS0FBSyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBRTtDQUNyRCxDQUFDLENBQUM7QUFFSCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUU7SUFDNUMsU0FBUyxFQUFFLEdBQUc7SUFDZCxpQkFBaUIsRUFBRSxDQUFDO0lBQ3BCLGlCQUFpQixFQUFFLENBQUM7Q0FDckIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxTQUFTLEdBQUcsSUFBSSxVQUFVLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQztBQUMxRCxTQUFTLENBQUMsR0FBRyxDQUNYLElBQUksVUFBVSxDQUFDLFVBQVUsQ0FBQyxFQUFFLFFBQVEsRUFBRSx3QkFBd0IsRUFBRSxDQUFDLEVBQ2pFLElBQUksVUFBVSxDQUFDLFVBQVUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUNyRCxDQUFDO0FBQ0YsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLFVBQVUsQ0FBQyxXQUFXLENBQUM7SUFDdkMsS0FBSyxFQUFFLG1CQUFtQjtJQUMxQixLQUFLO0NBQ04sQ0FBQyxDQUFDLENBQUM7QUFDSixTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksVUFBVSxDQUFDLFdBQVcsQ0FBQztJQUN2QyxLQUFLLEVBQUUsOENBQThDO0lBQ3JELElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQztJQUNkLGVBQWUsRUFBRSxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQUUsQ0FBQztDQUN4QyxDQUFDLENBQUMsQ0FBQztBQUNKLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxVQUFVLENBQUMsaUJBQWlCLENBQUM7SUFDN0MsS0FBSyxFQUFFLDJCQUEyQjtJQUNsQyxPQUFPLEVBQUUsQ0FBQyxNQUFNLENBQUM7Q0FDbEIsQ0FBQyxDQUFDLENBQUM7QUFFSixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJbnRlZ3JhdGlvbiB0ZXN0IHRvIGRlcGxveSBzb21lIHJlc291cmNlcywgY3JlYXRlIGFuIGFsYXJtIG9uIGl0IGFuZCBjcmVhdGUgYSBkYXNoYm9hcmQuXG4vL1xuLy8gQmVjYXVzZSBsaXRlcmFsbHkgZXZlcnkgb3RoZXIgbGlicmFyeSBpcyBnb2luZyB0byBkZXBlbmQgb24gQGF3cy1jZGsvYXdzLWNsb3Vkd2F0Y2gsIHdlIGRyb3AgZG93blxuLy8gdG8gdGhlIHZlcnkgbG93ZXN0IGxldmVsIHRvIGNyZWF0ZSBDbG91ZEZvcm1hdGlvbiByZXNvdXJjZXMgYnkgaGFuZCwgd2l0aG91dCBldmVuIGdlbmVyYXRlZFxuLy8gbGlicmFyeSBzdXBwb3J0LlxuXG5pbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgY2xvdWR3YXRjaCA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcCgpO1xuXG5jb25zdCBzdGFjayA9IG5ldyBjZGsuU3RhY2soYXBwLCBgYXdzLWNkay1jbG91ZHdhdGNoYCk7XG5cbmNvbnN0IHF1ZXVlID0gbmV3IGNkay5DZm5SZXNvdXJjZShzdGFjaywgJ3F1ZXVlJywgeyB0eXBlOiAnQVdTOjpTUVM6OlF1ZXVlJyB9KTtcblxuY29uc3QgbWV0cmljID0gbmV3IGNsb3Vkd2F0Y2guTWV0cmljKHtcbiAgbmFtZXNwYWNlOiAnQVdTL1NRUycsXG4gIG1ldHJpY05hbWU6ICdBcHByb3hpbWF0ZU51bWJlck9mTWVzc2FnZXNWaXNpYmxlJyxcbiAgZGltZW5zaW9uczogeyBRdWV1ZU5hbWU6IHF1ZXVlLmdldEF0dCgnUXVldWVOYW1lJykgfVxufSk7XG5cbmNvbnN0IGFsYXJtID0gbWV0cmljLm5ld0FsYXJtKHN0YWNrLCAnQWxhcm0nLCB7XG4gIHRocmVzaG9sZDogMTAwLFxuICBldmFsdWF0aW9uUGVyaW9kczogMyxcbiAgZGF0YXBvaW50c1RvQWxhcm06IDIsXG59KTtcblxuY29uc3QgZGFzaGJvYXJkID0gbmV3IGNsb3Vkd2F0Y2guRGFzaGJvYXJkKHN0YWNrLCAnRGFzaCcpO1xuZGFzaGJvYXJkLmFkZChcbiAgbmV3IGNsb3Vkd2F0Y2guVGV4dFdpZGdldCh7IG1hcmtkb3duOiAnIyBUaGlzIGlzIG15IGRhc2hib2FyZCcgfSksXG4gIG5ldyBjbG91ZHdhdGNoLlRleHRXaWRnZXQoeyBtYXJrZG93bjogJ3lvdSBsaWtlPycgfSksXG4pO1xuZGFzaGJvYXJkLmFkZChuZXcgY2xvdWR3YXRjaC5BbGFybVdpZGdldCh7XG4gIHRpdGxlOiAnTWVzc2FnZXMgaW4gcXVldWUnLFxuICBhbGFybSxcbn0pKTtcbmRhc2hib2FyZC5hZGQobmV3IGNsb3Vkd2F0Y2guR3JhcGhXaWRnZXQoe1xuICB0aXRsZTogJ01vcmUgbWVzc2FnZXMgaW4gcXVldWUgd2l0aCBhbGFybSBhbm5vdGF0aW9uJyxcbiAgbGVmdDogW21ldHJpY10sXG4gIGxlZnRBbm5vdGF0aW9uczogW2FsYXJtLnRvQW5ub3RhdGlvbigpXVxufSkpO1xuZGFzaGJvYXJkLmFkZChuZXcgY2xvdWR3YXRjaC5TaW5nbGVWYWx1ZVdpZGdldCh7XG4gIHRpdGxlOiAnQ3VycmVudCBtZXNzYWdlcyBpbiBxdWV1ZScsXG4gIG1ldHJpY3M6IFttZXRyaWNdXG59KSk7XG5cbmFwcC5ydW4oKTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuYWxhcm0tYW5kLWRhc2hib2FyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmFsYXJtLWFuZC1kYXNoYm9hcmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDJGQUEyRjtBQUMzRixFQUFFO0FBQ0Ysb0dBQW9HO0FBQ3BHLDhGQUE4RjtBQUM5RixtQkFBbUI7O0FBRW5CLG9DQUFxQztBQUNyQyxxQ0FBc0M7QUFDdEMsZ0NBQXdDO0FBRXhDLE1BQU0sR0FBRyxHQUFHLElBQUksR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0FBRTFCLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsb0JBQW9CLENBQUMsQ0FBQztBQUV2RCxNQUFNLEtBQUssR0FBRyxJQUFJLEdBQUcsQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFLElBQUksRUFBRSxpQkFBaUIsRUFBRSxDQUFDLENBQUM7QUFFL0UsTUFBTSxNQUFNLEdBQUcsSUFBSSxVQUFVLENBQUMsTUFBTSxDQUFDO0lBQ25DLFNBQVMsRUFBRSxTQUFTO0lBQ3BCLFVBQVUsRUFBRSxvQ0FBb0M7SUFDaEQsVUFBVSxFQUFFLEVBQUUsU0FBUyxFQUFFLEtBQUssQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLEVBQUU7Q0FDckQsQ0FBQyxDQUFDO0FBRUgsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFO0lBQzVDLFNBQVMsRUFBRSxHQUFHO0lBQ2QsaUJBQWlCLEVBQUUsQ0FBQztJQUNwQixpQkFBaUIsRUFBRSxDQUFDO0NBQ3JCLENBQUMsQ0FBQztBQUVILE1BQU0sU0FBUyxHQUFHLElBQUksVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFO0lBQ3hELGFBQWEsRUFBRSx1QkFBdUI7SUFDdEMsS0FBSyxFQUFFLEtBQUs7SUFDWixHQUFHLEVBQUUsMEJBQTBCO0lBQy9CLGNBQWMsRUFBRSxvQkFBYyxDQUFDLE9BQU87Q0FDdkMsQ0FBQyxDQUFDO0FBQ0gsU0FBUyxDQUFDLEdBQUcsQ0FDWCxJQUFJLFVBQVUsQ0FBQyxVQUFVLENBQUMsRUFBRSxRQUFRLEVBQUUsd0JBQXdCLEVBQUUsQ0FBQyxFQUNqRSxJQUFJLFVBQVUsQ0FBQyxVQUFVLENBQUMsRUFBRSxRQUFRLEVBQUUsV0FBVyxFQUFFLENBQUMsQ0FDckQsQ0FBQztBQUNGLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxVQUFVLENBQUMsV0FBVyxDQUFDO0lBQ3ZDLEtBQUssRUFBRSxtQkFBbUI7SUFDMUIsS0FBSztDQUNOLENBQUMsQ0FBQyxDQUFDO0FBQ0osU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLFVBQVUsQ0FBQyxXQUFXLENBQUM7SUFDdkMsS0FBSyxFQUFFLDhDQUE4QztJQUNyRCxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUM7SUFDZCxlQUFlLEVBQUUsQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLENBQUM7Q0FDeEMsQ0FBQyxDQUFDLENBQUM7QUFDSixTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksVUFBVSxDQUFDLGlCQUFpQixDQUFDO0lBQzdDLEtBQUssRUFBRSwyQkFBMkI7SUFDbEMsT0FBTyxFQUFFLENBQUMsTUFBTSxDQUFDO0NBQ2xCLENBQUMsQ0FBQyxDQUFDO0FBRUosR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gSW50ZWdyYXRpb24gdGVzdCB0byBkZXBsb3kgc29tZSByZXNvdXJjZXMsIGNyZWF0ZSBhbiBhbGFybSBvbiBpdCBhbmQgY3JlYXRlIGEgZGFzaGJvYXJkLlxuLy9cbi8vIEJlY2F1c2UgbGl0ZXJhbGx5IGV2ZXJ5IG90aGVyIGxpYnJhcnkgaXMgZ29pbmcgdG8gZGVwZW5kIG9uIEBhd3MtY2RrL2F3cy1jbG91ZHdhdGNoLCB3ZSBkcm9wIGRvd25cbi8vIHRvIHRoZSB2ZXJ5IGxvd2VzdCBsZXZlbCB0byBjcmVhdGUgQ2xvdWRGb3JtYXRpb24gcmVzb3VyY2VzIGJ5IGhhbmQsIHdpdGhvdXQgZXZlbiBnZW5lcmF0ZWRcbi8vIGxpYnJhcnkgc3VwcG9ydC5cblxuaW1wb3J0IGNkayA9IHJlcXVpcmUoJ0Bhd3MtY2RrL2NkaycpO1xuaW1wb3J0IGNsb3Vkd2F0Y2ggPSByZXF1aXJlKCcuLi9saWInKTtcbmltcG9ydCB7IFBlcmlvZE92ZXJyaWRlIH0gZnJvbSAnLi4vbGliJztcblxuY29uc3QgYXBwID0gbmV3IGNkay5BcHAoKTtcblxuY29uc3Qgc3RhY2sgPSBuZXcgY2RrLlN0YWNrKGFwcCwgYGF3cy1jZGstY2xvdWR3YXRjaGApO1xuXG5jb25zdCBxdWV1ZSA9IG5ldyBjZGsuQ2ZuUmVzb3VyY2Uoc3RhY2ssICdxdWV1ZScsIHsgdHlwZTogJ0FXUzo6U1FTOjpRdWV1ZScgfSk7XG5cbmNvbnN0IG1ldHJpYyA9IG5ldyBjbG91ZHdhdGNoLk1ldHJpYyh7XG4gIG5hbWVzcGFjZTogJ0FXUy9TUVMnLFxuICBtZXRyaWNOYW1lOiAnQXBwcm94aW1hdGVOdW1iZXJPZk1lc3NhZ2VzVmlzaWJsZScsXG4gIGRpbWVuc2lvbnM6IHsgUXVldWVOYW1lOiBxdWV1ZS5nZXRBdHQoJ1F1ZXVlTmFtZScpIH1cbn0pO1xuXG5jb25zdCBhbGFybSA9IG1ldHJpYy5uZXdBbGFybShzdGFjaywgJ0FsYXJtJywge1xuICB0aHJlc2hvbGQ6IDEwMCxcbiAgZXZhbHVhdGlvblBlcmlvZHM6IDMsXG4gIGRhdGFwb2ludHNUb0FsYXJtOiAyLFxufSk7XG5cbmNvbnN0IGRhc2hib2FyZCA9IG5ldyBjbG91ZHdhdGNoLkRhc2hib2FyZChzdGFjaywgJ0Rhc2gnLCB7XG4gIGRhc2hib2FyZE5hbWU6ICdNeUN1c3RvbURhc2hib2FyZE5hbWUnLFxuICBzdGFydDogJy05SCcsXG4gIGVuZDogJzIwMTgtMTItMTdUMDY6MDA6MDAuMDAwWicsXG4gIHBlcmlvZE92ZXJyaWRlOiBQZXJpb2RPdmVycmlkZS5Jbmhlcml0XG59KTtcbmRhc2hib2FyZC5hZGQoXG4gIG5ldyBjbG91ZHdhdGNoLlRleHRXaWRnZXQoeyBtYXJrZG93bjogJyMgVGhpcyBpcyBteSBkYXNoYm9hcmQnIH0pLFxuICBuZXcgY2xvdWR3YXRjaC5UZXh0V2lkZ2V0KHsgbWFya2Rvd246ICd5b3UgbGlrZT8nIH0pLFxuKTtcbmRhc2hib2FyZC5hZGQobmV3IGNsb3Vkd2F0Y2guQWxhcm1XaWRnZXQoe1xuICB0aXRsZTogJ01lc3NhZ2VzIGluIHF1ZXVlJyxcbiAgYWxhcm0sXG59KSk7XG5kYXNoYm9hcmQuYWRkKG5ldyBjbG91ZHdhdGNoLkdyYXBoV2lkZ2V0KHtcbiAgdGl0bGU6ICdNb3JlIG1lc3NhZ2VzIGluIHF1ZXVlIHdpdGggYWxhcm0gYW5ub3RhdGlvbicsXG4gIGxlZnQ6IFttZXRyaWNdLFxuICBsZWZ0QW5ub3RhdGlvbnM6IFthbGFybS50b0Fubm90YXRpb24oKV1cbn0pKTtcbmRhc2hib2FyZC5hZGQobmV3IGNsb3Vkd2F0Y2guU2luZ2xlVmFsdWVXaWRnZXQoe1xuICB0aXRsZTogJ0N1cnJlbnQgbWVzc2FnZXMgaW4gcXVldWUnLFxuICBtZXRyaWNzOiBbbWV0cmljXVxufSkpO1xuXG5hcHAucnVuKCk7XG4iXX0=

@@ -6,4 +6,6 @@ import { Test } from 'nodeunit';

'tokens in widgets are retained'(test: Test): void;
'work around CloudFormation bug'(test: Test): void;
'dashboard body includes non-widget fields'(test: Test): void;
'DashboardName is set when provided'(test: Test): void;
'DashboardName is not generated if not provided'(test: Test): void;
};
export = _default;

@@ -93,16 +93,49 @@ "use strict";

},
'work around CloudFormation bug'(test) {
// See: https://github.com/awslabs/aws-cdk/issues/213
'dashboard body includes non-widget fields'(test) {
// GIVEN
const stack = new cdk_1.Stack();
const dashboard = new lib_1.Dashboard(stack, 'Dash', {
start: '-9H',
end: '2018-12-17T06:00:00.000Z',
periodOverride: lib_1.PeriodOverride.Inherit
});
// WHEN
dashboard.add(new lib_1.GraphWidget({ width: 1, height: 1 }) // GraphWidget has internal reference to current region
);
// THEN
assert_1.expect(stack).to(assert_1.haveResource('AWS::CloudWatch::Dashboard', {
DashboardBody: { "Fn::Join": ["", [
"{\"start\":\"-9H\",\"end\":\"2018-12-17T06:00:00.000Z\",\"periodOverride\":\"inherit\",\
\"widgets\":[{\"type\":\"metric\",\"width\":1,\"height\":1,\"x\":0,\"y\":0,\"properties\":{\"view\":\"timeSeries\",\"region\":\"",
{ Ref: "AWS::Region" },
"\",\"metrics\":[],\"annotations\":{\"horizontal\":[]},\"yAxis\":{\"left\":{\"min\":0},\"right\":{\"min\":0}}}}]}"
]] }
}));
test.done();
},
'DashboardName is set when provided'(test) {
// GIVEN
const app = new cdk_1.App();
const stack = new cdk_1.Stack(app, 'MyStack');
// WHEN
new lib_1.Dashboard(stack, 'MyDashboard');
new lib_1.Dashboard(stack, 'MyDashboard', {
dashboardName: 'MyCustomDashboardName'
});
// THEN
assert_1.expect(stack).to(assert_1.haveResource('AWS::CloudWatch::Dashboard', {
DashboardName: 'MyStack-MyDashboardCD351363'
DashboardName: 'MyCustomDashboardName'
}));
test.done();
},
'DashboardName is not generated if not provided'(test) {
// GIVEN
const app = new cdk_1.App();
const stack = new cdk_1.Stack(app, 'MyStack');
// WHEN
new lib_1.Dashboard(stack, 'MyDashboard');
// THEN
assert_1.expect(stack).to(assert_1.haveResource('AWS::CloudWatch::Dashboard', {}));
test.done();
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.dashboard.js","sourceRoot":"","sources":["test.dashboard.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, isSuperObject } from '@aws-cdk/assert';\nimport { App, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Dashboard, GraphWidget, TextWidget } from '../lib';\n\nexport = {\n  'widgets in different adds are laid out underneath each other'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const dashboard = new Dashboard(stack, 'Dash');\n\n    // WHEN\n    dashboard.add(new TextWidget({\n      width: 10,\n      height: 2,\n      markdown: \"first\"\n    }));\n    dashboard.add(new TextWidget({\n      width: 1,\n      height: 4,\n      markdown: \"second\"\n    }));\n    dashboard.add(new TextWidget({\n      width: 4,\n      height: 1,\n      markdown: \"third\"\n    }));\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', thatHasWidgets([\n      { type: 'text', width: 10, height: 2, x: 0, y: 0, properties: { markdown: 'first' } },\n      { type: 'text', width: 1, height: 4, x: 0, y: 2, properties: { markdown: 'second' } },\n      { type: 'text', width: 4, height: 1, x: 0, y: 6, properties: { markdown: 'third' } },\n    ])));\n\n    test.done();\n  },\n\n  'widgets in same add are laid out next to each other'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const dashboard = new Dashboard(stack, 'Dash');\n\n    // WHEN\n    dashboard.add(\n      new TextWidget({\n        width: 10,\n        height: 2,\n        markdown: \"first\"\n      }),\n      new TextWidget({\n        width: 1,\n        height: 4,\n        markdown: \"second\"\n      }),\n      new TextWidget({\n        width: 4,\n        height: 1,\n        markdown: \"third\"\n      }),\n    );\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', thatHasWidgets([\n      { type: 'text', width: 10, height: 2, x: 0, y: 0, properties: { markdown: 'first' } },\n      { type: 'text', width: 1, height: 4, x: 10, y: 0, properties: { markdown: 'second' } },\n      { type: 'text', width: 4, height: 1, x: 11, y: 0, properties: { markdown: 'third' } },\n    ])));\n\n    test.done();\n  },\n\n  'tokens in widgets are retained'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const dashboard = new Dashboard(stack, 'Dash');\n\n    // WHEN\n    dashboard.add(\n      new GraphWidget({ width: 1, height: 1 }) // GraphWidget has internal reference to current region\n    );\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', {\n      DashboardBody: { \"Fn::Join\": [ \"\", [\n        \"{\\\"widgets\\\":[{\\\"type\\\":\\\"metric\\\",\\\"width\\\":1,\\\"height\\\":1,\\\"x\\\":0,\\\"y\\\":0,\\\"properties\\\":{\\\"view\\\":\\\"timeSeries\\\",\\\"region\\\":\\\"\",\n        { Ref: \"AWS::Region\" },\n        \"\\\",\\\"metrics\\\":[],\\\"annotations\\\":{\\\"horizontal\\\":[]},\\\"yAxis\\\":{\\\"left\\\":{\\\"min\\\":0},\\\"right\\\":{\\\"min\\\":0}}}}]}\"\n      ]]}\n    }));\n\n    test.done();\n  },\n\n  'work around CloudFormation bug'(test: Test) {\n    // See: https://github.com/awslabs/aws-cdk/issues/213\n\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n\n    // WHEN\n    new Dashboard(stack, 'MyDashboard');\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', {\n      DashboardName: 'MyStack-MyDashboardCD351363'\n    }));\n\n    test.done();\n  }\n};\n\n/**\n * Returns a property predicate that checks that the given Dashboard has the indicated widgets\n */\nfunction thatHasWidgets(widgets: any): (props: any) => boolean {\n  return (props: any) => {\n    try {\n      const actualWidgets = JSON.parse(props.DashboardBody).widgets;\n      return isSuperObject(actualWidgets, widgets);\n    } catch (e) {\n      // tslint:disable-next-line:no-console\n      console.error('Error parsing', props);\n      throw e;\n    }\n  };\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.dashboard.js","sourceRoot":"","sources":["test.dashboard.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect, haveResource, isSuperObject } from '@aws-cdk/assert';\nimport { App, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { Dashboard, GraphWidget, PeriodOverride, TextWidget } from '../lib';\n\nexport = {\n  'widgets in different adds are laid out underneath each other'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const dashboard = new Dashboard(stack, 'Dash');\n\n    // WHEN\n    dashboard.add(new TextWidget({\n      width: 10,\n      height: 2,\n      markdown: \"first\"\n    }));\n    dashboard.add(new TextWidget({\n      width: 1,\n      height: 4,\n      markdown: \"second\"\n    }));\n    dashboard.add(new TextWidget({\n      width: 4,\n      height: 1,\n      markdown: \"third\"\n    }));\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', thatHasWidgets([\n      { type: 'text', width: 10, height: 2, x: 0, y: 0, properties: { markdown: 'first' } },\n      { type: 'text', width: 1, height: 4, x: 0, y: 2, properties: { markdown: 'second' } },\n      { type: 'text', width: 4, height: 1, x: 0, y: 6, properties: { markdown: 'third' } },\n    ])));\n\n    test.done();\n  },\n\n  'widgets in same add are laid out next to each other'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const dashboard = new Dashboard(stack, 'Dash');\n\n    // WHEN\n    dashboard.add(\n      new TextWidget({\n        width: 10,\n        height: 2,\n        markdown: \"first\"\n      }),\n      new TextWidget({\n        width: 1,\n        height: 4,\n        markdown: \"second\"\n      }),\n      new TextWidget({\n        width: 4,\n        height: 1,\n        markdown: \"third\"\n      }),\n    );\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', thatHasWidgets([\n      { type: 'text', width: 10, height: 2, x: 0, y: 0, properties: { markdown: 'first' } },\n      { type: 'text', width: 1, height: 4, x: 10, y: 0, properties: { markdown: 'second' } },\n      { type: 'text', width: 4, height: 1, x: 11, y: 0, properties: { markdown: 'third' } },\n    ])));\n\n    test.done();\n  },\n\n  'tokens in widgets are retained'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const dashboard = new Dashboard(stack, 'Dash');\n\n    // WHEN\n    dashboard.add(\n      new GraphWidget({ width: 1, height: 1 }) // GraphWidget has internal reference to current region\n    );\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', {\n      DashboardBody: { \"Fn::Join\": [ \"\", [\n        \"{\\\"widgets\\\":[{\\\"type\\\":\\\"metric\\\",\\\"width\\\":1,\\\"height\\\":1,\\\"x\\\":0,\\\"y\\\":0,\\\"properties\\\":{\\\"view\\\":\\\"timeSeries\\\",\\\"region\\\":\\\"\",\n        { Ref: \"AWS::Region\" },\n        \"\\\",\\\"metrics\\\":[],\\\"annotations\\\":{\\\"horizontal\\\":[]},\\\"yAxis\\\":{\\\"left\\\":{\\\"min\\\":0},\\\"right\\\":{\\\"min\\\":0}}}}]}\"\n      ]]}\n    }));\n\n    test.done();\n  },\n\n  'dashboard body includes non-widget fields'(test: Test) {\n    // GIVEN\n    const stack = new Stack();\n    const dashboard = new Dashboard(stack, 'Dash',\n    {\n      start: '-9H',\n      end: '2018-12-17T06:00:00.000Z',\n      periodOverride: PeriodOverride.Inherit\n    });\n\n    // WHEN\n    dashboard.add(\n      new GraphWidget({ width: 1, height: 1 }) // GraphWidget has internal reference to current region\n    );\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', {\n      DashboardBody: { \"Fn::Join\": [ \"\", [\n        \"{\\\"start\\\":\\\"-9H\\\",\\\"end\\\":\\\"2018-12-17T06:00:00.000Z\\\",\\\"periodOverride\\\":\\\"inherit\\\",\\\n\\\"widgets\\\":[{\\\"type\\\":\\\"metric\\\",\\\"width\\\":1,\\\"height\\\":1,\\\"x\\\":0,\\\"y\\\":0,\\\"properties\\\":{\\\"view\\\":\\\"timeSeries\\\",\\\"region\\\":\\\"\",\n        { Ref: \"AWS::Region\" },\n        \"\\\",\\\"metrics\\\":[],\\\"annotations\\\":{\\\"horizontal\\\":[]},\\\"yAxis\\\":{\\\"left\\\":{\\\"min\\\":0},\\\"right\\\":{\\\"min\\\":0}}}}]}\"\n      ]]}\n    }));\n\n    test.done();\n  },\n\n  'DashboardName is set when provided'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n\n    // WHEN\n    new Dashboard(stack, 'MyDashboard', {\n      dashboardName: 'MyCustomDashboardName'\n    });\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', {\n      DashboardName: 'MyCustomDashboardName'\n    }));\n\n    test.done();\n  },\n\n  'DashboardName is not generated if not provided'(test: Test) {\n    // GIVEN\n    const app = new App();\n    const stack = new Stack(app, 'MyStack');\n\n    // WHEN\n    new Dashboard(stack, 'MyDashboard');\n\n    // THEN\n    expect(stack).to(haveResource('AWS::CloudWatch::Dashboard', {}));\n\n    test.done();\n  }\n};\n\n/**\n * Returns a property predicate that checks that the given Dashboard has the indicated widgets\n */\nfunction thatHasWidgets(widgets: any): (props: any) => boolean {\n  return (props: any) => {\n    try {\n      const actualWidgets = JSON.parse(props.DashboardBody).widgets;\n      return isSuperObject(actualWidgets, widgets);\n    } catch (e) {\n      // tslint:disable-next-line:no-console\n      console.error('Error parsing', props);\n      throw e;\n    }\n  };\n}\n"]}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc