UNPKG

@aws-cdk/aws-glue-alpha

Version:

The CDK Construct Library for AWS::Glue

152 lines 19.1 kB
"use strict"; var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) { function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; } var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value"; var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null; var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {}); var _, done = false; for (var i = decorators.length - 1; i >= 0; i--) { var context = {}; for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p]; for (var p in contextIn.access) context.access[p] = contextIn.access[p]; context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); }; var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context); if (kind === "accessor") { if (result === void 0) continue; if (result === null || typeof result !== "object") throw new TypeError("Object expected"); if (_ = accept(result.get)) descriptor.get = _; if (_ = accept(result.set)) descriptor.set = _; if (_ = accept(result.init)) initializers.unshift(_); } else if (_ = accept(result)) { if (kind === "field") initializers.unshift(_); else descriptor[key] = _; } } if (target) Object.defineProperty(target, contextIn.name, descriptor); done = true; }; var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) { var useValue = arguments.length > 2; for (var i = 0; i < initializers.length; i++) { value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg); } return useValue ? value : void 0; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.PythonShellJob = void 0; const jsiiDeprecationWarnings = require("../../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const aws_glue_1 = require("aws-cdk-lib/aws-glue"); const job_1 = require("./job"); const constants_1 = require("../constants"); const metadata_resource_1 = require("aws-cdk-lib/core/lib/metadata-resource"); const prop_injectable_1 = require("aws-cdk-lib/core/lib/prop-injectable"); /** * Python Shell Jobs class * * A Python shell job runs Python scripts as a shell and supports a Python version that * depends on the AWS Glue version you are using. * This can be used to schedule and run tasks that don't require an Apache Spark environment. */ let PythonShellJob = (() => { let _classDecorators = [prop_injectable_1.propertyInjectable]; let _classDescriptor; let _classExtraInitializers = []; let _classThis; let _classSuper = job_1.Job; var PythonShellJob = class extends _classSuper { static { _classThis = this; } static { const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0; __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers); PythonShellJob = _classThis = _classDescriptor.value; if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata }); } static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-glue-alpha.PythonShellJob", version: "2.225.0-alpha.0" }; /** Uniquely identifies this class. */ static PROPERTY_INJECTION_ID = '@aws-cdk.aws-glue-alpha.PythonShellJob'; jobArn; jobName; role; grantPrincipal; /** * PythonShellJob constructor */ constructor(scope, id, props) { super(scope, id, { physicalName: props.jobName }); try { jsiiDeprecationWarnings._aws_cdk_aws_glue_alpha_PythonShellJobProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, PythonShellJob); } throw error; } // Enhanced CDK Analytics Telemetry (0, metadata_resource_1.addConstructMetadata)(this, props); // Set up role and permissions for principal this.role = props.role; this.grantPrincipal = this.role; // Enable CloudWatch metrics and continuous logging by default as a best practice const continuousLoggingArgs = this.setupContinuousLogging(this.role, props.continuousLogging); const profilingMetricsArgs = { '--enable-metrics': '' }; const observabilityMetricsArgs = { '--enable-observability-metrics': 'true' }; // Gather executable arguments const executableArgs = this.executableArguments(props); // Combine command line arguments into a single line item const defaultArguments = { ...executableArgs, ...continuousLoggingArgs, ...profilingMetricsArgs, ...observabilityMetricsArgs, ...this.checkNoReservedArgs(props.defaultArguments), }; const jobResource = new aws_glue_1.CfnJob(this, 'Resource', { name: props.jobName, description: props.description, role: this.role.roleArn, command: { name: constants_1.JobType.PYTHON_SHELL, scriptLocation: this.codeS3ObjectUrl(props.script), pythonVersion: props.pythonVersion ? props.pythonVersion : constants_1.PythonVersion.THREE_NINE, }, glueVersion: props.glueVersion ? props.glueVersion : constants_1.GlueVersion.V3_0, maxCapacity: props.maxCapacity ? props.maxCapacity : constants_1.MaxCapacity.DPU_1_16TH, maxRetries: props.jobRunQueuingEnabled ? 0 : props.maxRetries ? props.maxRetries : 0, jobRunQueuingEnabled: props.jobRunQueuingEnabled ? props.jobRunQueuingEnabled : false, executionProperty: props.maxConcurrentRuns ? { maxConcurrentRuns: props.maxConcurrentRuns } : undefined, timeout: props.timeout?.toMinutes(), connections: props.connections ? { connections: props.connections.map((connection) => connection.connectionName) } : undefined, securityConfiguration: props.securityConfiguration?.securityConfigurationName, tags: props.tags, defaultArguments, }); const resourceName = this.getResourceNameAttribute(jobResource.ref); this.jobArn = this.buildJobArn(this, resourceName); this.jobName = resourceName; } /** * Set the executable arguments with best practices enabled by default * * @returns An array of arguments for Glue to use on execution */ executableArguments(props) { const args = {}; args['--job-language'] = constants_1.JobLanguage.PYTHON; // If no Python version set (default 3.9) or the version is set to 3.9 then set library-set argument if (!props.pythonVersion || props.pythonVersion == constants_1.PythonVersion.THREE_NINE) { // Selecting this option includes common libraries for Python 3.9 args['library-set'] = 'analytics'; } return args; } static { __runInitializers(_classThis, _classExtraInitializers); } }; return PythonShellJob = _classThis; })(); exports.PythonShellJob = PythonShellJob; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"python-shell-job.js","sourceRoot":"","sources":["python-shell-job.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnJob } from 'aws-cdk-lib/aws-glue';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Job, JobProps } from './job';\nimport { Construct } from 'constructs';\nimport { JobType, GlueVersion, PythonVersion, MaxCapacity, JobLanguage } from '../constants';\nimport { addConstructMetadata } from 'aws-cdk-lib/core/lib/metadata-resource';\nimport { propertyInjectable } from 'aws-cdk-lib/core/lib/prop-injectable';\n\n/**\n * Properties for creating a Python Shell job\n */\nexport interface PythonShellJobProps extends JobProps {\n  /**\n   * Python Version\n   * The version of Python to use to execute this job\n   * @default 3.9 for Shell Jobs\n   **/\n  readonly pythonVersion?: PythonVersion;\n\n  /**\n   * The total number of DPU to assign to the Python Job\n   *\n   * @default 0.0625\n   */\n  readonly maxCapacity?: MaxCapacity;\n\n  /**\n   * Specifies whether job run queuing is enabled for the job runs for this job.\n   * A value of true means job run queuing is enabled for the job runs.\n   * If false or not populated, the job runs will not be considered for queueing.\n   * If this field does not match the value set in the job run, then the value from\n   * the job run field will be used. This property must be set to false for flex jobs.\n   * If this property is enabled, maxRetries must be set to zero.\n   *\n   * @default false\n   */\n  readonly jobRunQueuingEnabled?: boolean;\n}\n\n/**\n * Python Shell Jobs class\n *\n * A Python shell job runs Python scripts as a shell and supports a Python version that\n * depends on the AWS Glue version you are using.\n * This can be used to schedule and run tasks that don't require an Apache Spark environment.\n */\n@propertyInjectable\nexport class PythonShellJob extends Job {\n  /** Uniquely identifies this class. */\n  public static readonly PROPERTY_INJECTION_ID: string = '@aws-cdk.aws-glue-alpha.PythonShellJob';\n  public readonly jobArn: string;\n  public readonly jobName: string;\n  public readonly role: iam.IRole;\n  public readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * PythonShellJob constructor\n   */\n  constructor(scope: Construct, id: string, props: PythonShellJobProps) {\n    super(scope, id, { physicalName: props.jobName });\n    // Enhanced CDK Analytics Telemetry\n    addConstructMetadata(this, props);\n\n    // Set up role and permissions for principal\n    this.role = props.role;\n    this.grantPrincipal = this.role;\n\n    // Enable CloudWatch metrics and continuous logging by default as a best practice\n    const continuousLoggingArgs = this.setupContinuousLogging(this.role, props.continuousLogging);\n    const profilingMetricsArgs = { '--enable-metrics': '' };\n    const observabilityMetricsArgs = { '--enable-observability-metrics': 'true' };\n\n    // Gather executable arguments\n    const executableArgs = this.executableArguments(props);\n\n    // Combine command line arguments into a single line item\n    const defaultArguments = {\n      ...executableArgs,\n      ...continuousLoggingArgs,\n      ...profilingMetricsArgs,\n      ...observabilityMetricsArgs,\n      ...this.checkNoReservedArgs(props.defaultArguments),\n    };\n\n    const jobResource = new CfnJob(this, 'Resource', {\n      name: props.jobName,\n      description: props.description,\n      role: this.role.roleArn,\n      command: {\n        name: JobType.PYTHON_SHELL,\n        scriptLocation: this.codeS3ObjectUrl(props.script),\n        pythonVersion: props.pythonVersion ? props.pythonVersion : PythonVersion.THREE_NINE,\n      },\n      glueVersion: props.glueVersion ? props.glueVersion : GlueVersion.V3_0,\n      maxCapacity: props.maxCapacity ? props.maxCapacity : MaxCapacity.DPU_1_16TH,\n      maxRetries: props.jobRunQueuingEnabled ? 0 : props.maxRetries ? props.maxRetries : 0,\n      jobRunQueuingEnabled: props.jobRunQueuingEnabled ? props.jobRunQueuingEnabled : false,\n      executionProperty: props.maxConcurrentRuns ? { maxConcurrentRuns: props.maxConcurrentRuns } : undefined,\n      timeout: props.timeout?.toMinutes(),\n      connections: props.connections ? { connections: props.connections.map((connection) => connection.connectionName) } : undefined,\n      securityConfiguration: props.securityConfiguration?.securityConfigurationName,\n      tags: props.tags,\n      defaultArguments,\n    });\n\n    const resourceName = this.getResourceNameAttribute(jobResource.ref);\n    this.jobArn = this.buildJobArn(this, resourceName);\n    this.jobName = resourceName;\n  }\n\n  /**\n   * Set the executable arguments with best practices enabled by default\n   *\n   * @returns An array of arguments for Glue to use on execution\n   */\n  private executableArguments(props: PythonShellJobProps) {\n    const args: { [key: string]: string } = {};\n    args['--job-language'] = JobLanguage.PYTHON;\n\n    // If no Python version set (default 3.9) or the version is set to 3.9 then set library-set argument\n    if (!props.pythonVersion || props.pythonVersion == PythonVersion.THREE_NINE) {\n      // Selecting this option includes common libraries for Python 3.9\n      args['library-set'] = 'analytics';\n    }\n\n    return args;\n  }\n}\n"]}