UNPKG

12.4 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.SplunkLogDriver = exports.SplunkLogFormat = void 0;
5const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const log_driver_1 = require("./log-driver");
8const utils_1 = require("./utils");
9/**
10 * Log Message Format
11 */
12var SplunkLogFormat;
13(function (SplunkLogFormat) {
14 SplunkLogFormat["INLINE"] = "inline";
15 SplunkLogFormat["JSON"] = "json";
16 SplunkLogFormat["RAW"] = "raw";
17})(SplunkLogFormat = exports.SplunkLogFormat || (exports.SplunkLogFormat = {}));
18/**
19 * A log driver that sends log information to splunk Logs.
20 */
21class SplunkLogDriver extends log_driver_1.LogDriver {
22 /**
23 * Constructs a new instance of the SplunkLogDriver class.
24 *
25 * @param props the splunk log driver configuration options.
26 */
27 constructor(props) {
28 super();
29 this.props = props;
30 try {
31 jsiiDeprecationWarnings._aws_cdk_aws_ecs_SplunkLogDriverProps(props);
32 }
33 catch (error) {
34 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
35 Error.captureStackTrace(error, this.constructor);
36 }
37 throw error;
38 }
39 if (!props.token && !props.secretToken) {
40 throw new Error('Please provide either token or secretToken.');
41 }
42 if (props.gzipLevel) {
43 utils_1.ensureInRange(props.gzipLevel, -1, 9);
44 }
45 }
46 /**
47 * Called when the log driver is configured on a container
48 */
49 bind(_scope, _containerDefinition) {
50 var _b;
51 try {
52 jsiiDeprecationWarnings._aws_cdk_aws_ecs_ContainerDefinition(_containerDefinition);
53 }
54 catch (error) {
55 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
56 Error.captureStackTrace(error, this.bind);
57 }
58 throw error;
59 }
60 const options = utils_1.stringifyOptions({
61 'splunk-token': (_b = this.props.token) === null || _b === void 0 ? void 0 : _b.unsafeUnwrap(),
62 'splunk-url': this.props.url,
63 'splunk-source': this.props.source,
64 'splunk-sourcetype': this.props.sourceType,
65 'splunk-index': this.props.index,
66 'splunk-capath': this.props.caPath,
67 'splunk-caname': this.props.caName,
68 'splunk-insecureskipverify': this.props.insecureSkipVerify,
69 'splunk-format': this.props.format,
70 'splunk-verify-connection': this.props.verifyConnection,
71 'splunk-gzip': this.props.gzip,
72 'splunk-gzip-level': this.props.gzipLevel,
73 ...utils_1.renderCommonLogDriverOptions(this.props),
74 });
75 return {
76 logDriver: 'splunk',
77 options,
78 secretOptions: this.props.secretToken && utils_1.renderLogDriverSecretOptions({ 'splunk-token': this.props.secretToken }, _containerDefinition.taskDefinition),
79 };
80 }
81}
82exports.SplunkLogDriver = SplunkLogDriver;
83_a = JSII_RTTI_SYMBOL_1;
84SplunkLogDriver[_a] = { fqn: "@aws-cdk/aws-ecs.SplunkLogDriver", version: "1.156.1" };
85//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"splunk-log-driver.js","sourceRoot":"","sources":["splunk-log-driver.ts"],"names":[],"mappings":";;;;;;AAGA,6CAA0D;AAC1D,mCAAsH;AAMtH;;GAEG;AACH,IAAY,eAIX;AAJD,WAAY,eAAe;IACzB,oCAAiB,CAAA;IACjB,gCAAa,CAAA;IACb,8BAAW,CAAA;AACb,CAAC,EAJW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAI1B;AAgHD;;GAEG;AACH,MAAa,eAAgB,SAAQ,sBAAS;IAC5C;;;;OAIG;IACH,YAA6B,KAA2B;QACtD,KAAK,EAAE,CAAC;QADmB,UAAK,GAAL,KAAK,CAAsB;;;;;;;;;;QAGtD,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;YACtC,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;SAChE;QACD,IAAI,KAAK,CAAC,SAAS,EAAE;YACnB,qBAAa,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SACvC;KACF;IAED;;OAEG;IACI,IAAI,CAAC,MAAqB,EAAE,oBAAyC;;;;;;;;;;;QAC1E,MAAM,OAAO,GAAG,wBAAgB,CAAC;YAC/B,cAAc,QAAE,IAAI,CAAC,KAAK,CAAC,KAAK,0CAAE,YAAY,EAAE;YAChD,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG;YAC5B,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YAClC,mBAAmB,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU;YAC1C,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK;YAChC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YAClC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YAClC,2BAA2B,EAAE,IAAI,CAAC,KAAK,CAAC,kBAAkB;YAC1D,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM;YAClC,0BAA0B,EAAE,IAAI,CAAC,KAAK,CAAC,gBAAgB;YACvD,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI;YAC9B,mBAAmB,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YACzC,GAAG,oCAA4B,CAAC,IAAI,CAAC,KAAK,CAAC;SAC5C,CAAC,CAAC;QAEH,OAAO;YACL,SAAS,EAAE,QAAQ;YACnB,OAAO;YACP,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,oCAA4B,CAAC,EAAE,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,oBAAoB,CAAC,cAAc,CAAC;SACvJ,CAAC;KACH;;AA1CH,0CA2CC","sourcesContent":["import { SecretValue } from '@aws-cdk/core';\nimport { ContainerDefinition, Secret } from '../container-definition';\nimport { BaseLogDriverProps } from './base-log-driver';\nimport { LogDriver, LogDriverConfig } from './log-driver';\nimport { ensureInRange, renderCommonLogDriverOptions, renderLogDriverSecretOptions, stringifyOptions } from './utils';\n\n// v2 - keep this import as a separate section to reduce merge conflict when forward merging with the v2 branch.\n// eslint-disable-next-line\nimport { Construct as CoreConstruct } from '@aws-cdk/core';\n\n/**\n * Log Message Format\n */\nexport enum SplunkLogFormat {\n  INLINE = 'inline',\n  JSON = 'json',\n  RAW = 'raw'\n}\n\n/**\n * Specifies the splunk log driver configuration options.\n *\n * [Source](https://docs.docker.com/config/containers/logging/splunk/)\n */\nexport interface SplunkLogDriverProps extends BaseLogDriverProps {\n  /**\n   * Splunk HTTP Event Collector token.\n   *\n   * The splunk-token is added to the Options property of the Log Driver Configuration. So the secret value will be resolved and\n   * viewable in plain text in the console.\n   *\n   * Please provide at least one of `token` or `secretToken`.\n   * @deprecated Use {@link SplunkLogDriverProps.secretToken} instead.\n   * @default - token not provided.\n   */\n  readonly token?: SecretValue;\n\n  /**\n   * Splunk HTTP Event Collector token (Secret).\n   *\n   * The splunk-token is added to the SecretOptions property of the Log Driver Configuration. So the secret value will not be\n   * resolved or viewable as plain text.\n   *\n   * Please provide at least one of `token` or `secretToken`.\n   * @default - If secret token is not provided, then the value provided in `token` will be used.\n   */\n  readonly secretToken?: Secret;\n\n  /**\n   * Path to your Splunk Enterprise, self-service Splunk Cloud instance, or Splunk\n   * Cloud managed cluster (including port and scheme used by HTTP Event Collector)\n   * in one of the following formats: https://your_splunk_instance:8088 or\n   * https://input-prd-p-XXXXXXX.cloud.splunk.com:8088 or https://http-inputs-XXXXXXXX.splunkcloud.com.\n   */\n  readonly url: string;\n\n  /**\n   * Event source.\n   *\n   * @default - source not set.\n   */\n  readonly source?: string;\n\n  /**\n   * Event source type.\n   *\n   * @default - sourceType not set.\n   */\n  readonly sourceType?: string;\n\n  /**\n   * Event index.\n   *\n   * @default - index not set.\n   */\n  readonly index?: string;\n\n  /**\n   * Path to root certificate.\n   *\n   * @default - caPath not set.\n   */\n  readonly caPath?: string;\n\n  /**\n   * Name to use for validating server certificate.\n   *\n   * @default - The hostname of the splunk-url\n   */\n  readonly caName?: string;\n\n  /**\n   * Ignore server certificate validation.\n   *\n   * @default - insecureSkipVerify not set.\n   */\n  readonly insecureSkipVerify?: string;\n\n  /**\n   * Message format. Can be inline, json or raw.\n   *\n   * @default - inline\n   */\n  readonly format?: SplunkLogFormat;\n\n  /**\n   * Verify on start, that docker can connect to Splunk server.\n   *\n   * @default - true\n   */\n  readonly verifyConnection?: boolean;\n\n  /**\n   * Enable/disable gzip compression to send events to Splunk Enterprise or Splunk\n   * Cloud instance.\n   *\n   * @default - false\n   */\n  readonly gzip?: boolean;\n\n  /**\n   * Set compression level for gzip. Valid values are -1 (default), 0 (no compression),\n   * 1 (best speed) ... 9 (best compression).\n   *\n   * @default - -1 (Default Compression)\n   */\n  readonly gzipLevel?: number;\n}\n\n/**\n * A log driver that sends log information to splunk Logs.\n */\nexport class SplunkLogDriver extends LogDriver {\n  /**\n   * Constructs a new instance of the SplunkLogDriver class.\n   *\n   * @param props the splunk log driver configuration options.\n   */\n  constructor(private readonly props: SplunkLogDriverProps) {\n    super();\n\n    if (!props.token && !props.secretToken) {\n      throw new Error('Please provide either token or secretToken.');\n    }\n    if (props.gzipLevel) {\n      ensureInRange(props.gzipLevel, -1, 9);\n    }\n  }\n\n  /**\n   * Called when the log driver is configured on a container\n   */\n  public bind(_scope: CoreConstruct, _containerDefinition: ContainerDefinition): LogDriverConfig {\n    const options = stringifyOptions({\n      'splunk-token': this.props.token?.unsafeUnwrap(), // Safe usage\n      'splunk-url': this.props.url,\n      'splunk-source': this.props.source,\n      'splunk-sourcetype': this.props.sourceType,\n      'splunk-index': this.props.index,\n      'splunk-capath': this.props.caPath,\n      'splunk-caname': this.props.caName,\n      'splunk-insecureskipverify': this.props.insecureSkipVerify,\n      'splunk-format': this.props.format,\n      'splunk-verify-connection': this.props.verifyConnection,\n      'splunk-gzip': this.props.gzip,\n      'splunk-gzip-level': this.props.gzipLevel,\n      ...renderCommonLogDriverOptions(this.props),\n    });\n\n    return {\n      logDriver: 'splunk',\n      options,\n      secretOptions: this.props.secretToken && renderLogDriverSecretOptions({ 'splunk-token': this.props.secretToken }, _containerDefinition.taskDefinition),\n    };\n  }\n}\n"]}
\No newline at end of file