projen
Version:
CDK for software projects
34 lines • 50 kB
JavaScript
;
// @see https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions
Object.defineProperty(exports, "__esModule", { value: true });
exports.AppPermission = exports.JobPermission = void 0;
/**
* Access level for workflow permission scopes.
*/
var JobPermission;
(function (JobPermission) {
/** Read-only access */
JobPermission["READ"] = "read";
/** Read-write access */
JobPermission["WRITE"] = "write";
/** No access at all */
JobPermission["NONE"] = "none";
})(JobPermission || (exports.JobPermission = JobPermission = {}));
/**
* The permissions available for an access token for a GitHub App.
*/
var AppPermission;
(function (AppPermission) {
/** Read-only acccess */
AppPermission["READ"] = "read";
/** Read-write access */
AppPermission["WRITE"] = "write";
/**
* Read-write and admin access.
*
* Not all permissions support `admin`.
*/
AppPermission["ADMIN"] = "admin";
})(AppPermission || (exports.AppPermission = AppPermission = {}));
//#endregion
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflows-model.js","sourceRoot":"","sources":["../../src/github/workflows-model.ts"],"names":[],"mappings":";AAAA,uFAAuF;;;AAgSvF;;GAEG;AACH,IAAY,aASX;AATD,WAAY,aAAa;IACvB,uBAAuB;IACvB,8BAAa,CAAA;IAEb,wBAAwB;IACxB,gCAAe,CAAA;IAEf,uBAAuB;IACvB,8BAAa,CAAA;AACf,CAAC,EATW,aAAa,6BAAb,aAAa,QASxB;AAED;;GAEG;AACH,IAAY,aAWX;AAXD,WAAY,aAAa;IACvB,wBAAwB;IACxB,8BAAa,CAAA;IACb,wBAAwB;IACxB,gCAAe,CAAA;IACf;;;;OAIG;IACH,gCAAe,CAAA;AACjB,CAAC,EAXW,aAAa,6BAAb,aAAa,QAWxB;AAy7BD,YAAY","sourcesContent":["// @see https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions\n\nimport { GroupRunnerOptions } from \"../runner-options\";\n\nexport interface CommonJobDefinition {\n  /**\n   * The name of the job displayed on GitHub.\n   */\n  readonly name?: string;\n\n  /**\n   * Identifies any jobs that must complete successfully before this job will\n   * run. It can be a string or array of strings. If a job fails, all jobs\n   * that need it are skipped unless the jobs use a conditional expression\n   * that causes the job to continue.\n   */\n  readonly needs?: string[];\n\n  /**\n   * You can modify the default permissions granted to the GITHUB_TOKEN, adding\n   * or removing access as required, so that you only allow the minimum required\n   * access.\n   *\n   * Use `{ contents: READ }` if your job only needs to clone code.\n   *\n   * This is intentionally a required field since it is required in order to\n   * allow workflows to run in GitHub repositories with restricted default\n   * access.\n   *\n   * @see https://docs.github.com/en/actions/reference/authentication-in-a-workflow#permissions-for-the-github_token\n   */\n  readonly permissions: JobPermissions;\n\n  /**\n   * Concurrency ensures that only a single job or workflow using the same\n   * concurrency group will run at a time. A concurrency group can be any\n   * string or expression. The expression can use any context except for the\n   * secrets context.\n   *\n   * @experimental\n   */\n  readonly concurrency?: unknown;\n\n  /**\n   * You can use the if conditional to prevent a job from running unless a\n   * condition is met. You can use any supported context and expression to\n   * create a conditional.\n   */\n  readonly if?: string;\n\n  /**\n   * A strategy creates a build matrix for your jobs. You can define different\n   * variations to run each job in.\n   */\n  readonly strategy?: JobStrategy;\n}\n\n/**\n * A GitHub Workflow Job calling a reusable workflow\n *\n */\nexport interface JobCallingReusableWorkflow extends CommonJobDefinition {\n  /**\n   * The location and version of a reusable workflow file to run as a job.\n   */\n  readonly uses: string;\n\n  /**\n   * When a job is used to call a reusable workflow, you can use with to\n   * provide a map of inputs that are passed to the called workflow.\n   *\n   * Allowed expression contexts: `github`, and `needs`.\n   */\n  readonly with?: Record<string, string | boolean>;\n\n  /**\n   * When a job is used to call a reusable workflow, you can use secrets to\n   * provide a map of secrets that are passed to the called workflow.\n   *\n   * Use the 'inherit' keyword to pass all the calling workflow's secrets to the called workflow\n   */\n  readonly secrets?: string | Record<string, string>;\n}\n\n/**\n * A GitHub Workflow job definition.\n */\nexport interface Job extends CommonJobDefinition {\n  /**\n   * The type of machine to run the job on. The machine can be either a\n   * GitHub-hosted runner or a self-hosted runner.\n   *\n   * @example [\"ubuntu-latest\"]\n   */\n  readonly runsOn?: string[];\n\n  /**\n   * Github Runner Group selection options\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly runsOnGroup?: GroupRunnerOptions;\n\n  /**\n   * A job contains a sequence of tasks called steps. Steps can run commands,\n   * run setup tasks, or run an action in your repository, a public repository,\n   * or an action published in a Docker registry. Not all steps run actions,\n   * but all actions run as a step. Each step runs in its own process in the\n   * runner environment and has access to the workspace and filesystem.\n   * Because steps run in their own process, changes to environment variables\n   * are not preserved between steps. GitHub provides built-in steps to set up\n   * and complete a job.\n   */\n  readonly steps: JobStep[];\n\n  /**\n   * The environment that the job references. All environment protection rules\n   * must pass before a job referencing the environment is sent to a runner.\n   *\n   * @see https://docs.github.com/en/actions/reference/environments\n   */\n  readonly environment?: unknown;\n\n  /**\n   * A map of outputs for a job. Job outputs are available to all downstream\n   * jobs that depend on this job.\n   */\n  readonly outputs?: Record<string, JobStepOutput>;\n\n  /**\n   * A map of environment variables that are available to all steps in the\n   * job. You can also set environment variables for the entire workflow or an\n   * individual step.\n   */\n  readonly env?: Record<string, string>;\n\n  /**\n   * A map of default settings that will apply to all steps in the job. You\n   * can also set default settings for the entire workflow.\n   */\n  readonly defaults?: JobDefaults;\n\n  /**\n   * The maximum number of minutes to let a job run before GitHub\n   * automatically cancels it.\n   *\n   * @default 360\n   */\n  readonly timeoutMinutes?: number;\n\n  /**\n   * Prevents a workflow run from failing when a job fails. Set to true to\n   * allow a workflow run to pass when this job fails.\n   */\n  readonly continueOnError?: boolean;\n\n  /**\n   * A container to run any steps in a job that don't already specify a\n   * container. If you have steps that use both script and container actions,\n   * the container actions will run as sibling containers on the same network\n   * with the same volume mounts.\n   */\n  readonly container?: ContainerOptions;\n\n  /**\n   * Used to host service containers for a job in a workflow. Service\n   * containers are useful for creating databases or cache services like Redis.\n   * The runner automatically creates a Docker network and manages the life\n   * cycle of the service containers.\n   */\n  readonly services?: Record<string, ContainerOptions>;\n\n  /**\n   * Tools required for this job. Translates into `actions/setup-xxx` steps at\n   * the beginning of the job.\n   */\n  readonly tools?: Tools;\n}\n\n/**\n * Supported tools.\n */\nexport interface Tools {\n  /**\n   * Setup java (temurin distribution).\n   * @default - not installed\n   */\n  readonly java?: ToolRequirement;\n\n  /**\n   * Setup python.\n   * @default - not installed\n   */\n  readonly python?: ToolRequirement;\n\n  /**\n   * Setup golang.\n   * @default - not installed\n   */\n  readonly go?: ToolRequirement;\n\n  /**\n   * Setup node.js\n   * @default - not installed\n   */\n  readonly node?: ToolRequirement;\n\n  /**\n   * Setup .NET Core\n   * @default - not installed\n   */\n  readonly dotnet?: ToolRequirement;\n}\n\n/**\n * Version requirement for tools.\n */\nexport interface ToolRequirement {\n  readonly version: string;\n}\n\n/**\n * The available scopes and access values for workflow permissions. If you\n * specify the access for any of these scopes, all those that are not\n * specified are set to `JobPermission.NONE`, instead of the default behavior\n * when none is specified.\n */\nexport interface JobPermissions {\n  readonly actions?: JobPermission;\n  readonly checks?: JobPermission;\n  readonly contents?: JobPermission;\n  readonly deployments?: JobPermission;\n  readonly idToken?: JobPermission;\n  readonly issues?: JobPermission;\n  readonly discussions?: JobPermission;\n  readonly packages?: JobPermission;\n  readonly pages?: JobPermission;\n  readonly pullRequests?: JobPermission;\n  readonly repositoryProjects?: JobPermission;\n  readonly securityEvents?: JobPermission;\n  readonly statuses?: JobPermission;\n}\n\n/**\n * The permissions available to a GitHub App.\n *\n * Typically a token for a GitHub App has all the available scopes/permissions available to the app\n * itself; however, a more limited set of permissions can be specified. When permissions are provided,\n * **only** the specified permissions are granted to the token.\n *\n * @see https://docs.github.com/en/rest/apps/apps?apiVersion=2022-11-28#create-an-installation-access-token-for-an-app\n */\nexport interface AppPermissions {\n  readonly actions?: AppPermission;\n  readonly administration?: AppPermission;\n  readonly checks?: AppPermission;\n  readonly contents?: AppPermission;\n  readonly deployments?: AppPermission;\n  readonly environments?: AppPermission;\n  readonly issues?: AppPermission;\n  readonly metadata?: AppPermission;\n  readonly packages?: AppPermission;\n  readonly pages?: AppPermission;\n  readonly pullRequests?: AppPermission;\n  readonly repositoryAnnouncementBanners?: AppPermission;\n  readonly repositoryHooks?: AppPermission;\n  readonly repositoryProject?: AppPermission;\n  readonly secretScanningAlerts?: AppPermission;\n  readonly secrets?: AppPermission;\n  readonly securityEvents?: AppPermission;\n  readonly singleFile?: AppPermission;\n  readonly statuses?: AppPermission;\n  readonly vulnerabilityAlerts?: AppPermission;\n  readonly workflows?: AppPermission;\n  readonly members?: AppPermission;\n  readonly organizationAdministration?: AppPermission;\n  readonly organizationCustomRoles?: AppPermission;\n  readonly organizationAnnouncementBanners?: AppPermission;\n  readonly organizationHooks?: AppPermission;\n  readonly organizationPlan?: AppPermission;\n  readonly organizationProjects?: AppPermission;\n  readonly organizationPackages?: AppPermission;\n  readonly organizationSecrets?: AppPermission;\n  readonly organizationSelfHostedRunners?: AppPermission;\n  readonly orgnaizationUserBlocking?: AppPermission;\n  readonly teamDiscussions?: AppPermission;\n}\n\n/**\n * Access level for workflow permission scopes.\n */\nexport enum JobPermission {\n  /** Read-only access */\n  READ = \"read\",\n\n  /** Read-write access */\n  WRITE = \"write\",\n\n  /** No access at all */\n  NONE = \"none\",\n}\n\n/**\n * The permissions available for an access token for a GitHub App.\n */\nexport enum AppPermission {\n  /** Read-only acccess */\n  READ = \"read\",\n  /** Read-write access */\n  WRITE = \"write\",\n  /**\n   * Read-write and admin access.\n   *\n   * Not all permissions support `admin`.\n   */\n  ADMIN = \"admin\",\n}\n\n/**\n * An output binding for a job.\n */\nexport interface JobStepOutput {\n  /**\n   * The ID of the step that exposes the output.\n   */\n  readonly stepId: string;\n\n  /**\n   * The name of the job output that is being bound.\n   */\n  readonly outputName: string;\n}\n\n/**\n * Default settings for all steps in the job.\n */\nexport interface JobDefaults {\n  /** Default run settings. */\n  readonly run?: RunSettings;\n}\n\n/**\n * Run settings for a job.\n */\nexport interface RunSettings {\n  /**\n   * Which shell to use for running the step.\n   *\n   * @example \"bash\"\n   */\n  readonly shell?: string;\n\n  /**\n   * Working directory to use when running the step.\n   */\n  readonly workingDirectory?: string;\n}\n\n/**\n * Fields that describe the How, Why, When, and Who of a Step.\n * These fields can have none present, but can be present on every Step, and have no effect on one another.\n *\n * This stands in contrast to the Command (non-Configuration) fields, which are mutually exclusive, and describe the What.\n */\nexport interface StepConfiguration {\n  /**\n   * A unique identifier for the step. You can use the id to reference the\n   * step in contexts.\n   */\n  readonly id?: string;\n\n  /**\n   * You can use the if conditional to prevent a job from running unless a\n   * condition is met. You can use any supported context and expression to\n   * create a conditional.\n   */\n  readonly if?: string;\n\n  /**\n   * A name for your step to display on GitHub.\n   */\n  readonly name?: string;\n\n  /**\n   * Sets environment variables for steps to use in the runner environment.\n   * You can also set environment variables for the entire workflow or a job.\n   */\n  readonly env?: Record<string, string>;\n\n  /**\n   * Specifies a working directory for a step.\n   * Overrides a job's working directory.\n   */\n  readonly workingDirectory?: string;\n}\n\n/**\n * This contains the fields that are common amongst both:\n * - JobStep, which is a step that is part of a Job in Github Actions. This is by far the most common use case.\n * - The metadata file `action.yaml` that is used to define an Action when you are creating one. As in, if you were creating an Action to be used in a JobStep.\n * There is some overlap between the two, and this captures that overlap.\n *\n * @see https://docs.github.com/en/actions/creating-actions/metadata-syntax-for-github-actions\n */\nexport interface Step extends StepConfiguration {\n  /**\n   * Selects an action to run as part of a step in your job. An action is a\n   * reusable unit of code. You can use an action defined in the same\n   * repository as the workflow, a public repository, or in a published Docker\n   * container image.\n   */\n  readonly uses?: string;\n\n  /**\n   * Runs command-line programs using the operating system's shell. If you do\n   * not provide a name, the step name will default to the text specified in\n   * the run command.\n   */\n  readonly run?: string;\n\n  /**\n   * A map of the input parameters defined by the action. Each input parameter\n   * is a key/value pair. Input parameters are set as environment variables.\n   * The variable is prefixed with INPUT_ and converted to upper case.\n   */\n  readonly with?: Record<string, any>;\n}\n\n/**\n * These settings are unique to a JobStep from the fields contained within the metadata action.yaml file present in when creating a new GitHub Action.\n * These fields are not present in action.yml, but are in JobStep, which are using when creating workflows.\n */\nexport interface JobStepConfiguration extends StepConfiguration {\n  /**\n   * Prevents a job from failing when a step fails. Set to true to allow a job\n   * to pass when this step fails.\n   */\n  readonly continueOnError?: boolean;\n\n  /**\n   * The maximum number of minutes to run the step before killing the process.\n   */\n  readonly timeoutMinutes?: number;\n}\n\n/**\n * JobSteps run as part of a GitHub Workflow Job.\n *\n * @see https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idsteps\n */\nexport interface JobStep extends Step, JobStepConfiguration {}\n\n/**\n * A strategy creates a build matrix for your jobs. You can define different\n * variations to run each job in.\n */\nexport interface JobStrategy {\n  /**\n   * You can define a matrix of different job configurations. A matrix allows\n   * you to create multiple jobs by performing variable substitution in a\n   * single job definition. For example, you can use a matrix to create jobs\n   * for more than one supported version of a programming language, operating\n   * system, or tool. A matrix reuses the job's configuration and creates a\n   * job for each matrix you configure.\n   *\n   * A job matrix can generate a maximum of 256 jobs per workflow run. This\n   * limit also applies to self-hosted runners.\n   */\n  readonly matrix?: JobMatrix;\n\n  /**\n   * When set to true, GitHub cancels all in-progress jobs if any matrix job\n   * fails. Default: true\n   */\n  readonly failFast?: boolean;\n\n  /**\n   * The maximum number of jobs that can run simultaneously when using a\n   * matrix job strategy. By default, GitHub will maximize the number of jobs\n   * run in parallel depending on the available runners on GitHub-hosted\n   * virtual machines.\n   */\n  readonly maxParallel?: number;\n}\n\ntype JobMatrixValue = string | boolean | number;\n\n/**\n * A job matrix.\n */\nexport interface JobMatrix {\n  /**\n   * Each option you define in the matrix has a key and value. The keys you\n   * define become properties in the matrix context and you can reference the\n   * property in other areas of your workflow file. For example, if you define\n   * the key os that contains an array of operating systems, you can use the\n   * matrix.os property as the value of the runs-on keyword to create a job\n   * for each operating system.\n   */\n  readonly domain?: Record<string, string | JobMatrixValue[]>;\n\n  /**\n   * You can add additional configuration options to a build matrix job that\n   * already exists. For example, if you want to use a specific version of npm\n   * when the job that uses windows-latest and version 8 of node runs, you can\n   * use include to specify that additional option.\n   */\n  readonly include?: Array<Record<string, JobMatrixValue>>;\n\n  /**\n   * You can remove a specific configurations defined in the build matrix\n   * using the exclude option. Using exclude removes a job defined by the\n   * build matrix.\n   */\n  readonly exclude?: Array<Record<string, JobMatrixValue>>;\n}\n\n/**\n * Options pertaining to container environments.\n */\nexport interface ContainerOptions {\n  /**\n   * The Docker image to use as the container to run the action. The value can\n   * be the Docker Hub image name or a registry name.\n   */\n  readonly image: string;\n\n  /**\n   * f the image's container registry requires authentication to pull the\n   * image, you can use credentials to set a map of the username and password.\n   * The credentials are the same values that you would provide to the docker\n   * login command.\n   */\n  readonly credentials?: ContainerCredentials;\n\n  /**\n   * Sets a map of environment variables in the container.\n   */\n  readonly env?: Record<string, string>;\n\n  /**\n   * Sets an array of ports to expose on the container.\n   */\n  readonly ports?: number[];\n\n  /**\n   * Sets an array of volumes for the container to use. You can use volumes to\n   * share data between services or other steps in a job. You can specify\n   * named Docker volumes, anonymous Docker volumes, or bind mounts on the\n   * host.\n   *\n   * To specify a volume, you specify the source and destination path:\n   * `<source>:<destinationPath>`.\n   */\n  readonly volumes?: string[];\n\n  /**\n   * Additional Docker container resource options.\n   *\n   * @see https://docs.docker.com/engine/reference/commandline/create/#options\n   */\n  readonly options?: string[];\n}\n\n/**\n * Credentials to use to authenticate to Docker registries.\n */\nexport interface ContainerCredentials {\n  /** The username. */\n  readonly username: string;\n\n  /** The password. */\n  readonly password: string;\n}\n\n/**\n * The set of available triggers for GitHub Workflows.\n *\n * @see https://docs.github.com/en/actions/reference/events-that-trigger-workflows\n */\nexport interface Triggers {\n  //#region Scheduled events\n  /**\n   * You can schedule a workflow to run at specific UTC times using POSIX cron\n   * syntax. Scheduled workflows run on the latest commit on the default or\n   * base branch. The shortest interval you can run scheduled workflows is\n   * once every 5 minutes.\n   *\n   * @see https://pubs.opengroup.org/onlinepubs/9699919799/utilities/crontab.html#tag_20_25_07\n   */\n  readonly schedule?: CronScheduleOptions[];\n  //#endregion\n\n  //#region Manual events\n  /**\n   * You can configure custom-defined input properties, default input values,\n   * and required inputs for the event directly in your workflow. When the\n   * workflow runs, you can access the input values in the github.event.inputs\n   * context.\n   */\n  readonly workflowDispatch?: WorkflowDispatchOptions;\n\n  /**\n   * You can use the GitHub API to trigger a webhook event called\n   * repository_dispatch when you want to trigger a workflow for activity that\n   * happens outside of GitHub.\n   */\n  readonly repositoryDispatch?: RepositoryDispatchOptions;\n  //#endregion\n\n  //#region Workflow reuse events\n  /**\n   * Can be called from another workflow\n   * @see https://docs.github.com/en/actions/learn-github-actions/reusing-workflows\n   */\n  readonly workflowCall?: WorkflowCallOptions;\n  //#endregion\n\n  //#region Webhook events\n  /**\n   * Runs your workflow anytime the branch_protection_rule event occurs.\n   */\n  readonly branchProtectionRule?: BranchProtectionRuleOptions;\n\n  /**\n   * Runs your workflow anytime the check_run event occurs.\n   */\n  readonly checkRun?: CheckRunOptions;\n\n  /**\n   * Runs your workflow anytime the check_suite event occurs.\n   */\n  readonly checkSuite?: CheckSuiteOptions;\n\n  /**\n   * Runs your workflow anytime someone creates a branch or tag, which\n   * triggers the create event.\n   */\n  readonly create?: CreateOptions;\n\n  /**\n   * Runs your workflow anytime someone deletes a branch or tag, which\n   * triggers the delete event.\n   */\n  readonly delete?: DeleteOptions;\n\n  /**\n   * Runs your workflow anytime someone creates a deployment, which triggers\n   * the deployment event. Deployments created with a commit SHA may not have\n   * a Git ref.\n   */\n  readonly deployment?: DeploymentOptions;\n\n  /**\n   * Runs your workflow anytime a third party provides a deployment status,\n   * which triggers the deployment_status event. Deployments created with a\n   * commit SHA may not have a Git ref.\n   */\n  readonly deploymentStatus?: DeploymentStatusOptions;\n\n  /**\n   * Runs your workflow anytime the discussion event occurs. More than one activity type triggers this event.\n   * @see https://docs.github.com/en/graphql/guides/using-the-graphql-api-for-discussions\n   */\n  readonly discussion?: DiscussionOptions;\n\n  /**\n   * Runs your workflow anytime the discussion_comment event occurs. More than one activity type triggers this event.\n   * @see https://docs.github.com/en/graphql/guides/using-the-graphql-api-for-discussions\n   */\n  readonly discussionComment?: DiscussionCommentOptions;\n\n  /**\n   * Runs your workflow anytime when someone forks a repository, which\n   * triggers the fork event.\n   */\n  readonly fork?: ForkOptions;\n\n  /**\n   * Runs your workflow when someone creates or updates a Wiki page, which\n   * triggers the gollum event.\n   */\n  readonly gollum?: GollumOptions;\n\n  /**\n   * Runs your workflow anytime the issue_comment event occurs.\n   */\n  readonly issueComment?: IssueCommentOptions;\n\n  /**\n   * Runs your workflow anytime the issues event occurs.\n   */\n  readonly issues?: IssuesOptions;\n\n  /**\n   * Runs your workflow anytime the label event occurs.\n   */\n  readonly label?: LabelOptions;\n\n  /**\n   * Runs your workflow when a pull request is added to a merge queue, which\n   * adds the pull request to a merge group.\n   *\n   * @stability experimental\n   */\n  readonly mergeGroup?: MergeGroupOptions;\n\n  /**\n   * Runs your workflow anytime the milestone event occurs.\n   */\n  readonly milestone?: MilestoneOptions;\n\n  /**\n   * Runs your workflow anytime someone pushes to a GitHub Pages-enabled\n   * branch, which triggers the page_build event.\n   */\n  readonly pageBuild?: PageBuildOptions;\n\n  /**\n   * Runs your workflow anytime the project event occurs.\n   */\n  readonly project?: ProjectOptions;\n\n  /**\n   * Runs your workflow anytime the project_card event occurs.\n   */\n  readonly projectCard?: ProjectCardOptions;\n\n  /**\n   * Runs your workflow anytime the project_column event occurs.\n   */\n  readonly projectColumn?: ProjectColumnOptions;\n\n  /**\n   * Runs your workflow anytime someone makes a private repository public,\n   * which triggers the public event.\n   */\n  readonly public?: PublicOptions;\n\n  /**\n   * Runs your workflow anytime the pull_request event occurs.\n   */\n  readonly pullRequest?: PullRequestOptions;\n\n  /**\n   * Runs your workflow anytime the pull_request_review event occurs.\n   */\n  readonly pullRequestReview?: PullRequestReviewOptions;\n\n  /**\n   * Runs your workflow anytime a comment on a pull request's unified diff is\n   * modified, which triggers the pull_request_review_comment event.\n   */\n  readonly pullRequestReviewComment?: PullRequestReviewCommentOptions;\n\n  /**\n   * This event runs in the context of the base of the pull request, rather\n   * than in the merge commit as the pull_request event does. This prevents\n   * executing unsafe workflow code from the head of the pull request that\n   * could alter your repository or steal any secrets you use in your workflow.\n   * This event allows you to do things like create workflows that label and\n   * comment on pull requests based on the contents of the event payload.\n   *\n   * WARNING: The `pull_request_target` event is granted read/write repository\n   * token and can access secrets, even when it is triggered from a fork.\n   * Although the workflow runs in the context of the base of the pull request,\n   * you should make sure that you do not check out, build, or run untrusted\n   * code from the pull request with this event. Additionally, any caches\n   * share the same scope as the base branch, and to help prevent cache\n   * poisoning, you should not save the cache if there is a possibility that\n   * the cache contents were altered.\n   *\n   * @see https://securitylab.github.com/research/github-actions-preventing-pwn-requests\n   */\n  readonly pullRequestTarget?: PullRequestTargetOptions;\n\n  /**\n   * Runs your workflow when someone pushes to a repository branch, which\n   * triggers the push event.\n   */\n  readonly push?: PushOptions;\n\n  /**\n   * Runs your workflow anytime a package is published or updated.\n   */\n  readonly registryPackage?: RegistryPackageOptions;\n\n  /**\n   * Runs your workflow anytime the release event occurs.\n   */\n  readonly release?: ReleaseOptions;\n\n  /**\n   * Runs your workflow anytime the status of a Git commit changes, which\n   * triggers the status event.\n   */\n  readonly status?: StatusOptions;\n\n  /**\n   * Runs your workflow anytime the watch event occurs.\n   */\n  readonly watch?: WatchOptions;\n\n  /**\n   * This event occurs when a workflow run is requested or completed, and\n   * allows you to execute a workflow based on the finished result of another\n   * workflow. A workflow run is triggered regardless of the result of the\n   * previous workflow.\n   */\n  readonly workflowRun?: WorkflowRunOptions;\n  //#endregion\n}\n\n/**\n * CRON schedule options.\n */\nexport interface CronScheduleOptions {\n  /**\n   * @see https://pubs.opengroup.org/onlinepubs/9699919799/utilities/crontab.html#tag_20_25_07\n   */\n  readonly cron: string;\n}\n\n/**\n * Repository dispatch options.\n */\nexport interface RepositoryDispatchOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: string[];\n}\n\n/**\n * Branch Protection Rule options\n */\nexport interface BranchProtectionRuleOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"created\" | \"edited\" | \"deleted\">;\n}\n\n/**\n * Check run options.\n */\nexport interface CheckRunOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    \"create\" | \"rerequested\" | \"completed\" | \"requested_action\"\n  >;\n}\n\n/**\n * Check suite options\n */\nexport interface CheckSuiteOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"completed\" | \"requested\" | \"rerequested\">;\n}\n\n/**\n * Discussion options\n */\nexport interface DiscussionOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    | \"created\"\n    | \"edited\"\n    | \"transferred\"\n    | \"pinned\"\n    | \"unpinned\"\n    | \"labeled\"\n    | \"unlabeled\"\n    | \"locked\"\n    | \"unlocked\"\n    | \"category_changed\"\n    | \"answered\"\n    | \"unanswered\"\n  >;\n}\n\n/**\n * Discussion comment options\n */\nexport interface DiscussionCommentOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"created\" | \"edited\" | \"deleted\">;\n}\n\n/**\n * Issue comment options\n */\nexport interface IssueCommentOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"created\" | \"edited\" | \"deleted\">;\n}\n\n/**\n * Issues options\n */\nexport interface IssuesOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    | \"opened\"\n    | \"edited\"\n    | \"deleted\"\n    | \"transferred\"\n    | \"pinned\"\n    | \"unpinned\"\n    | \"closed\"\n    | \"reopened\"\n    | \"assigned\"\n    | \"unassigned\"\n    | \"labeled\"\n    | \"unlabeled\"\n    | \"locked\"\n    | \"unlocked\"\n    | \"milestoned\"\n    | \"demilestoned\"\n  >;\n}\n\n/**\n * Label options\n */\nexport interface LabelOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"created\" | \"edited\" | \"deleted\">;\n}\n\n/**\n * Merge group options.\n *\n * @stability experimental\n */\nexport interface MergeGroupOptions {\n  /**\n   * When using the merge_group events, you can configure a workflow\n   * to run on specific base branches. If not specified, all branches will\n   * trigger the workflow.\n   */\n  readonly branches?: string[];\n}\n\n/**\n * Milestone options\n */\nexport interface MilestoneOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    \"created\" | \"closed\" | \"opened\" | \"edited\" | \"deleted\"\n  >;\n}\n\n/**\n * Project options\n */\nexport interface ProjectOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    \"created\" | \"updated\" | \"closed\" | \"reopened\" | \"edited\" | \"deleted\"\n  >;\n}\n\n/**\n * Project card options\n */\nexport interface ProjectCardOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    \"created\" | \"moved\" | \"converted\" | \"edited\" | \"deleted\"\n  >;\n}\n\n/**\n * Probject column options\n */\nexport interface ProjectColumnOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"created\" | \"updated\" | \"moved\" | \"deleted\">;\n}\n\n/**\n * Pull request options\n */\nexport interface PullRequestOptions extends PushOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    | \"assigned\"\n    | \"unassigned\"\n    | \"labeled\"\n    | \"unlabeled\"\n    | \"opened\"\n    | \"edited\"\n    | \"closed\"\n    | \"reopened\"\n    | \"synchronize\"\n    | \"ready_for_review\"\n    | \"locked\"\n    | \"unlocked\"\n    | \"review_requested\"\n    | \"review_request_removed\"\n  >;\n}\n\n/**\n * Pull request review options\n */\nexport interface PullRequestReviewOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"submitted\" | \"edited\" | \"dismissed\">;\n}\n\n/**\n * Pull request review comment options\n */\nexport interface PullRequestReviewCommentOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"created\" | \"edited\" | \"deleted\">;\n}\n\n/**\n * Pull request target options.\n */\nexport interface PullRequestTargetOptions extends PushOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    | \"assigned\"\n    | \"unassigned\"\n    | \"labeled\"\n    | \"unlabeled\"\n    | \"opened\"\n    | \"edited\"\n    | \"closed\"\n    | \"reopened\"\n    | \"synchronize\"\n    | \"ready_for_review\"\n    | \"locked\"\n    | \"unlocked\"\n    | \"review_requested\"\n    | \"review_request_removed\"\n  >;\n}\n\n/**\n * Options for push-like events.\n */\nexport interface PushOptions {\n  /**\n   * When using the push, pull_request and pull_request_target events, you can configure a workflow\n   * to run on specific branches or tags. For a pull_request event, only\n   * branches and tags on the base are evaluated. If you define only tags or\n   * only branches, the workflow won't run for events affecting the undefined\n   * Git ref.\n   *\n   * @see https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet\n   */\n  readonly branches?: string[];\n\n  /**\n   * When using the push, pull_request and pull_request_target events, you can configure a workflow\n   * to run on specific branches or tags. For a pull_request event, only\n   * branches and tags on the base are evaluated. If you define only tags or\n   * only branches, the workflow won't run for events affecting the undefined\n   * Git ref.\n   *\n   * @see https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet\n   */\n  readonly tags?: string[];\n\n  /**\n   * When using the push, pull_request and pull_request_target events, you can configure a workflow\n   * to run when at least one file does not match paths-ignore or at least one\n   * modified file matches the configured paths. Path filters are not\n   * evaluated for pushes to tags.\n   *\n   * @see https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet\n   */\n  readonly paths?: string[];\n}\n\n/**\n * Registry package options\n */\nexport interface RegistryPackageOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"published\" | \"updated\">;\n}\n\n/**\n * Release options\n */\nexport interface ReleaseOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\n    | \"published\"\n    | \"unpublished\"\n    | \"created\"\n    | \"edited\"\n    | \"deleted\"\n    | \"prereleased\"\n    | \"released\"\n  >;\n}\n\n/**\n * Watch options\n */\nexport interface WatchOptions {\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"started\">;\n}\n\n/**\n * Workflow run options\n */\nexport interface WorkflowRunOptions {\n  /**\n   * Which workflow to trigger on.\n   *\n   * @defaults - any workflows\n   */\n  readonly workflows?: Array<string>;\n  /**\n   * Which activity types to trigger on.\n   *\n   * @defaults - all activity types\n   */\n  readonly types?: Array<\"completed\" | \"requested\">;\n  /**\n   * Which branches or branch-ignore to limit the trigger to.\n   *\n   * @defaults - no branch limits\n   */\n  readonly branches?: Array<string>;\n}\n\n//#region Empty Options (future-proofing the API)\n/**\n * The Workflow dispatch event accepts no options.\n */\nexport interface WorkflowDispatchOptions {}\n\n/**\n * The Workflow Call event accepts no options.\n */\nexport interface WorkflowCallOptions {}\n\n/**\n * The Create event accepts no options.\n */\nexport interface CreateOptions {}\n\n/**\n * The Delete event accepts no options.\n */\nexport interface DeleteOptions {}\n\n/**\n * The Deployment event accepts no options.\n */\nexport interface DeploymentOptions {}\n\n/**\n * The Deployment status event accepts no options.\n */\nexport interface DeploymentStatusOptions {}\n\n/**\n * The Fork event accepts no options.\n */\nexport interface ForkOptions {}\n\n/**\n * The Gollum event accepts no options.\n */\nexport interface GollumOptions {}\n\n/**\n * The Page build event accepts no options.\n */\nexport interface PageBuildOptions {}\n\n/**\n * The Public event accepts no options.\n */\nexport interface PublicOptions {}\n\n/**\n * The Status event accepts no options.\n */\nexport interface StatusOptions {}\n//#endregion\n"]}