UNPKG

@aws-cdk/aws-cloudwatch

Version:

The CDK Construct Library for AWS::CloudWatch

123 lines 14.9 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.Dashboard = exports.PeriodOverride = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const core_1 = require("@aws-cdk/core"); const cloudwatch_generated_1 = require("./cloudwatch.generated"); const layout_1 = require("./layout"); /** * Specify the period for graphs when the CloudWatch dashboard loads */ var PeriodOverride; (function (PeriodOverride) { /** * Period of all graphs on the dashboard automatically adapt to the time range of the dashboard. */ PeriodOverride["AUTO"] = "auto"; /** * Period set for each graph will be used */ PeriodOverride["INHERIT"] = "inherit"; })(PeriodOverride = exports.PeriodOverride || (exports.PeriodOverride = {})); /** * A CloudWatch dashboard */ class Dashboard extends core_1.Resource { constructor(scope, id, props = {}) { super(scope, id, { physicalName: props.dashboardName, }); this.rows = []; try { jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_DashboardProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, Dashboard); } throw error; } { const { dashboardName } = props; if (dashboardName && !core_1.Token.isUnresolved(dashboardName) && !dashboardName.match(/^[\w-]+$/)) { throw new Error([ `The value ${dashboardName} for field dashboardName contains invalid characters.`, 'It can only contain alphanumerics, dash (-) and underscore (_).', ].join(' ')); } } const dashboard = new cloudwatch_generated_1.CfnDashboard(this, 'Resource', { dashboardName: this.physicalName, dashboardBody: core_1.Lazy.string({ produce: () => { const column = new layout_1.Column(...this.rows); column.position(0, 0); return core_1.Stack.of(this).toJsonString({ start: props.start, end: props.end, periodOverride: props.periodOverride, widgets: column.toJson(), }); }, }), }); this.dashboardName = this.getResourceNameAttribute(dashboard.ref); (props.widgets || []).forEach(row => { this.addWidgets(...row); }); this.dashboardArn = core_1.Stack.of(this).formatArn({ service: 'cloudwatch', resource: 'dashboard', resourceName: this.physicalName, }); } /** * Add a widget to the dashboard. * * Widgets given in multiple calls to add() will be laid out stacked on * top of each other. * * Multiple widgets added in the same call to add() will be laid out next * to each other. */ addWidgets(...widgets) { try { jsiiDeprecationWarnings._aws_cdk_aws_cloudwatch_IWidget(widgets); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.addWidgets); } throw error; } if (widgets.length === 0) { return; } const warnings = allWidgetsDeep(widgets).flatMap(w => w.warnings ?? []); for (const w of warnings) { core_1.Annotations.of(this).addWarning(w); } const w = widgets.length > 1 ? new layout_1.Row(...widgets) : widgets[0]; this.rows.push(w); } } exports.Dashboard = Dashboard; _a = JSII_RTTI_SYMBOL_1; Dashboard[_a] = { fqn: "@aws-cdk/aws-cloudwatch.Dashboard", version: "1.198.0" }; function allWidgetsDeep(ws) { const ret = new Array(); ws.forEach(recurse); return ret; function recurse(w) { ret.push(w); if (hasSubWidgets(w)) { w.widgets.forEach(recurse); } } } function hasSubWidgets(w) { return 'widgets' in w; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.js","sourceRoot":"","sources":["dashboard.ts"],"names":[],"mappings":"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","sourcesContent":["import { Lazy, Resource, Stack, Token, Annotations } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnDashboard } from './cloudwatch.generated';\nimport { Column, Row } from './layout';\nimport { IWidget } from './widget';\n\n/**\n * Specify the period for graphs when the CloudWatch dashboard loads\n */\nexport enum PeriodOverride {\n  /**\n   * Period of all graphs on the dashboard automatically adapt to the time range of the dashboard.\n   */\n  AUTO = 'auto',\n  /**\n   * Period set for each graph will be used\n   */\n  INHERIT = 'inherit',\n}\n\n/**\n * Properties for defining a CloudWatch Dashboard\n */\nexport interface DashboardProps {\n  /**\n   * Name of the dashboard.\n   *\n   * If set, must only contain alphanumerics, dash (-) and underscore (_)\n   *\n   * @default - automatically generated name\n   */\n  readonly dashboardName?: string;\n\n  /**\n   * The start of the time range to use for each widget on the dashboard.\n   * You can specify start without specifying end to specify a relative time range that ends with the current time.\n   * In this case, the value of start must begin with -P, and you can use M, H, D, W and M as abbreviations for\n   * minutes, hours, days, weeks and months. For example, -PT8H shows the last 8 hours and -P3M shows the last three months.\n   * You can also use start along with an end field, to specify an absolute time range.\n   * When specifying an absolute time range, use the ISO 8601 format. For example, 2018-12-17T06:00:00.000Z.\n   *\n   * @default When the dashboard loads, the start time will be the default time range.\n   */\n  readonly start?: string;\n\n  /**\n   * The end of the time range to use for each widget on the dashboard when the dashboard loads.\n   * If you specify a value for end, you must also specify a value for start.\n   * Specify an absolute time in the ISO 8601 format. For example, 2018-12-17T06:00:00.000Z.\n   *\n   * @default When the dashboard loads, the end date will be the current time.\n   */\n  readonly end?: string;\n\n  /**\n   * Use this field to specify the period for the graphs when the dashboard loads.\n   * Specifying `Auto` causes the period of all graphs on the dashboard to automatically adapt to the time range of the dashboard.\n   * Specifying `Inherit` ensures that the period set for each graph is always obeyed.\n   *\n   * @default Auto\n   */\n  readonly periodOverride?: PeriodOverride;\n\n  /**\n   * Initial set of widgets on the dashboard\n   *\n   * One array represents a row of widgets.\n   *\n   * @default - No widgets\n   */\n  readonly widgets?: IWidget[][]\n}\n\n/**\n * A CloudWatch dashboard\n */\nexport class Dashboard extends Resource {\n\n  /**\n   * The name of this dashboard\n   *\n   * @attribute\n  */\n  public readonly dashboardName: string;\n\n  /**\n   * ARN of this dashboard\n   *\n   * @attribute\n   */\n  public readonly dashboardArn: string;\n\n  private readonly rows: IWidget[] = [];\n\n  constructor(scope: Construct, id: string, props: DashboardProps = {}) {\n    super(scope, id, {\n      physicalName: props.dashboardName,\n    });\n\n    {\n      const { dashboardName } = props;\n      if (dashboardName && !Token.isUnresolved(dashboardName) && !dashboardName.match(/^[\\w-]+$/)) {\n        throw new Error([\n          `The value ${dashboardName} for field dashboardName contains invalid characters.`,\n          'It can only contain alphanumerics, dash (-) and underscore (_).',\n        ].join(' '));\n      }\n    }\n\n    const dashboard = new CfnDashboard(this, 'Resource', {\n      dashboardName: this.physicalName,\n      dashboardBody: Lazy.string({\n        produce: () => {\n          const column = new Column(...this.rows);\n          column.position(0, 0);\n          return Stack.of(this).toJsonString({\n            start: props.start,\n            end: props.end,\n            periodOverride: props.periodOverride,\n            widgets: column.toJson(),\n          });\n        },\n      }),\n    });\n\n    this.dashboardName = this.getResourceNameAttribute(dashboard.ref);\n\n    (props.widgets || []).forEach(row => {\n      this.addWidgets(...row);\n    });\n\n    this.dashboardArn = Stack.of(this).formatArn({\n      service: 'cloudwatch',\n      resource: 'dashboard',\n      resourceName: this.physicalName,\n    });\n  }\n\n  /**\n   * Add a widget to the dashboard.\n   *\n   * Widgets given in multiple calls to add() will be laid out stacked on\n   * top of each other.\n   *\n   * Multiple widgets added in the same call to add() will be laid out next\n   * to each other.\n   */\n  public addWidgets(...widgets: IWidget[]) {\n    if (widgets.length === 0) {\n      return;\n    }\n\n    const warnings = allWidgetsDeep(widgets).flatMap(w => w.warnings ?? []);\n    for (const w of warnings) {\n      Annotations.of(this).addWarning(w);\n    }\n\n    const w = widgets.length > 1 ? new Row(...widgets) : widgets[0];\n    this.rows.push(w);\n  }\n}\n\nfunction allWidgetsDeep(ws: IWidget[]) {\n  const ret = new Array<IWidget>();\n  ws.forEach(recurse);\n  return ret;\n\n  function recurse(w: IWidget) {\n    ret.push(w);\n    if (hasSubWidgets(w)) {\n      w.widgets.forEach(recurse);\n    }\n  }\n}\n\nfunction hasSubWidgets(w: IWidget): w is IWidget & { widgets: IWidget[] } {\n  return 'widgets' in w;\n}\n"]}