UNPKG

projen

Version:

CDK for software projects

48 lines 18.3 kB
"use strict"; // @see https://circleci.com/docs/2.0/configuration-reference Object.defineProperty(exports, "__esModule", { value: true }); exports.PipelineParameterType = exports.JobWhen = exports.ResourceClass = exports.JobType = void 0; /** * A job may have a type of approval indicating it must be manually approved before downstream jobs may proceed * @see https://circleci.com/docs/2.0/configuration-reference/#type */ var JobType; (function (JobType) { JobType["APPROVAL"] = "approval"; })(JobType || (exports.JobType = JobType = {})); /** * The resource_class feature allows configuring CPU and RAM resources for each job. * Different resource classes are available for different executors, as described in the tables below. * @see https://circleci.com/docs/2.0/configuration-reference/#resourceclass */ var ResourceClass; (function (ResourceClass) { ResourceClass["SMALL"] = "small"; ResourceClass["MEDIUM"] = "medium"; ResourceClass["MEDIUM_PLUS"] = "medium+"; ResourceClass["LARGE_X"] = "xlarge"; ResourceClass["LARGE_2X"] = "2xlarge"; ResourceClass["LARGE_2X_PLUS"] = "2xlarge+"; })(ResourceClass || (exports.ResourceClass = ResourceClass = {})); /** * Specify when to enable or disable the step. * @see https://circleci.com/docs/2.0/configuration-reference/#steps */ var JobWhen; (function (JobWhen) { JobWhen["ALWAYS"] = "always"; JobWhen["ON_SUCCESS"] = "on_success"; JobWhen["ON_FAIL"] = "on_fail"; })(JobWhen || (exports.JobWhen = JobWhen = {})); /** * Pipeline parameter types * @see https://circleci.com/docs/2.0/reusing-config#parameter-syntax */ var PipelineParameterType; (function (PipelineParameterType) { PipelineParameterType["STRING"] = "string"; PipelineParameterType["BOOLEAN"] = "boolean"; PipelineParameterType["INTEGER"] = "integer"; PipelineParameterType["ENUM"] = "enum"; })(PipelineParameterType || (exports.PipelineParameterType = PipelineParameterType = {})); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/circleci/model.ts"],"names":[],"mappings":";AAAA,6DAA6D;;;AA2B7D;;;GAGG;AACH,IAAY,OAEX;AAFD,WAAY,OAAO;IACjB,gCAAqB,CAAA;AACvB,CAAC,EAFW,OAAO,uBAAP,OAAO,QAElB;AAED;;;;GAIG;AACH,IAAY,aAOX;AAPD,WAAY,aAAa;IACvB,gCAAe,CAAA;IACf,kCAAiB,CAAA;IACjB,wCAAuB,CAAA;IACvB,mCAAkB,CAAA;IAClB,qCAAoB,CAAA;IACpB,2CAA0B,CAAA;AAC5B,CAAC,EAPW,aAAa,6BAAb,aAAa,QAOxB;AAED;;;GAGG;AACH,IAAY,OAIX;AAJD,WAAY,OAAO;IACjB,4BAAiB,CAAA;IACjB,oCAAyB,CAAA;IACzB,8BAAmB,CAAA;AACrB,CAAC,EAJW,OAAO,uBAAP,OAAO,QAIlB;AAED;;;GAGG;AACH,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC/B,0CAAiB,CAAA;IACjB,4CAAmB,CAAA;IACnB,4CAAmB,CAAA;IACnB,sCAAa,CAAA;AACf,CAAC,EALW,qBAAqB,qCAArB,qBAAqB,QAKhC","sourcesContent":["// @see https://circleci.com/docs/2.0/configuration-reference\n\n/**\n * Used to represent objects with a dynamic key.\n * Dynamic are marked with `<>` in configuration reference like '<workflow_name>' and '<job_name>'\n * This field is required for objects with dynamic keys.\n */\ninterface INamed {\n  /** name of dynamic key **/\n  readonly identifier: string;\n}\n\n/**\n * Used for orchestrating all jobs. Each workflow consists of the workflow name as a key and a map as a value.\n * A name should be unique within the current config.yml.\n * The top-level keys for the Workflows configuration are version and jobs.\n * @see https://circleci.com/docs/2.0/configuration-reference/#workflows\n */\nexport interface Workflow extends INamed {\n  readonly jobs?: WorkflowJob[];\n  readonly triggers?: Triggers[];\n  /** when is too dynamic to be casted to interfaces. Check Docu as reference\n   * @see https://circleci.com/docs/2.0/configuration-reference/#logic-statement-examples\n   */\n  readonly when?: any;\n}\n\n/**\n * A job may have a type of approval indicating it must be manually approved before downstream jobs may proceed\n * @see https://circleci.com/docs/2.0/configuration-reference/#type\n */\nexport enum JobType {\n  APPROVAL = \"approval\",\n}\n\n/**\n * The resource_class feature allows configuring CPU and RAM resources for each job.\n * Different resource classes are available for different executors, as described in the tables below.\n * @see https://circleci.com/docs/2.0/configuration-reference/#resourceclass\n */\nexport enum ResourceClass {\n  SMALL = \"small\",\n  MEDIUM = \"medium\",\n  MEDIUM_PLUS = \"medium+\",\n  LARGE_X = \"xlarge\",\n  LARGE_2X = \"2xlarge\",\n  LARGE_2X_PLUS = \"2xlarge+\",\n}\n\n/**\n * Specify when to enable or disable the step.\n * @see https://circleci.com/docs/2.0/configuration-reference/#steps\n */\nexport enum JobWhen {\n  ALWAYS = \"always\",\n  ON_SUCCESS = \"on_success\",\n  ON_FAIL = \"on_fail\",\n}\n\n/**\n * Pipeline parameter types\n * @see https://circleci.com/docs/2.0/reusing-config#parameter-syntax\n */\nexport enum PipelineParameterType {\n  STRING = \"string\",\n  BOOLEAN = \"boolean\",\n  INTEGER = \"integer\",\n  ENUM = \"enum\",\n}\n\n/**\n * A Workflow is comprised of one or more uniquely named jobs. Jobs are specified in the jobs map,\n * see Sample 2.0 config.yml for two examples of a job map.\n * The name of the job is the key in the map, and the value is a map describing the job.\n * @see https://circleci.com/docs/2.0/configuration-reference/#jobs\n */\nexport interface Job extends INamed {}\n\n/**\n * A Job is part of Workflow. A Job can be created with {@link Job} or it can be provided by the orb\n * @see https://circleci.com/docs/2.0/configuration-reference/#jobs-in-workflow\n */\nexport interface WorkflowJob extends INamed {\n  /** A list of jobs that must succeed for the job to start. */\n  readonly requires?: string[];\n  /** A replacement for the job name. Useful when calling a job multiple times */\n  readonly name?: string;\n  /** The name of the context(s). The initial default name is org-global. Each context name must be unique. */\n  readonly context?: string[];\n  /** A job may have a type of approval indicating it must be manually approved before downstream jobs may proceed. */\n  readonly type?: JobType;\n  /** Job Filters can have the key branches or tags */\n  readonly filters?: Filter;\n  readonly matrix?: Matrix;\n  /** Parameters passed to job when referencing a job from orb */\n  readonly orbParameters?: Record<string, string | number | boolean>;\n}\n\n/**\n * Parameters are declared by name under a job, command, or executor.\n * @see https://circleci.com/docs/2.0/reusing-config#using-the-parameters-declaration\n */\nexport interface PipelineParameter {\n  /** Used to generate documentation for your orb. */\n  readonly description?: string;\n  /** The parameter type, required. */\n  readonly type: PipelineParameterType;\n  /** The default value for the parameter. If not present, the parameter is implied to be required. */\n  readonly default?: string | number | boolean;\n}\n\n/**\n * The matrix stanza allows you to run a parameterized job multiple times with different arguments.\n * @see https://circleci.com/docs/2.0/configuration-reference/#matrix-requires-version-21\n */\nexport interface Matrix {\n  /** A map of parameter names to every value the job should be called with */\n  readonly parameters?: Record<string, string[] | number[]>;\n  /** An alias for the matrix, usable from another job’s requires stanza. Defaults to the name of the job being executed */\n  readonly alias?: string;\n}\n\n/**\n * Specifies which triggers will cause this workflow to be executed.\n * Default behavior is to trigger the workflow when pushing to a branch.\n * @see https://circleci.com/docs/2.0/configuration-reference/#triggers\n */\nexport interface Triggers {\n  readonly schedule?: Schedule;\n}\n\n/**\n *  A workflow may have a schedule indicating it runs at a certain time.\n *  @see https://circleci.com/docs/2.0/configuration-reference/#schedule\n */\nexport interface Schedule {\n  /** The cron key is defined using POSIX crontab syntax. */\n  readonly cron?: string;\n  readonly filters: Filter;\n}\n\n/**\n * The branches key controls whether the current branch should have a schedule trigger created for it,\n * where current branch is the branch containing the config.yml file with the trigger stanza.\n * That is, a push on the main branch will only schedule a workflow for the main branch.\n *\n * Branches can have the keys only and ignore which either map to a single string naming a branch.\n * You may also use regular expressions to match against branches by enclosing them with /’s, or map to a list of such strings.\n * Regular expressions must match the entire string.\n *\n * Any branches that match only will run the job.\n * Any branches that match ignore will not run the job.\n * If neither only nor ignore are specified then all branches will run the job.\n * If both only and ignore are specified the only is considered before ignore.\n * @see https://circleci.com/docs/2.0/configuration-reference/#filters\n */\nexport interface Filter {\n  readonly branches?: FilterConfig;\n  readonly tags?: FilterConfig;\n}\n\n/**\n * set an inclusive or exclusive filter\n * @see https://circleci.com/docs/2.0/configuration-reference/#filters\n */\nexport interface FilterConfig {\n  /** Either a single branch specifier, or a list of branch specifiers */\n  readonly only?: string[];\n  /** Either a single branch specifier, or a list of branch specifiers */\n  readonly ignore?: string[];\n}\n\n/**\n * Each job consists of the job’s name as a key and a map as a value. A name should be case insensitive unique within a current jobs list.\n * @see https://circleci.com/docs/2.0/configuration-reference/#job_name\n */\nexport interface Job {\n  readonly docker?: Docker[];\n  readonly machine?: Machine;\n  readonly macos?: Macos;\n  /** Shell to use for execution command in all steps. Can be overridden by shell in each step */\n  readonly shell?: string;\n  /** Parameters for making a job explicitly configurable in a workflow. */\n  readonly parameters?: Record<string, PipelineParameter>;\n  /** no type support here, for syntax {@see https://circleci.com/docs/2.0/configuration-reference/#steps} */\n  readonly steps?: any[];\n  /** In which directory to run the steps. Will be interpreted as an absolute path. Default: `~/project` */\n  readonly workingDirectory?: string;\n  /** Number of parallel instances of this job to run (default: 1) */\n  readonly parallelism?: number;\n  /** A map of environment variable names and values. */\n  readonly environment?: Record<string, string | number | boolean>;\n  /** {@link ResourceClass} */\n  readonly resourceClass?: ResourceClass | string;\n  /** Enables jobs to go through a set of well-defined IP address ranges */\n  readonly circleciIpRanges?: boolean;\n}\n\n/**\n * Options for docker executor\n * @see https://circleci.com/docs/2.0/configuration-reference/#docker\n */\nexport interface Docker {\n  /** The name of a custom docker image to use */\n  readonly image: string;\n  /** The name the container is reachable by. By default, container services are accessible through localhost */\n  readonly name?: string;\n  /** The command used as executable when launching the container */\n  readonly entrypoint?: string[];\n  /** The command used as pid 1 (or args for entrypoint) when launching the container */\n  readonly command?: string[];\n  /** Which user to run commands as within the Docker container */\n  readonly user?: string;\n  /** A map of environment variable names and values */\n  readonly environment?: Record<string, string | number | boolean>;\n  /** Authentication for registries using standard docker login credentials */\n  readonly auth?: Record<string, string>;\n  /** Authentication for AWS Elastic Container Registry (ECR) */\n  readonly awsAuth?: Record<string, string>;\n}\n\nexport interface Machine {\n  /**\n   * The VM image to use.\n   * @see https://circleci.com/docs/2.0/configuration-reference/#available-machine-images\n   */\n  readonly image: string;\n  /** enable docker layer caching\n   * @see https://circleci.com/docs/2.0/configuration-reference/#available-machine-images\n   */\n  readonly dockerLayerCaching?: string;\n}\n\n/**\n * CircleCI supports running jobs on macOS, to allow you to build, test,\n * and deploy apps for macOS, iOS, tvOS and watchOS. To run a job in a macOS virtual machine,\n * you must add the macos key to the top-level configuration for the job and specify\n * the version of Xcode you would like to use.\n * @see https://circleci.com/docs/2.0/configuration-reference/#macos\n */\nexport interface Macos {\n  /** The version of Xcode that is installed on the virtual machine */\n  readonly xcode: string;\n}\n\n/**\n * Execution steps for Job\n * @see https://circleci.com/docs/2.0/configuration-reference/#steps\n */\nexport interface StepRun {\n  readonly run?: Run;\n}\n\n/**\n * Used for invoking all command-line programs, taking either a map of configuration values,\n * or, when called in its short-form, a string that will be used as both the command and name.\n * Run commands are executed using non-login shells by default,\n * so you must explicitly source any dotfiles as part of the command.\n *\n * Not used because type incompatible types in steps array\n *\n * @see https://circleci.com/docs/2.0/configuration-reference/#run\n */\nexport interface Run {\n  /** Command to run via the shell */\n  readonly command: string;\n  /** Title of the step to be shown in the CircleCI UI (default: full command) */\n  readonly name?: string;\n  /** Shell to use for execution command */\n  readonly shell?: string;\n  /** Additional environmental variables, locally scoped to command */\n  readonly environment?: string;\n  /** Whether this step should run in the background (default: false) */\n  readonly background?: string;\n  /** In which directory to run this step. Will be interpreted relative to the working_directory of the job). (default: .) */\n  readonly workingDirectory?: string;\n  /** Elapsed time the command can run without output such as “20m”, “1.25h”, “5s”. The default is 10 minutes */\n  readonly noOutputTimeout?: string;\n  /** Specify when to enable or disable the step. */\n  readonly when?: JobWhen | string;\n}\n"]}