@rio-cloud/cdk-v2-constructs 6.19.0 → 6.20.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +180 -161
- package/docs/API.md +27 -8
- package/docs/changelog.md +15 -0
- package/lib/contributions/team-transport-two/pipeline/datadog-monitors.js +3 -1
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.d.ts +2 -3
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.js +4 -16
- package/lib/datadogv2/datadog-monitor.d.ts +8 -0
- package/lib/datadogv2/datadog-monitor.js +12 -2
- package/lib/kafka/kafka-topic.d.ts +4 -6
- package/lib/kafka/kafka-topic.js +1 -1
- package/package.json +1 -1
- package/version.json +1 -1
|
@@ -91,6 +91,12 @@ class DatadogMonitor extends constructs_1.Construct {
|
|
|
91
91
|
const annotations = cdk.Annotations.of(cdk.Stack.of(this));
|
|
92
92
|
annotations.addWarningV2(`@rio-cloud/cdk-v2-constructs/datadogv2/DatadogMonitor/${id}/CloudMetricEvaluationDelay`, '\n ❌ Your monitor is alerting on Cloud Metrics but you haven\'t set an \'optionOverrides.evaluationDelay\'.\n ✅ It\'s automatically set to 15 minutes, but please provide a suitable value on your own.\n');
|
|
93
93
|
}
|
|
94
|
+
let cloudformationOptions = undefined;
|
|
95
|
+
if (props.lowercaseQuery === true) {
|
|
96
|
+
cloudformationOptions = {
|
|
97
|
+
LowercaseQuery: true,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
94
100
|
// https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json
|
|
95
101
|
this.monitor = new cdk.CfnResource(this, 'Monitor', {
|
|
96
102
|
type: 'Datadog::Monitors::Monitor',
|
|
@@ -98,9 +104,13 @@ class DatadogMonitor extends constructs_1.Construct {
|
|
|
98
104
|
Type: props.monitorType,
|
|
99
105
|
Query: props.query,
|
|
100
106
|
Name: `${teamName.stringValue} ${props.serviceName} ${props.name}`,
|
|
101
|
-
Message: this.concatenateMessage({
|
|
107
|
+
Message: this.concatenateMessage({
|
|
108
|
+
message: props.message,
|
|
109
|
+
notification,
|
|
110
|
+
}),
|
|
102
111
|
Priority: this.priority,
|
|
103
112
|
Options: mapMonitorOptions(optionOverrides),
|
|
113
|
+
CloudformationOptions: cloudformationOptions,
|
|
104
114
|
Tags: [
|
|
105
115
|
...(props.extraTags ?? []),
|
|
106
116
|
`account_id:${cdk.Stack.of(this).account}`,
|
|
@@ -192,4 +202,4 @@ function mapThresholdWindowsProperties(source) {
|
|
|
192
202
|
RecoveryWindow: source.recoveryWindow,
|
|
193
203
|
} : undefined;
|
|
194
204
|
}
|
|
195
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-monitor.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { DefaultSlackNotification, INotification } from './datadog-notification';\nimport { RioLandingZone } from '../rio-landing-zone';\n\n/**\n * Well known monitor types supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/types/\n */\nexport enum DatadogMonitorQueryAlertType {\n  AUDIT_ALERT = 'audit alert',\n  COMPOSITE = 'composite',\n  EVENT_ALERT = 'event alert',\n  EVENT_V_2_ALERT = 'event-v2 alert',\n  LOG_ALERT = 'log alert',\n  METRIC_ALERT = 'metric alert',\n  PROCESS_ALERT = 'process alert',\n  QUERY_ALERT = 'query alert',\n  SERVICE_CHECK = 'service check',\n  SYNTHETICS_ALERT = 'synthetics alert',\n  TRACE_ANALYTICS_ALERT = 'trace-analytics alert',\n  SLO_ALERT = 'slo alert',\n  RUM_ALERT = 'rum alert',\n  CI_PIPELINES_ALERT = 'ci-pipelines alert',\n  ERROR_TRACKING_ALERT = 'error-tracking alert',\n  CI_TESTS_ALERT = 'ci-tests alert',\n}\n\n/**\n * Properties of {@link DatadogMonitor}\n */\nexport interface DatadogMonitorProps {\n\n  /**\n   * A name suffix to be appended to the monitors name.\n   *\n   * The monitor name is concatenated form `<TeamName> <serviceName property> <name property>`\n   */\n  readonly name: string;\n\n  /**\n   * The name of the service to which the monitor belongs.\n   *\n   * Used to generate the monitor name as well a apply the `service` tag.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The monitors type\n   *\n   * @see https://docs.datadoghq.com/monitors/types/\n   */\n  readonly monitorType: DatadogMonitorQueryAlertType;\n\n  /**\n   * The monitors search query\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#define-the-search-query\n   */\n  readonly query: string;\n\n  /**\n   * The message pattern for the monitor\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#message\n   */\n  readonly message: string;\n\n  /**\n   * To explicitly disable notifications use {@link NoNotification}.\n   *\n   * @defaultValue {@link DefaultSlackNotification}\n   *\n   * @see https://docs.datadoghq.com/monitors/notify\n   */\n  readonly notification?: INotification;\n\n  /**\n   * The alert priority of the monitor\n   *\n   * @defaultValue 4\n   */\n  readonly priority?: number;\n\n  /**\n   * Specific options to override the default monitor options.\n   */\n  readonly optionOverrides?: CfnDatadogMonitorOptions;\n\n  /**\n   * Tags to be appended to the monitor in addition to the RIO default tags\n   */\n  readonly extraTags?: string[];\n}\n\n/**\n * Well known renotification settings supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/notify/#renotify\n */\nexport enum RenotifyStatuses {\n  ALERT = 'alert',\n  NO_DATA = 'no data',\n  WARN = 'warn'\n}\n\n/**\n * Well known notification presets supported by Datadog.\n *\n * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n */\nexport enum MonitorNotificationPreset {\n  SHOW_ALL = 'show_all',\n  HIDE_QUERY = 'hide_query',\n  HIDE_HANDLES = 'hide_handles',\n  HIDE_ALL = 'hide_all',\n}\n\n/**\n * Options for onMissingData supported by Datadog.\n *\n * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n */\nexport enum MonitorOnMissingData {\n  DEFAULT = 'default',\n  SHOW_NO_DATA = 'show_no_data',\n  SHOW_AND_NOTIFY_NO_DATA = 'show_and_notify_no_data',\n  RESOLVE = 'resolve',\n}\n\n/**\n * Options to override for Datadog monitors in case more specific settings are required.\n *\n * {@link https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json}\n */\nexport interface CfnDatadogMonitorOptions {\n\n  /**\n   * Whether or not to include a sample of the logs\n   */\n  readonly enableLogsSample?: boolean;\n\n  /**\n   * Whether or not to send a list of samples when the monitor triggers.\n   *\n   * This is only used by CI Test and Pipeline monitors.\n   */\n  readonly enableSamples?: boolean;\n\n  /**\n   * Message to include with a re-notification when renotify_interval is set\n   */\n  readonly escalationMessage?: string;\n\n  /**\n   * Time in seconds to delay evaluation\n   *\n   */\n  readonly evaluationDelay?: number;\n\n  /**\n   * The time span after which groups with missing data are dropped from the monitor state.\n   *\n   * The minimum value is one hour, and the maximum value is 72 hours.\n   * Example values are: \"60m\", \"1h\", and \"2d\".\n   * This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.\n   */\n  readonly groupRetentionDuration?: string;\n\n  /**\n   * Whether or not to include triggering tags into notification title'\n   *\n   * @defaultValue true\n   */\n  readonly includeTags?: boolean;\n\n  /**\n   * Whether or not changes to this monitor should be restricted to the creator or admins\n   */\n  readonly locked?: boolean;\n\n  /**\n   * Number of locations allowed to fail before triggering alert\n   */\n  readonly minLocationFailed?: number;\n\n  /**\n   * Time in seconds to allow a host to start reporting data before starting the evaluation of monitor results\n   */\n  readonly newHostDelay?: number;\n\n  /**\n   * Number of minutes data stopped reporting before notifying\n   */\n  readonly noDataTimeframe?: number;\n\n  /**\n   * Whether or not to notify tagged users when changes are made to the monitor\n   */\n  readonly notifyAudit?: boolean;\n\n  /**\n   * Controls what granularity a monitor alerts on.\n   *\n   * Only available for monitors with groupings.\n   * For instance, a monitor grouped by `cluster`, `namespace`, and `pod` can be configured to only notify on each new `cluster` violating the alert conditions by setting `notify_by` to `[\"cluster\"]`.\n   * Tags mentioned in `notify_by` must be a subset of the grouping tags in the query.\n   * For example, a query grouped by `cluster` and `namespace` cannot notify on `region`.\n   * Setting `notify_by` to `[*]` configures the monitor to notify as a simple-alert.\n   */\n  readonly notifyBy?: string[];\n\n  /**\n   * Whether or not to notify when data stops reporting\n   *\n   * @defaultValue false\n   */\n  readonly notifyNoData?: boolean;\n\n  /**\n   * Controls how groups or monitors are treated if an evaluation does not return any data points.\n   *\n   * The default option results in different behavior depending on the monitor query type.\n   * For monitors using Count queries, an empty monitor evaluation is treated as 0 and is compared to the threshold conditions.\n   * For monitors using any query type other than Count, for example Gauge, Measure, or Rate, the monitor shows the last known status.\n   * This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.\n   */\n  readonly onMissingData?: MonitorOnMissingData;\n\n  /**\n   * Number of minutes after the last notification before the monitor re-notifies on the current status\n   */\n  readonly renotifyInterval?: number;\n\n  /**\n   * Whether or not the monitor requires a full window of data before it is evaluated\n   *\n   * @defaultValue false\n   */\n  readonly requireFullWindow?: boolean;\n\n  /**\n   * Configuration options for scheduling\n   */\n  readonly schedulingOptions?: MonitorSchedulingOptions;\n\n  /**\n   * ID of the corresponding synthetics check\n   */\n  readonly syntheticsCheckID?: number;\n\n  readonly thresholds?: CfnDatadogMonitorThresholds;\n\n  readonly thresholdWindows?: CfnDatadogMonitorThresholdWindows;\n\n  /**\n   * Number of hours of the monitor not reporting data before it automatically resolves\n   */\n  readonly timeoutH?: number;\n\n  /**\n   * The number of times re-notification messages should be sent on the current status at the provided re-notification interval.\n   */\n  readonly renotifyOccurrences?: number;\n\n  /**\n   * The types of monitor statuses for which re-notification messages are sent.\n   */\n  readonly renotifyStatuses?: RenotifyStatuses[];\n\n  /**\n   * How long the test should be in failure before alerting (integer, number of seconds, max 7200).\n   */\n  readonly minFailureDuration?: number;\n\n  /**\n   * Controls which information should be added/lett out from the notification.\n   *\n   * @defaultValue {@link MonitorNotificationPreset.SHOW_ALL}\n   */\n  readonly monitorNotificationPresetName?: MonitorNotificationPreset;\n\n  /**\n   * Time (in seconds) to skip evaluations for new groups. For example, this option can be used to skip evaluations for new hosts while they initialize. Must be a non negative integer.\n   */\n  readonly newGroupDelay?: number;\n\n  /**\n   * List of requests that can be used in the monitor query.\n   */\n  readonly variables?: object[];\n}\n\nexport interface CfnDatadogMonitorThresholds {\n\n  /**\n   * Threshold value for triggering an alert\n   */\n  readonly critical?: number;\n\n  /**\n   * Threshold value for recovering from an alert state\n   */\n  readonly criticalRecovery?: number;\n\n  /**\n   * Threshold value for recovering from an alert state\n   */\n  readonly ok?: number;\n\n  /**\n   * Threshold value for triggering a warning\n   */\n  readonly warning?: number;\n\n  /**\n   * Threshold value for recovering from a warning state\n   */\n  readonly warningRecovery?: number;\n}\n\nexport interface CfnDatadogMonitorThresholdWindows {\n\n  /**\n   * How long a metric must be anomalous before triggering an alert\n   */\n  readonly triggerWindow?: string;\n\n  /**\n   * How long an anomalous metric must be normal before recovering from an alert state\n   */\n  readonly recoveryWindow?: string;\n}\n\n/**\n * Configuration options for scheduling\n */\nexport interface MonitorSchedulingOptions {\n  readonly evaluationWindow?: MonitorSchedulingOptionsEvaluationWindow;\n}\n\n/**\n * Configuration options for the evaluation window.\n *\n * If `hour_starts` is set, no other fields may be set.\n * Otherwise, `day_starts` and `month_starts` must be set together.\n */\nexport interface MonitorSchedulingOptionsEvaluationWindow {\n\n  /**\n   * The time of the day at which a one day cumulative evaluation window starts.\n   *\n   * Must be defined in UTC time in `HH:mm` format.\n   */\n  readonly dayStarts?: string;\n\n  /**\n   * The day of the month at which a one month cumulative evaluation window starts\n   */\n  readonly monthStarts?: number;\n\n  /**\n   * The minute of the hour at which a one hour cumulative evaluation window starts\n   */\n  readonly hourStarts?: number;\n}\n\n/**\n * Wrapper around Datadog's CloudFormation `Datadog::Monitors::Monitor` with some RIO defaults applied.\n *\n * To use this the Datadog resources have to be {@link https://docs.datadoghq.com/integrations/guide/amazon_cloudformation/\n * |enabled in the CloudFormation registry} of the corresponding AWS account. Usually this is done\n * automatically by the Datadog Integrations (account module AND ServiceCatalog) provided by CLAID.\n */\nexport class DatadogMonitor extends Construct {\n  /**\n   * Default priority of a monitor\n   */\n  static readonly DEFAULT_PRIORITY = 4;\n\n  readonly name: string;\n  readonly priority: number;\n\n  private readonly monitor: cdk.CfnResource;\n\n  constructor(scope: Construct, id: string, props: DatadogMonitorProps) {\n    super(scope, id);\n    this.priority = props.priority ?? DatadogMonitor.DEFAULT_PRIORITY;\n    this.name = props.name;\n\n    const teamName = RioLandingZone.getTeamNameParameter(this);\n    const teamIdentifier = RioLandingZone.getTeamIdentifierParameter(this);\n    const accountName = RioLandingZone.getAccountNameParameter(this);\n\n    const notification = props.notification ? props.notification : new DefaultSlackNotification();\n\n    const isAwsMetrikMonitor = (props.monitorType === DatadogMonitorQueryAlertType.METRIC_ALERT || props.monitorType === DatadogMonitorQueryAlertType.QUERY_ALERT) && props.query.indexOf('aws.') > -1;\n    const optionOverrides = {\n      ...props.optionOverrides,\n    };\n\n    if (isAwsMetrikMonitor && optionOverrides.evaluationDelay === undefined) {\n      optionOverrides.evaluationDelay = 900;\n      const annotations = cdk.Annotations.of(cdk.Stack.of(this));\n      annotations.addWarningV2(\n        `@rio-cloud/cdk-v2-constructs/datadogv2/DatadogMonitor/${id}/CloudMetricEvaluationDelay`,\n        '\\n ❌ Your monitor is alerting on Cloud Metrics but you haven\\'t set an \\'optionOverrides.evaluationDelay\\'.\\n ✅ It\\'s automatically set to 15 minutes, but please provide a suitable value on your own.\\n',\n      );\n    }\n\n    // https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n    this.monitor = new cdk.CfnResource(this, 'Monitor', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Type: props.monitorType,\n        Query: props.query,\n        Name: `${teamName.stringValue} ${props.serviceName} ${props.name}`,\n        Message: this.concatenateMessage({ message: props.message, notification }),\n        Priority: this.priority,\n        Options: mapMonitorOptions(optionOverrides),\n        Tags: [\n          ...(props.extraTags ?? []),\n          `account_id:${cdk.Stack.of(this).account}`,\n          `account_name:${accountName.stringValue}`,\n          `service:${props.serviceName}`,\n          `team:${teamName.stringValue}`,\n          `team_identifier:${teamIdentifier.stringValue}`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Obtain the monitor_id as used in Datadog\n   * See https://docs.datadoghq.com/api/latest/monitors/#get-a-monitors-details\n   *\n   * This allows referencing this monitor in other constructs/resources (e.g. SLOs)\n   */\n  get monitorId() {\n    // return Ref as it returns the Id as string instead of the GetAtt(Id) wihch returns the id as number\n    // https://my-rio.slack.com/archives/C034WAG3QUA/p1708419871398949\n    return cdk.Fn.ref(this.monitor.logicalId);\n  }\n\n  private concatenateMessage(props: {message: string; notification: INotification}) {\n    return `${props.message}\\n\\n${props.notification.generateMessageAnnotation(this)}`;\n  }\n\n}\n\nfunction mapMonitorOptions(source: CfnDatadogMonitorOptions | undefined) {\n  return {\n    EnableLogsSample: source?.enableLogsSample,\n    EnableSamples: source?.enableSamples,\n    EscalationMessage: source?.escalationMessage,\n    EvaluationDelay: source?.evaluationDelay,\n    GroupRetentionDuration: source?.groupRetentionDuration,\n    IncludeTags: source?.includeTags ?? true,\n    Locked: source?.locked,\n    MinLocationFailed: source?.minLocationFailed,\n    NewHostDelay: source?.newHostDelay,\n    NoDataTimeframe: source?.noDataTimeframe,\n    NotifyAudit: source?.notifyAudit,\n    NotifyBy: source?.notifyBy,\n    NotifyNoData: source?.notifyNoData ?? false,\n    RenotifyInterval: source?.renotifyInterval,\n    RequireFullWindow: source?.requireFullWindow ?? false,\n    SchedulingOptions: mapSchedulingOptionsProperties(source?.schedulingOptions),\n    SyntheticsCheckID: source?.syntheticsCheckID,\n    Thresholds: mapThresholdsProperties(source?.thresholds),\n    ThresholdWindows: mapThresholdWindowsProperties(source?.thresholdWindows),\n    MonitorNotificationPresetName: source?.monitorNotificationPresetName,\n    TimeoutH: source?.timeoutH,\n    RenotifyOccurrences: source?.renotifyOccurrences,\n    RenotifyStatuses: source?.renotifyStatuses,\n    MinFailureDuration: source?.minFailureDuration,\n    NewGroupDelay: source?.newGroupDelay,\n    Variables: source?.variables,\n    OnMissingData: source?.onMissingData,\n  };\n}\n\nfunction mapSchedulingOptionsProperties(source: MonitorSchedulingOptions | undefined) {\n  return source ? {\n    EvaluationWindow: mapSchedulingOptionsEvaluationWindowProperties(source.evaluationWindow),\n  } : undefined;\n}\n\nfunction mapSchedulingOptionsEvaluationWindowProperties(source: MonitorSchedulingOptionsEvaluationWindow | undefined) {\n  return source ? {\n    DayStarts: source.dayStarts,\n    MonthStarts: source.monthStarts,\n    HourStarts: source.hourStarts,\n  } : undefined;\n}\n\nfunction mapThresholdsProperties(source: CfnDatadogMonitorThresholds | undefined) {\n  return source ? {\n    Critical: source.critical,\n    CriticalRecovery: source.criticalRecovery,\n    OK: source.ok,\n    Warning: source.warning,\n    WarningRecovery: source.warningRecovery,\n  } : undefined;\n}\n\nfunction mapThresholdWindowsProperties(source: CfnDatadogMonitorThresholdWindows | undefined) {\n  return source ? {\n    TriggerWindow: source.triggerWindow,\n    RecoveryWindow: source.recoveryWindow,\n  } : undefined;\n}\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-monitor.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { DefaultSlackNotification, INotification } from './datadog-notification';\nimport { RioLandingZone } from '../rio-landing-zone';\n\n/**\n * Well known monitor types supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/types/\n */\nexport enum DatadogMonitorQueryAlertType {\n  AUDIT_ALERT = 'audit alert',\n  COMPOSITE = 'composite',\n  EVENT_ALERT = 'event alert',\n  EVENT_V_2_ALERT = 'event-v2 alert',\n  LOG_ALERT = 'log alert',\n  METRIC_ALERT = 'metric alert',\n  PROCESS_ALERT = 'process alert',\n  QUERY_ALERT = 'query alert',\n  SERVICE_CHECK = 'service check',\n  SYNTHETICS_ALERT = 'synthetics alert',\n  TRACE_ANALYTICS_ALERT = 'trace-analytics alert',\n  SLO_ALERT = 'slo alert',\n  RUM_ALERT = 'rum alert',\n  CI_PIPELINES_ALERT = 'ci-pipelines alert',\n  ERROR_TRACKING_ALERT = 'error-tracking alert',\n  CI_TESTS_ALERT = 'ci-tests alert',\n}\n\n/**\n * Properties of {@link DatadogMonitor}\n */\nexport interface DatadogMonitorProps {\n\n  /**\n   * A name suffix to be appended to the monitors name.\n   *\n   * The monitor name is concatenated form `<TeamName> <serviceName property> <name property>`\n   */\n  readonly name: string;\n\n  /**\n   * The name of the service to which the monitor belongs.\n   *\n   * Used to generate the monitor name as well a apply the `service` tag.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The monitors type\n   *\n   * @see https://docs.datadoghq.com/monitors/types/\n   */\n  readonly monitorType: DatadogMonitorQueryAlertType;\n\n  /**\n   * The monitors search query\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#define-the-search-query\n   */\n  readonly query: string;\n\n  /**\n   * Convert the query string to lower case. This is useful for passing in AWS resource names into metric queries (metric names are automatically\n   * lowercased in Datadog, but the monitor queries not).\n   * Defaults to false.\n   *\n   * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/docs/cloudformationoptions.md#lowercasequery\n   */\n  readonly lowercaseQuery?: boolean;\n\n  /**\n   * The message pattern for the monitor\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#message\n   */\n  readonly message: string;\n\n  /**\n   * To explicitly disable notifications use {@link NoNotification}.\n   *\n   * @defaultValue {@link DefaultSlackNotification}\n   *\n   * @see https://docs.datadoghq.com/monitors/notify\n   */\n  readonly notification?: INotification;\n\n  /**\n   * The alert priority of the monitor\n   *\n   * @defaultValue 4\n   */\n  readonly priority?: number;\n\n  /**\n   * Specific options to override the default monitor options.\n   */\n  readonly optionOverrides?: CfnDatadogMonitorOptions;\n\n  /**\n   * Tags to be appended to the monitor in addition to the RIO default tags\n   */\n  readonly extraTags?: string[];\n}\n\n/**\n * Well known renotification settings supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/notify/#renotify\n */\nexport enum RenotifyStatuses {\n  ALERT = 'alert',\n  NO_DATA = 'no data',\n  WARN = 'warn'\n}\n\n/**\n * Well known notification presets supported by Datadog.\n *\n * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n */\nexport enum MonitorNotificationPreset {\n  SHOW_ALL = 'show_all',\n  HIDE_QUERY = 'hide_query',\n  HIDE_HANDLES = 'hide_handles',\n  HIDE_ALL = 'hide_all',\n}\n\n/**\n * Options for onMissingData supported by Datadog.\n *\n * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n */\nexport enum MonitorOnMissingData {\n  DEFAULT = 'default',\n  SHOW_NO_DATA = 'show_no_data',\n  SHOW_AND_NOTIFY_NO_DATA = 'show_and_notify_no_data',\n  RESOLVE = 'resolve',\n}\n\n/**\n * Options to override for Datadog monitors in case more specific settings are required.\n *\n * {@link https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json}\n */\nexport interface CfnDatadogMonitorOptions {\n\n  /**\n   * Whether or not to include a sample of the logs\n   */\n  readonly enableLogsSample?: boolean;\n\n  /**\n   * Whether or not to send a list of samples when the monitor triggers.\n   *\n   * This is only used by CI Test and Pipeline monitors.\n   */\n  readonly enableSamples?: boolean;\n\n  /**\n   * Message to include with a re-notification when renotify_interval is set\n   */\n  readonly escalationMessage?: string;\n\n  /**\n   * Time in seconds to delay evaluation\n   *\n   */\n  readonly evaluationDelay?: number;\n\n  /**\n   * The time span after which groups with missing data are dropped from the monitor state.\n   *\n   * The minimum value is one hour, and the maximum value is 72 hours.\n   * Example values are: \"60m\", \"1h\", and \"2d\".\n   * This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.\n   */\n  readonly groupRetentionDuration?: string;\n\n  /**\n   * Whether or not to include triggering tags into notification title'\n   *\n   * @defaultValue true\n   */\n  readonly includeTags?: boolean;\n\n  /**\n   * Whether or not changes to this monitor should be restricted to the creator or admins\n   */\n  readonly locked?: boolean;\n\n  /**\n   * Number of locations allowed to fail before triggering alert\n   */\n  readonly minLocationFailed?: number;\n\n  /**\n   * Time in seconds to allow a host to start reporting data before starting the evaluation of monitor results\n   */\n  readonly newHostDelay?: number;\n\n  /**\n   * Number of minutes data stopped reporting before notifying\n   */\n  readonly noDataTimeframe?: number;\n\n  /**\n   * Whether or not to notify tagged users when changes are made to the monitor\n   */\n  readonly notifyAudit?: boolean;\n\n  /**\n   * Controls what granularity a monitor alerts on.\n   *\n   * Only available for monitors with groupings.\n   * For instance, a monitor grouped by `cluster`, `namespace`, and `pod` can be configured to only notify on each new `cluster` violating the alert conditions by setting `notify_by` to `[\"cluster\"]`.\n   * Tags mentioned in `notify_by` must be a subset of the grouping tags in the query.\n   * For example, a query grouped by `cluster` and `namespace` cannot notify on `region`.\n   * Setting `notify_by` to `[*]` configures the monitor to notify as a simple-alert.\n   */\n  readonly notifyBy?: string[];\n\n  /**\n   * Whether or not to notify when data stops reporting\n   *\n   * @defaultValue false\n   */\n  readonly notifyNoData?: boolean;\n\n  /**\n   * Controls how groups or monitors are treated if an evaluation does not return any data points.\n   *\n   * The default option results in different behavior depending on the monitor query type.\n   * For monitors using Count queries, an empty monitor evaluation is treated as 0 and is compared to the threshold conditions.\n   * For monitors using any query type other than Count, for example Gauge, Measure, or Rate, the monitor shows the last known status.\n   * This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.\n   */\n  readonly onMissingData?: MonitorOnMissingData;\n\n  /**\n   * Number of minutes after the last notification before the monitor re-notifies on the current status\n   */\n  readonly renotifyInterval?: number;\n\n  /**\n   * Whether or not the monitor requires a full window of data before it is evaluated\n   *\n   * @defaultValue false\n   */\n  readonly requireFullWindow?: boolean;\n\n  /**\n   * Configuration options for scheduling\n   */\n  readonly schedulingOptions?: MonitorSchedulingOptions;\n\n  /**\n   * ID of the corresponding synthetics check\n   */\n  readonly syntheticsCheckID?: number;\n\n  readonly thresholds?: CfnDatadogMonitorThresholds;\n\n  readonly thresholdWindows?: CfnDatadogMonitorThresholdWindows;\n\n  /**\n   * Number of hours of the monitor not reporting data before it automatically resolves\n   */\n  readonly timeoutH?: number;\n\n  /**\n   * The number of times re-notification messages should be sent on the current status at the provided re-notification interval.\n   */\n  readonly renotifyOccurrences?: number;\n\n  /**\n   * The types of monitor statuses for which re-notification messages are sent.\n   */\n  readonly renotifyStatuses?: RenotifyStatuses[];\n\n  /**\n   * How long the test should be in failure before alerting (integer, number of seconds, max 7200).\n   */\n  readonly minFailureDuration?: number;\n\n  /**\n   * Controls which information should be added/lett out from the notification.\n   *\n   * @defaultValue {@link MonitorNotificationPreset.SHOW_ALL}\n   */\n  readonly monitorNotificationPresetName?: MonitorNotificationPreset;\n\n  /**\n   * Time (in seconds) to skip evaluations for new groups. For example, this option can be used to skip evaluations for new hosts while they initialize. Must be a non negative integer.\n   */\n  readonly newGroupDelay?: number;\n\n  /**\n   * List of requests that can be used in the monitor query.\n   */\n  readonly variables?: object[];\n}\n\nexport interface CfnDatadogMonitorThresholds {\n\n  /**\n   * Threshold value for triggering an alert\n   */\n  readonly critical?: number;\n\n  /**\n   * Threshold value for recovering from an alert state\n   */\n  readonly criticalRecovery?: number;\n\n  /**\n   * Threshold value for recovering from an alert state\n   */\n  readonly ok?: number;\n\n  /**\n   * Threshold value for triggering a warning\n   */\n  readonly warning?: number;\n\n  /**\n   * Threshold value for recovering from a warning state\n   */\n  readonly warningRecovery?: number;\n}\n\nexport interface CfnDatadogMonitorThresholdWindows {\n\n  /**\n   * How long a metric must be anomalous before triggering an alert\n   */\n  readonly triggerWindow?: string;\n\n  /**\n   * How long an anomalous metric must be normal before recovering from an alert state\n   */\n  readonly recoveryWindow?: string;\n}\n\n/**\n * Configuration options for scheduling\n */\nexport interface MonitorSchedulingOptions {\n  readonly evaluationWindow?: MonitorSchedulingOptionsEvaluationWindow;\n}\n\n/**\n * Configuration options for the evaluation window.\n *\n * If `hour_starts` is set, no other fields may be set.\n * Otherwise, `day_starts` and `month_starts` must be set together.\n */\nexport interface MonitorSchedulingOptionsEvaluationWindow {\n\n  /**\n   * The time of the day at which a one day cumulative evaluation window starts.\n   *\n   * Must be defined in UTC time in `HH:mm` format.\n   */\n  readonly dayStarts?: string;\n\n  /**\n   * The day of the month at which a one month cumulative evaluation window starts\n   */\n  readonly monthStarts?: number;\n\n  /**\n   * The minute of the hour at which a one hour cumulative evaluation window starts\n   */\n  readonly hourStarts?: number;\n}\n\n/**\n * Wrapper around Datadog's CloudFormation `Datadog::Monitors::Monitor` with some RIO defaults applied.\n *\n * To use this the Datadog resources have to be {@link https://docs.datadoghq.com/integrations/guide/amazon_cloudformation/\n * |enabled in the CloudFormation registry} of the corresponding AWS account. Usually this is done\n * automatically by the Datadog Integrations (account module AND ServiceCatalog) provided by CLAID.\n */\nexport class DatadogMonitor extends Construct {\n  /**\n   * Default priority of a monitor\n   */\n  static readonly DEFAULT_PRIORITY = 4;\n\n  readonly name: string;\n  readonly priority: number;\n\n  private readonly monitor: cdk.CfnResource;\n\n  constructor(scope: Construct, id: string, props: DatadogMonitorProps) {\n    super(scope, id);\n    this.priority = props.priority ?? DatadogMonitor.DEFAULT_PRIORITY;\n    this.name = props.name;\n\n    const teamName = RioLandingZone.getTeamNameParameter(this);\n    const teamIdentifier = RioLandingZone.getTeamIdentifierParameter(this);\n    const accountName = RioLandingZone.getAccountNameParameter(this);\n\n    const notification = props.notification ? props.notification : new DefaultSlackNotification();\n\n    const isAwsMetrikMonitor = (props.monitorType === DatadogMonitorQueryAlertType.METRIC_ALERT || props.monitorType === DatadogMonitorQueryAlertType.QUERY_ALERT) && props.query.indexOf('aws.') > -1;\n    const optionOverrides = {\n      ...props.optionOverrides,\n    };\n\n    if (isAwsMetrikMonitor && optionOverrides.evaluationDelay === undefined) {\n      optionOverrides.evaluationDelay = 900;\n      const annotations = cdk.Annotations.of(cdk.Stack.of(this));\n      annotations.addWarningV2(\n        `@rio-cloud/cdk-v2-constructs/datadogv2/DatadogMonitor/${id}/CloudMetricEvaluationDelay`,\n        '\\n ❌ Your monitor is alerting on Cloud Metrics but you haven\\'t set an \\'optionOverrides.evaluationDelay\\'.\\n ✅ It\\'s automatically set to 15 minutes, but please provide a suitable value on your own.\\n',\n      );\n    }\n\n    let cloudformationOptions = undefined;\n    if (props.lowercaseQuery === true) {\n      cloudformationOptions = {\n        LowercaseQuery: true,\n      };\n    }\n\n    // https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n    this.monitor = new cdk.CfnResource(this, 'Monitor', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Type: props.monitorType,\n        Query: props.query,\n        Name: `${teamName.stringValue} ${props.serviceName} ${props.name}`,\n        Message: this.concatenateMessage({\n          message: props.message,\n          notification,\n        }),\n        Priority: this.priority,\n        Options: mapMonitorOptions(optionOverrides),\n        CloudformationOptions: cloudformationOptions,\n        Tags: [\n          ...(props.extraTags ?? []),\n          `account_id:${cdk.Stack.of(this).account}`,\n          `account_name:${accountName.stringValue}`,\n          `service:${props.serviceName}`,\n          `team:${teamName.stringValue}`,\n          `team_identifier:${teamIdentifier.stringValue}`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Obtain the monitor_id as used in Datadog\n   * See https://docs.datadoghq.com/api/latest/monitors/#get-a-monitors-details\n   *\n   * This allows referencing this monitor in other constructs/resources (e.g. SLOs)\n   */\n  get monitorId() {\n    // return Ref as it returns the Id as string instead of the GetAtt(Id) wihch returns the id as number\n    // https://my-rio.slack.com/archives/C034WAG3QUA/p1708419871398949\n    return cdk.Fn.ref(this.monitor.logicalId);\n  }\n\n  private concatenateMessage(props: { message: string; notification: INotification }) {\n    return `${props.message}\\n\\n${props.notification.generateMessageAnnotation(this)}`;\n  }\n\n}\n\nfunction mapMonitorOptions(source: CfnDatadogMonitorOptions | undefined) {\n  return {\n    EnableLogsSample: source?.enableLogsSample,\n    EnableSamples: source?.enableSamples,\n    EscalationMessage: source?.escalationMessage,\n    EvaluationDelay: source?.evaluationDelay,\n    GroupRetentionDuration: source?.groupRetentionDuration,\n    IncludeTags: source?.includeTags ?? true,\n    Locked: source?.locked,\n    MinLocationFailed: source?.minLocationFailed,\n    NewHostDelay: source?.newHostDelay,\n    NoDataTimeframe: source?.noDataTimeframe,\n    NotifyAudit: source?.notifyAudit,\n    NotifyBy: source?.notifyBy,\n    NotifyNoData: source?.notifyNoData ?? false,\n    RenotifyInterval: source?.renotifyInterval,\n    RequireFullWindow: source?.requireFullWindow ?? false,\n    SchedulingOptions: mapSchedulingOptionsProperties(source?.schedulingOptions),\n    SyntheticsCheckID: source?.syntheticsCheckID,\n    Thresholds: mapThresholdsProperties(source?.thresholds),\n    ThresholdWindows: mapThresholdWindowsProperties(source?.thresholdWindows),\n    MonitorNotificationPresetName: source?.monitorNotificationPresetName,\n    TimeoutH: source?.timeoutH,\n    RenotifyOccurrences: source?.renotifyOccurrences,\n    RenotifyStatuses: source?.renotifyStatuses,\n    MinFailureDuration: source?.minFailureDuration,\n    NewGroupDelay: source?.newGroupDelay,\n    Variables: source?.variables,\n    OnMissingData: source?.onMissingData,\n  };\n}\n\nfunction mapSchedulingOptionsProperties(source: MonitorSchedulingOptions | undefined) {\n  return source ? {\n    EvaluationWindow: mapSchedulingOptionsEvaluationWindowProperties(source.evaluationWindow),\n  } : undefined;\n}\n\nfunction mapSchedulingOptionsEvaluationWindowProperties(source: MonitorSchedulingOptionsEvaluationWindow | undefined) {\n  return source ? {\n    DayStarts: source.dayStarts,\n    MonthStarts: source.monthStarts,\n    HourStarts: source.hourStarts,\n  } : undefined;\n}\n\nfunction mapThresholdsProperties(source: CfnDatadogMonitorThresholds | undefined) {\n  return source ? {\n    Critical: source.critical,\n    CriticalRecovery: source.criticalRecovery,\n    OK: source.ok,\n    Warning: source.warning,\n    WarningRecovery: source.warningRecovery,\n  } : undefined;\n}\n\nfunction mapThresholdWindowsProperties(source: CfnDatadogMonitorThresholdWindows | undefined) {\n  return source ? {\n    TriggerWindow: source.triggerWindow,\n    RecoveryWindow: source.recoveryWindow,\n  } : undefined;\n}\n"]}
|
|
@@ -75,9 +75,8 @@ export interface LogCompactionProperties {
|
|
|
75
75
|
readonly deleteRetention?: Duration;
|
|
76
76
|
}
|
|
77
77
|
/**
|
|
78
|
-
* The current service limits
|
|
79
|
-
*
|
|
80
|
-
* @see https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml
|
|
78
|
+
* The current service limits are configured in the topic manager.
|
|
79
|
+
* If you need to increase the limits for your service, please contact CLAID.
|
|
81
80
|
*/
|
|
82
81
|
export interface KafkaTopicProps {
|
|
83
82
|
/**
|
|
@@ -135,9 +134,8 @@ export interface KafkaTopicProps {
|
|
|
135
134
|
readonly maxCompactionLagMs?: number;
|
|
136
135
|
}
|
|
137
136
|
/**
|
|
138
|
-
* The current service limits
|
|
139
|
-
*
|
|
140
|
-
* @see https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml
|
|
137
|
+
* The current service limits are configured in the topic manager.
|
|
138
|
+
* If you need to increase the limits for your service, please contact CLAID.
|
|
141
139
|
*/
|
|
142
140
|
export interface KafkaTopicV4Props {
|
|
143
141
|
/**
|
package/lib/kafka/kafka-topic.js
CHANGED
|
@@ -127,4 +127,4 @@ const mapProperties = (scope, props) => {
|
|
|
127
127
|
},
|
|
128
128
|
};
|
|
129
129
|
};
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kafka-topic.js","sourceRoot":"","sources":["../../src/kafka/kafka-topic.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, CfnResource, Annotations } from 'aws-cdk-lib';\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\nimport { KafkaEventSpec, KafkaEventSpecSource } from './kafka-event-spec';\nimport { RioLandingZone } from '../rio-landing-zone';\n\n/**\n * Wrapper for all meta data of a topic.\n */\nexport interface KafkaTopicMetaData {\n  /**\n   * The event specs of the events on that topic\n   */\n  readonly events: KafkaEventSpecSource[];\n\n  /**\n   * Describes the intent of the topic. This might be information about the events on that topic\n   * or additional information about the producer and the context of the events.\n   */\n  readonly description: string;\n}\n\n/**\n * Wrapper for all meta data of a v4 topic spec.\n */\nexport interface KafkaTopicMetaDataV4 {\n  /**\n   * The event specs of the events on that topic\n   */\n  readonly events: KafkaEventSpecSource[];\n\n  /**\n   * Describes the intent of the topic. This might be information about the events on that topic\n   * or additional information about the producer and the context of the events.\n   */\n  readonly description: string;\n\n  /**\n   * Indicates if a topic is meant for component internal usage only or if other services could\n   * use it too.\n   */\n  readonly audience: TopicAudience;\n\n  /**\n   * Indicates if the producer will restore the data in case of a disaster or not.\n   */\n  readonly recoveryPolicy: TopicRecoveryPolicy;\n}\n\n/**\n * Read and write permissions for the topic.\n *\n * strings are matched against the CNAME of the certificate of the Kafka clients.\n */\nexport interface KafkaAclStatement {\n  /**\n  * List of clients that should get write permissions\n  */\n  readonly write: string[];\n\n  /**\n   * List of clients that should get read permissions\n   */\n  readonly read: string[];\n\n  /**\n   * List of clients that should get delete permissions.\n   *\n   * Attention: Only use Deletion policy if you know what you are doing!\n   * This is only necessary for KStream and allows the application to delete messages and the topic.<br>\n   * If you just want to \"delete\" a message on a log compacted topic, you should not set this permission and send a tombstone message instead.\n   *\n   * @jsii ignore\n   */\n  readonly delete?: string[];\n}\n\n/**\n * Wrapper for all log compaction related properties.\n */\nexport interface LogCompactionProperties {\n  /**\n   * The amount of time to retain delete tombstone markers for log compacted topics;\n   * The soft limit is 10 days but can be increased upon requests.\n   * @defaultValue 1 day\n   */\n  readonly deleteRetention?: Duration;\n}\n\n/**\n * The current service limits can be found in the topic limits configuration of the topic manager.\n *\n * @see https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml\n */\nexport interface KafkaTopicProps {\n  /**\n   * The unique name of the topic; has to match pattern [A-Za-z0-9.-]+\n   */\n  readonly name: string;\n\n  /**\n   * Defines degree of parallelism of the topic; should be increased for\n   * large expected loads (e.g., 25 for rio.asset-iot-events).\n   * The soft limit is 10 partitions but can be increased upon requests.\n   */\n  readonly numberOfPartitions: number;\n\n  /**\n   * Defines degree of replication of messages; has to be between 1 and the number of brokers (currently 3).\n   * @defaultValue 3\n   */\n  readonly replicationFactor?: number;\n\n  /**\n   * Time how long messages are retained on Kafka cluster;\n   *\n   * We recommend 30 days for general events and 7 days for sensor events and other high-load cases.\n   * The soft limit is 3 to 30 days but can be increased upon requests.\n   * @defaultValue 7 days\n   */\n  readonly retention?: Duration;\n\n  /**\n   * If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion.\n   * If set to 'true', it will be deleted immediately after stack deletion.\n   * @defaultValue false\n   */\n  readonly instantDeletionEnabled?: boolean;\n\n  /**\n   * The metadata of the topic.\n   */\n  readonly metadata: KafkaTopicMetaData;\n\n  /**\n   * The permissions to access to the topic's data.\n   */\n  readonly acl: KafkaAclStatement;\n\n  /**\n   * Specify whether the topic is log compacted or not.\n   */\n  readonly isLogCompacted: boolean;\n\n  /**\n   * Must only be provided if 'isLogCompacted' is 'true'.\n   * @defaultValue undefined\n   */\n  readonly logCompactionProperties?: LogCompactionProperties;\n\n  /**\n   * The maximum compaction lag in milliseconds.\n   *\n   * The maximum time a message can be delayed before it is compacted.\n   * @defaultValue 9223372036854775807\n   */\n  readonly maxCompactionLagMs?: number;\n}\n\n/**\n * The current service limits can be found in the topic limits configuration of the topic manager.\n *\n * @see https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml\n */\nexport interface KafkaTopicV4Props {\n  /**\n   * The unique name of the topic; has to match pattern [A-Za-z0-9.-]+\n   */\n  readonly name: string;\n\n  /**\n   * Defines degree of parallelism of the topic; should be increased for\n   * large expected loads (e.g., 25 for rio.asset-iot-events).\n   * The soft limit is 10 partitions but can be increased upon requests.\n   */\n  readonly numberOfPartitions: number;\n\n  /**\n   * Defines degree of replication of messages; has to be between 1 and the number of brokers (currently 3).\n   * @defaultValue 3\n   */\n  readonly replicationFactor?: number;\n\n  /**\n   * Time how long messages are retained on Kafka cluster;\n   *\n   * We recommend 30 days for general events and 7 days for sensor events and other high-load cases.\n   * The soft limit is 3 to 30 days but can be increased upon requests.\n   * @defaultValue 7 days\n   */\n  readonly retention?: Duration;\n\n  /**\n   * If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion.\n   * If set to 'true', it will be deleted immediately after stack deletion.\n   * @defaultValue false\n   */\n  readonly instantDeletionEnabled?: boolean;\n\n  /**\n   * The metadata of the topic.\n   */\n  readonly metadata: KafkaTopicMetaDataV4;\n\n  /**\n   * The permissions to access to the topic's data.\n   */\n  readonly acl: KafkaAclStatement;\n\n  /**\n   * Specify whether the topic is log compacted or not.\n   */\n  readonly isLogCompacted: boolean;\n\n  /**\n   * Must only be provided if 'isLogCompacted' is 'true'.\n   * @defaultValue undefined\n   */\n  readonly logCompactionProperties?: LogCompactionProperties;\n\n  /**\n   * Specify whether the topic should be backed up automatically or not.\n   * It could just be enabled, if the topic is compacted and the RecoveryPolicy is 'recoverable'.\n   *\n   * @defaultValue undefined\n   */\n  readonly managedBackupEnabled?: boolean;\n\n  /**\n     * The maximum compaction lag in milliseconds.\n     *\n     * The maximum time a message can be delayed before it is compacted.\n     * @defaultValue 9223372036854775807\n     */\n  readonly maxCompactionLagMs?: number;\n}\n\n/**\n * The Topics target audience\n */\nexport type TopicAudience = 'component-internal' | 'company-internal';\n\n/**\n * The Topics recovery policy guaranteed by the producer\n */\nexport type TopicRecoveryPolicy = 'none' | 'recoverable';\n\n/**\n * Construct to create a kafka topic.\n *\n * @deprecated use {@link KafkaTopicV4} instead\n */\nexport class KafkaTopic extends Construct {\n\n  constructor(scope: Construct, id: string, props: KafkaTopicProps) {\n    super(scope, id);\n\n\n    Annotations.of(this).addDeprecation('KafkaTopic', \"Use 'KafkaTopicV4'!\");\n\n    new CfnResource(this, 'KafkaTopic', {\n      type: 'Custom::KafkaTopic',\n      properties: {\n        ...mapProperties(this, props),\n        Version: '3',\n      },\n    });\n\n    this.node.addValidation(validator(props));\n  }\n}\n\n/**\n * Construct to create a kafka topic.\n */\nexport class KafkaTopicV4 extends Construct {\n\n  constructor(scope: Construct, id: string, props: KafkaTopicV4Props) {\n    super(scope, id);\n\n    new CfnResource(this, 'KafkaTopic', {\n      type: 'Custom::KafkaTopic',\n      properties: {\n        ...mapProperties(this, props),\n        Version: '4',\n        Audience: props.metadata.audience,\n        RecoveryPolicy: props.metadata.recoveryPolicy,\n        ManagedBackupEnabled: props.managedBackupEnabled,\n      },\n    });\n\n    this.node.addValidation(validator(props));\n    this.node.addValidation(backupPropertiesValidator(props));\n  }\n}\n\nconst validator = (props: KafkaTopicProps) => {\n  return {\n    validate: (): string[] => {\n      const result = [];\n\n      if (!props.name.match(/^[A-Za-z0-9.-]+$/)) {\n        result.push('Invalid [name]: expecting topic name to match the reg exp `[A-Za-z0-9.-]+`.');\n      }\n\n      if (!Number.isInteger(props.numberOfPartitions) || props.numberOfPartitions < 1) {\n        result.push(`Invalid [numberOfPartitions]: expecting number of partitions to be a positive integer but got ${props.numberOfPartitions}.`);\n      }\n\n      if (props.replicationFactor !== undefined &&\n          (!Number.isInteger(props.replicationFactor) || props.replicationFactor < 1 || props.replicationFactor > 3)) {\n        result.push('Invalid [replicationFactor]: expecting an integer between 1 and 3.');\n      }\n\n      if (props.metadata.events.length === 0) {\n        result.push('Invalid [metadata]: expecting [events] to have at least on element.');\n      }\n\n      if (!props.isLogCompacted && props.logCompactionProperties) {\n        result.push('Invalid [logCompactionProperties]: log compaction is disabled so properties must be undefined.');\n      }\n\n      if (!props.isLogCompacted && props.maxCompactionLagMs) {\n        result.push('Invalid [maxCompactionLagMs]: max compaction lag is only allowed for log compacted topics.');\n      }\n\n      return result;\n    },\n  };\n};\n\nconst backupPropertiesValidator = (props: KafkaTopicV4Props) => {\n  return {\n    validate: (): string[] => {\n      const result = [];\n\n      if (props.managedBackupEnabled && !props.isLogCompacted) {\n        result.push('Invalid [managedBackupEnabled]: managed backup can only be enabled for log compacted topics.');\n      }\n\n      if (props.managedBackupEnabled && props.metadata.recoveryPolicy !== 'recoverable') {\n        result.push('Invalid [managedBackupEnabled]: topics with managedBackupEnabled have to have recovery policy \"recoverable\".');\n      }\n\n      return result;\n    },\n  };\n\n};\n\nconst mapProperties = (scope: IConstruct, props: KafkaTopicProps | KafkaTopicV4Props) => {\n  const teamEmail = RioLandingZone.getTeamEmailParameter(scope).stringValue;\n\n  const events = props.metadata.events.map(source => {\n    new KafkaEventSpec(scope, `${source.eventName.replace(/\\./g, '_')}-EventSpec`, { source });\n    return source.eventName;\n  });\n\n  const deleteRetentionDuration = props.logCompactionProperties?.deleteRetention ?? Duration.days(7);\n  if (props.acl.delete != undefined && props.acl.delete.length > 0) {\n    const annotations = cdk.Annotations.of(cdk.Stack.of(scope));\n    annotations.addWarningV2(\n      `@rio-cloud/cdk-v2-constructs/kafka/kafka-topic/${props.name}/DeletionPolicy`,\n      `\n ❌ You have set \"delete\" permission for kafka-topic ${props.name}. You probably do not need this. Please use this only if you know what you are doing.\n`,\n    );\n  }\n  return {\n    ServiceToken: 'arn:aws:sns:eu-west-1:186993757734:dp-topic-manager-sns-topic',\n    TopicName: props.name,\n    Description: props.metadata.description,\n    Events: events,\n    NumberOfPartitions: props.numberOfPartitions,\n    ReplicationFactor: props.replicationFactor ?? 3,\n    RetentionMs: (props.retention ?? Duration.days(7)).toMilliseconds(),\n    DeleteRetentionMs: props.isLogCompacted ? deleteRetentionDuration.toMilliseconds() : undefined,\n    InstantDeletionEnabled: props.instantDeletionEnabled ?? false,\n    CleanupPolicy: props.isLogCompacted ? 'compact' : 'delete',\n    TeamEmail: teamEmail,\n    MaxCompactionLagMs: props.maxCompactionLagMs,\n    ACL: {\n      Read: props.acl.read,\n      Write: props.acl.write,\n      Delete: props.acl.delete,\n    },\n  };\n};\n"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kafka-topic.js","sourceRoot":"","sources":["../../src/kafka/kafka-topic.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, CfnResource, Annotations } from 'aws-cdk-lib';\nimport * as cdk from 'aws-cdk-lib';\nimport { Construct, IConstruct } from 'constructs';\nimport { KafkaEventSpec, KafkaEventSpecSource } from './kafka-event-spec';\nimport { RioLandingZone } from '../rio-landing-zone';\n\n/**\n * Wrapper for all meta data of a topic.\n */\nexport interface KafkaTopicMetaData {\n  /**\n   * The event specs of the events on that topic\n   */\n  readonly events: KafkaEventSpecSource[];\n\n  /**\n   * Describes the intent of the topic. This might be information about the events on that topic\n   * or additional information about the producer and the context of the events.\n   */\n  readonly description: string;\n}\n\n/**\n * Wrapper for all meta data of a v4 topic spec.\n */\nexport interface KafkaTopicMetaDataV4 {\n  /**\n   * The event specs of the events on that topic\n   */\n  readonly events: KafkaEventSpecSource[];\n\n  /**\n   * Describes the intent of the topic. This might be information about the events on that topic\n   * or additional information about the producer and the context of the events.\n   */\n  readonly description: string;\n\n  /**\n   * Indicates if a topic is meant for component internal usage only or if other services could\n   * use it too.\n   */\n  readonly audience: TopicAudience;\n\n  /**\n   * Indicates if the producer will restore the data in case of a disaster or not.\n   */\n  readonly recoveryPolicy: TopicRecoveryPolicy;\n}\n\n/**\n * Read and write permissions for the topic.\n *\n * strings are matched against the CNAME of the certificate of the Kafka clients.\n */\nexport interface KafkaAclStatement {\n  /**\n  * List of clients that should get write permissions\n  */\n  readonly write: string[];\n\n  /**\n   * List of clients that should get read permissions\n   */\n  readonly read: string[];\n\n  /**\n   * List of clients that should get delete permissions.\n   *\n   * Attention: Only use Deletion policy if you know what you are doing!\n   * This is only necessary for KStream and allows the application to delete messages and the topic.<br>\n   * If you just want to \"delete\" a message on a log compacted topic, you should not set this permission and send a tombstone message instead.\n   *\n   * @jsii ignore\n   */\n  readonly delete?: string[];\n}\n\n/**\n * Wrapper for all log compaction related properties.\n */\nexport interface LogCompactionProperties {\n  /**\n   * The amount of time to retain delete tombstone markers for log compacted topics;\n   * The soft limit is 10 days but can be increased upon requests.\n   * @defaultValue 1 day\n   */\n  readonly deleteRetention?: Duration;\n}\n\n/**\n * The current service limits are configured in the topic manager.\n * If you need to increase the limits for your service, please contact CLAID.\n */\nexport interface KafkaTopicProps {\n  /**\n   * The unique name of the topic; has to match pattern [A-Za-z0-9.-]+\n   */\n  readonly name: string;\n\n  /**\n   * Defines degree of parallelism of the topic; should be increased for\n   * large expected loads (e.g., 25 for rio.asset-iot-events).\n   * The soft limit is 10 partitions but can be increased upon requests.\n   */\n  readonly numberOfPartitions: number;\n\n  /**\n   * Defines degree of replication of messages; has to be between 1 and the number of brokers (currently 3).\n   * @defaultValue 3\n   */\n  readonly replicationFactor?: number;\n\n  /**\n   * Time how long messages are retained on Kafka cluster;\n   *\n   * We recommend 30 days for general events and 7 days for sensor events and other high-load cases.\n   * The soft limit is 3 to 30 days but can be increased upon requests.\n   * @defaultValue 7 days\n   */\n  readonly retention?: Duration;\n\n  /**\n   * If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion.\n   * If set to 'true', it will be deleted immediately after stack deletion.\n   * @defaultValue false\n   */\n  readonly instantDeletionEnabled?: boolean;\n\n  /**\n   * The metadata of the topic.\n   */\n  readonly metadata: KafkaTopicMetaData;\n\n  /**\n   * The permissions to access to the topic's data.\n   */\n  readonly acl: KafkaAclStatement;\n\n  /**\n   * Specify whether the topic is log compacted or not.\n   */\n  readonly isLogCompacted: boolean;\n\n  /**\n   * Must only be provided if 'isLogCompacted' is 'true'.\n   * @defaultValue undefined\n   */\n  readonly logCompactionProperties?: LogCompactionProperties;\n\n  /**\n   * The maximum compaction lag in milliseconds.\n   *\n   * The maximum time a message can be delayed before it is compacted.\n   * @defaultValue 9223372036854775807\n   */\n  readonly maxCompactionLagMs?: number;\n}\n\n/**\n * The current service limits are configured in the topic manager.\n * If you need to increase the limits for your service, please contact CLAID.\n */\nexport interface KafkaTopicV4Props {\n  /**\n   * The unique name of the topic; has to match pattern [A-Za-z0-9.-]+\n   */\n  readonly name: string;\n\n  /**\n   * Defines degree of parallelism of the topic; should be increased for\n   * large expected loads (e.g., 25 for rio.asset-iot-events).\n   * The soft limit is 10 partitions but can be increased upon requests.\n   */\n  readonly numberOfPartitions: number;\n\n  /**\n   * Defines degree of replication of messages; has to be between 1 and the number of brokers (currently 3).\n   * @defaultValue 3\n   */\n  readonly replicationFactor?: number;\n\n  /**\n   * Time how long messages are retained on Kafka cluster;\n   *\n   * We recommend 30 days for general events and 7 days for sensor events and other high-load cases.\n   * The soft limit is 3 to 30 days but can be increased upon requests.\n   * @defaultValue 7 days\n   */\n  readonly retention?: Duration;\n\n  /**\n   * If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion.\n   * If set to 'true', it will be deleted immediately after stack deletion.\n   * @defaultValue false\n   */\n  readonly instantDeletionEnabled?: boolean;\n\n  /**\n   * The metadata of the topic.\n   */\n  readonly metadata: KafkaTopicMetaDataV4;\n\n  /**\n   * The permissions to access to the topic's data.\n   */\n  readonly acl: KafkaAclStatement;\n\n  /**\n   * Specify whether the topic is log compacted or not.\n   */\n  readonly isLogCompacted: boolean;\n\n  /**\n   * Must only be provided if 'isLogCompacted' is 'true'.\n   * @defaultValue undefined\n   */\n  readonly logCompactionProperties?: LogCompactionProperties;\n\n  /**\n   * Specify whether the topic should be backed up automatically or not.\n   * It could just be enabled, if the topic is compacted and the RecoveryPolicy is 'recoverable'.\n   *\n   * @defaultValue undefined\n   */\n  readonly managedBackupEnabled?: boolean;\n\n  /**\n     * The maximum compaction lag in milliseconds.\n     *\n     * The maximum time a message can be delayed before it is compacted.\n     * @defaultValue 9223372036854775807\n     */\n  readonly maxCompactionLagMs?: number;\n}\n\n/**\n * The Topics target audience\n */\nexport type TopicAudience = 'component-internal' | 'company-internal';\n\n/**\n * The Topics recovery policy guaranteed by the producer\n */\nexport type TopicRecoveryPolicy = 'none' | 'recoverable';\n\n/**\n * Construct to create a kafka topic.\n *\n * @deprecated use {@link KafkaTopicV4} instead\n */\nexport class KafkaTopic extends Construct {\n\n  constructor(scope: Construct, id: string, props: KafkaTopicProps) {\n    super(scope, id);\n\n\n    Annotations.of(this).addDeprecation('KafkaTopic', \"Use 'KafkaTopicV4'!\");\n\n    new CfnResource(this, 'KafkaTopic', {\n      type: 'Custom::KafkaTopic',\n      properties: {\n        ...mapProperties(this, props),\n        Version: '3',\n      },\n    });\n\n    this.node.addValidation(validator(props));\n  }\n}\n\n/**\n * Construct to create a kafka topic.\n */\nexport class KafkaTopicV4 extends Construct {\n\n  constructor(scope: Construct, id: string, props: KafkaTopicV4Props) {\n    super(scope, id);\n\n    new CfnResource(this, 'KafkaTopic', {\n      type: 'Custom::KafkaTopic',\n      properties: {\n        ...mapProperties(this, props),\n        Version: '4',\n        Audience: props.metadata.audience,\n        RecoveryPolicy: props.metadata.recoveryPolicy,\n        ManagedBackupEnabled: props.managedBackupEnabled,\n      },\n    });\n\n    this.node.addValidation(validator(props));\n    this.node.addValidation(backupPropertiesValidator(props));\n  }\n}\n\nconst validator = (props: KafkaTopicProps) => {\n  return {\n    validate: (): string[] => {\n      const result = [];\n\n      if (!props.name.match(/^[A-Za-z0-9.-]+$/)) {\n        result.push('Invalid [name]: expecting topic name to match the reg exp `[A-Za-z0-9.-]+`.');\n      }\n\n      if (!Number.isInteger(props.numberOfPartitions) || props.numberOfPartitions < 1) {\n        result.push(`Invalid [numberOfPartitions]: expecting number of partitions to be a positive integer but got ${props.numberOfPartitions}.`);\n      }\n\n      if (props.replicationFactor !== undefined &&\n          (!Number.isInteger(props.replicationFactor) || props.replicationFactor < 1 || props.replicationFactor > 3)) {\n        result.push('Invalid [replicationFactor]: expecting an integer between 1 and 3.');\n      }\n\n      if (props.metadata.events.length === 0) {\n        result.push('Invalid [metadata]: expecting [events] to have at least on element.');\n      }\n\n      if (!props.isLogCompacted && props.logCompactionProperties) {\n        result.push('Invalid [logCompactionProperties]: log compaction is disabled so properties must be undefined.');\n      }\n\n      if (!props.isLogCompacted && props.maxCompactionLagMs) {\n        result.push('Invalid [maxCompactionLagMs]: max compaction lag is only allowed for log compacted topics.');\n      }\n\n      return result;\n    },\n  };\n};\n\nconst backupPropertiesValidator = (props: KafkaTopicV4Props) => {\n  return {\n    validate: (): string[] => {\n      const result = [];\n\n      if (props.managedBackupEnabled && !props.isLogCompacted) {\n        result.push('Invalid [managedBackupEnabled]: managed backup can only be enabled for log compacted topics.');\n      }\n\n      if (props.managedBackupEnabled && props.metadata.recoveryPolicy !== 'recoverable') {\n        result.push('Invalid [managedBackupEnabled]: topics with managedBackupEnabled have to have recovery policy \"recoverable\".');\n      }\n\n      return result;\n    },\n  };\n\n};\n\nconst mapProperties = (scope: IConstruct, props: KafkaTopicProps | KafkaTopicV4Props) => {\n  const teamEmail = RioLandingZone.getTeamEmailParameter(scope).stringValue;\n\n  const events = props.metadata.events.map(source => {\n    new KafkaEventSpec(scope, `${source.eventName.replace(/\\./g, '_')}-EventSpec`, { source });\n    return source.eventName;\n  });\n\n  const deleteRetentionDuration = props.logCompactionProperties?.deleteRetention ?? Duration.days(7);\n  if (props.acl.delete != undefined && props.acl.delete.length > 0) {\n    const annotations = cdk.Annotations.of(cdk.Stack.of(scope));\n    annotations.addWarningV2(\n      `@rio-cloud/cdk-v2-constructs/kafka/kafka-topic/${props.name}/DeletionPolicy`,\n      `\n ❌ You have set \"delete\" permission for kafka-topic ${props.name}. You probably do not need this. Please use this only if you know what you are doing.\n`,\n    );\n  }\n  return {\n    ServiceToken: 'arn:aws:sns:eu-west-1:186993757734:dp-topic-manager-sns-topic',\n    TopicName: props.name,\n    Description: props.metadata.description,\n    Events: events,\n    NumberOfPartitions: props.numberOfPartitions,\n    ReplicationFactor: props.replicationFactor ?? 3,\n    RetentionMs: (props.retention ?? Duration.days(7)).toMilliseconds(),\n    DeleteRetentionMs: props.isLogCompacted ? deleteRetentionDuration.toMilliseconds() : undefined,\n    InstantDeletionEnabled: props.instantDeletionEnabled ?? false,\n    CleanupPolicy: props.isLogCompacted ? 'compact' : 'delete',\n    TeamEmail: teamEmail,\n    MaxCompactionLagMs: props.maxCompactionLagMs,\n    ACL: {\n      Read: props.acl.read,\n      Write: props.acl.write,\n      Delete: props.acl.delete,\n    },\n  };\n};\n"]}
|
package/package.json
CHANGED
package/version.json
CHANGED