@pdkit/github
Advanced tools
+16
-0
@@ -0,1 +1,17 @@ | ||
| # @pdkit/github [1.2.0](https://github.com/justinm/pdkit/compare/@pdkit/github@1.1.8...@pdkit/github@1.2.0) (2022-03-29) | ||
| ### Features | ||
| * reworking API for better simplicity due to typescript complications, merged react into nodejs ([62d0c44](https://github.com/justinm/pdkit/commit/62d0c44a399d13192bdee56e13012e3a78197280)) | ||
| ### Dependencies | ||
| * **@pdkit/core:** upgraded to 1.3.0 | ||
| * **@pdkit/nodejs:** upgraded to 1.2.0 | ||
| ## @pdkit/github [1.1.8](https://github.com/justinm/pdkit/compare/@pdkit/github@1.1.7...@pdkit/github@1.1.8) (2022-03-28) | ||
@@ -2,0 +18,0 @@ |
@@ -30,3 +30,3 @@ "use strict"; | ||
| if (!workflow) { | ||
| throw new core_1.ConstructError(construct, "Not a child of a GithubJob"); | ||
| throw new Error(`${construct}: Not a child of a GithubJob`); | ||
| } | ||
@@ -101,2 +101,2 @@ return workflow; | ||
| exports.GithubJob = GithubJob; | ||
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GithubJob.js","sourceRoot":"","sources":["GithubJob.ts"],"names":[],"mappings":"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","sourcesContent":["import { arrayOrScalar, ConstructError, kebabCaseKeys, XConstruct } from \"@pdkit/core\";\nimport { GithubJobStep, GithubJobStepProps } from \"./GithubJobStep\";\nimport { GithubWorkflow } from \"./GithubWorkflow\";\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    readonly cache?: string;\n    readonly registryUrl?: string;\n  };\n\n  /**\n   * Setup node.js with Yarn 2\n   * @default - not installed\n   */\n  readonly yarn?: ToolRequirement & {\n    readonly cache?: string;\n    readonly registryUrl?: string;\n  };\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 issues?: JobPermission;\n  readonly packages?: JobPermission;\n  readonly pullRequests?: JobPermission;\n  readonly repositoryProjects?: JobPermission;\n  readonly securityEvents?: JobPermission;\n  readonly statuses?: JobPermission;\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 * 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 * 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, 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 petaining 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 * A GitHub Workflow job definition.\n */\nexport interface GithubJobProps {\n  /**\n   * A jobs priority dictates which order its run in\n   */\n  readonly priority?: number;\n\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   * 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?: GithubJobStepProps[];\n\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   * 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   * 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   * 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   * 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   * 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   * 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   * 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\nexport type GithubJobImplProps = Partial<Pick<GithubJobProps, \"runsOn\">>;\n\nexport class GithubJob extends XConstruct {\n  public static of(construct: XConstruct): GithubJob {\n    const workflow = construct.node.scopes.find((s) => s instanceof this) as GithubJob;\n\n    if (!workflow) {\n      throw new ConstructError(construct, \"Not a child of a GithubJob\");\n    }\n\n    return workflow;\n  }\n\n  readonly props: GithubJobProps;\n  readonly priority: number;\n\n  constructor(scope: XConstruct, id: string, props: GithubJobProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.priority = props.priority ?? 10;\n\n    props.steps?.forEach((step, i) => new GithubJobStep(this, `Step-${i}`, step));\n  }\n\n  _beforeSynth() {\n    GithubWorkflow.of(this).addDeepFields(this.content);\n  }\n\n  get content(): Omit<GithubJobProps, \"outputs\" | \"runsOn\" | \"priority\"> & {\n    outputs: Record<string, string> | undefined;\n    \"runs-on\": string | string[] | undefined;\n    \"timeout-minutes\": number | undefined;\n    \"continue-on-error\": boolean | undefined;\n  } {\n    const steps = this.node\n      .findAll()\n      .filter((b) => b instanceof GithubJobStep)\n      .map((b) => (b as GithubJobStep).content);\n\n    return {\n      name: this.props.name,\n      needs: this.props.needs,\n      \"runs-on\": arrayOrScalar(this.props.runsOn),\n      permissions: kebabCaseKeys(this.props.permissions),\n      environment: this.props.environment,\n      concurrency: this.props.concurrency,\n      outputs: this.renderJobOutputs(),\n      env: this.props.env,\n      defaults: kebabCaseKeys(this.props.defaults),\n      if: this.props.if,\n      steps,\n      \"timeout-minutes\": this.props.timeoutMinutes,\n      strategy: this.renderJobStrategy(),\n      \"continue-on-error\": this.props.continueOnError,\n      container: this.props.container,\n      services: this.props.services,\n    };\n  }\n\n  protected renderJobOutputs() {\n    const { outputs } = this.props;\n\n    if (outputs == null) {\n      return undefined;\n    }\n\n    const rendered: Record<string, string> = {};\n    for (const [name, { stepId, outputName }] of Object.entries(outputs)) {\n      rendered[name] = `\\${{ steps.${stepId}.outputs.${outputName} }}`;\n    }\n\n    return rendered;\n  }\n\n  protected renderJobStrategy() {\n    const { strategy } = this.props;\n    if (strategy == null) {\n      return undefined;\n    }\n\n    const rendered: Record<string, unknown> = {\n      \"max-parallel\": strategy.maxParallel,\n      \"fail-fast\": strategy.failFast,\n    };\n\n    if (strategy.matrix) {\n      const matrix: Record<string, unknown> = {\n        include: strategy.matrix.include,\n        exclude: strategy.matrix.exclude,\n      };\n      for (const [key, values] of Object.entries(strategy.matrix.domain ?? {})) {\n        if (key in matrix) {\n          // A domain key was set to `include`, or `exclude`:\n          throw new Error(`Illegal job strategy matrix key: ${key}`);\n        }\n        matrix[key] = values;\n      }\n      rendered.matrix = matrix;\n    }\n\n    return rendered;\n  }\n}\n"]} | ||
| //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GithubJob.js","sourceRoot":"","sources":["GithubJob.ts"],"names":[],"mappings":"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","sourcesContent":["import { arrayOrScalar, kebabCaseKeys, XConstruct } from \"@pdkit/core\";\nimport { GithubJobStep, GithubJobStepProps } from \"./GithubJobStep\";\nimport { GithubWorkflow } from \"./GithubWorkflow\";\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    readonly cache?: string;\n    readonly registryUrl?: string;\n  };\n\n  /**\n   * Setup node.js with Yarn 2\n   * @default - not installed\n   */\n  readonly yarn?: ToolRequirement & {\n    readonly cache?: string;\n    readonly registryUrl?: string;\n  };\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 issues?: JobPermission;\n  readonly packages?: JobPermission;\n  readonly pullRequests?: JobPermission;\n  readonly repositoryProjects?: JobPermission;\n  readonly securityEvents?: JobPermission;\n  readonly statuses?: JobPermission;\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 * 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 * 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, 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 petaining 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 * A GitHub Workflow job definition.\n */\nexport interface GithubJobProps {\n  /**\n   * A jobs priority dictates which order its run in\n   */\n  readonly priority?: number;\n\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   * 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?: GithubJobStepProps[];\n\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   * 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   * 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   * 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   * 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   * 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   * 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   * 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\nexport type GithubJobImplProps = Partial<Pick<GithubJobProps, \"runsOn\">>;\n\nexport class GithubJob extends XConstruct {\n  public static of(construct: XConstruct): GithubJob {\n    const workflow = construct.node.scopes.find((s) => s instanceof this) as GithubJob;\n\n    if (!workflow) {\n      throw new Error(`${construct}: Not a child of a GithubJob`);\n    }\n\n    return workflow;\n  }\n\n  readonly props: GithubJobProps;\n  readonly priority: number;\n\n  constructor(scope: XConstruct, id: string, props: GithubJobProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.priority = props.priority ?? 10;\n\n    props.steps?.forEach((step, i) => new GithubJobStep(this, `Step-${i}`, step));\n  }\n\n  _beforeSynth() {\n    GithubWorkflow.of(this).addDeepFields(this.content);\n  }\n\n  get content(): Omit<GithubJobProps, \"outputs\" | \"runsOn\" | \"priority\"> & {\n    outputs: Record<string, string> | undefined;\n    \"runs-on\": string | string[] | undefined;\n    \"timeout-minutes\": number | undefined;\n    \"continue-on-error\": boolean | undefined;\n  } {\n    const steps = this.node\n      .findAll()\n      .filter((b) => b instanceof GithubJobStep)\n      .map((b) => (b as GithubJobStep).content);\n\n    return {\n      name: this.props.name,\n      needs: this.props.needs,\n      \"runs-on\": arrayOrScalar(this.props.runsOn),\n      permissions: kebabCaseKeys(this.props.permissions),\n      environment: this.props.environment,\n      concurrency: this.props.concurrency,\n      outputs: this.renderJobOutputs(),\n      env: this.props.env,\n      defaults: kebabCaseKeys(this.props.defaults),\n      if: this.props.if,\n      steps,\n      \"timeout-minutes\": this.props.timeoutMinutes,\n      strategy: this.renderJobStrategy(),\n      \"continue-on-error\": this.props.continueOnError,\n      container: this.props.container,\n      services: this.props.services,\n    };\n  }\n\n  protected renderJobOutputs() {\n    const { outputs } = this.props;\n\n    if (outputs == null) {\n      return undefined;\n    }\n\n    const rendered: Record<string, string> = {};\n    for (const [name, { stepId, outputName }] of Object.entries(outputs)) {\n      rendered[name] = `\\${{ steps.${stepId}.outputs.${outputName} }}`;\n    }\n\n    return rendered;\n  }\n\n  protected renderJobStrategy() {\n    const { strategy } = this.props;\n    if (strategy == null) {\n      return undefined;\n    }\n\n    const rendered: Record<string, unknown> = {\n      \"max-parallel\": strategy.maxParallel,\n      \"fail-fast\": strategy.failFast,\n    };\n\n    if (strategy.matrix) {\n      const matrix: Record<string, unknown> = {\n        include: strategy.matrix.include,\n        exclude: strategy.matrix.exclude,\n      };\n      for (const [key, values] of Object.entries(strategy.matrix.domain ?? {})) {\n        if (key in matrix) {\n          // A domain key was set to `include`, or `exclude`:\n          throw new Error(`Illegal job strategy matrix key: ${key}`);\n        }\n        matrix[key] = values;\n      }\n      rendered.matrix = matrix;\n    }\n\n    return rendered;\n  }\n}\n"]} |
@@ -18,3 +18,3 @@ "use strict"; | ||
| if (!workflow) { | ||
| throw new core_1.ConstructError(construct, "Not a child of a GithubWorkflow"); | ||
| throw new Error(`${construct}: Not a child of a GithubWorkflow`); | ||
| } | ||
@@ -42,2 +42,2 @@ return workflow; | ||
| exports.GithubWorkflow = GithubWorkflow; | ||
| //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiR2l0aHViV29ya2Zsb3cuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJHaXRodWJXb3JrZmxvdy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxzQ0FBa0Y7QUFFbEYsMkNBQXdEO0FBOEJ4RCxNQUFhLGNBQWUsU0FBUSxlQUFRO0lBYTFDLFlBQVksS0FBaUIsRUFBRSxFQUFVLEVBQUUsS0FBMEI7UUFDbkUsS0FBSyxDQUFDLEtBQUssRUFBRSxxQkFBcUIsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUU1QyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUVuQixJQUFJLEtBQUssSUFBSSxLQUFLLENBQUMsSUFBSSxFQUFFO1lBQ3ZCLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUM7WUFFeEIsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLElBQUkscUJBQVMsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDekU7SUFDSCxDQUFDO0lBdEJNLE1BQU0sQ0FBQyxFQUFFLENBQUMsU0FBcUI7UUFDcEMsTUFBTSxRQUFRLEdBQUcsU0FBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFlBQVksSUFBSSxDQUFtQixDQUFDO1FBRXhGLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixNQUFNLElBQUkscUJBQWMsQ0FBQyxTQUFTLEVBQUUsaUNBQWlDLENBQUMsQ0FBQztTQUN4RTtRQUVELE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7SUFnQkQsSUFBSSxPQUFPOztRQUNULE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJO2FBQ25CLE9BQU8sRUFBRTthQUNULE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxZQUFZLHFCQUFTLENBQUM7YUFDckMsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxFQUFFO1lBQ3BCLE1BQU0sR0FBRyxHQUFHLEdBQWdCLENBQUM7WUFFN0IsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQztZQUVoQyxPQUFPLElBQUksQ0FBQztRQUNkLENBQUMsRUFBRSxFQUE2QixDQUFDLENBQUM7UUFFcEMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ3BCLEdBQUcsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUc7WUFDbkIsRUFBRSxFQUFFLElBQUEsb0JBQWEsRUFBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQztZQUNwQyxXQUFXLEVBQUUsTUFBQSxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsbUNBQUksR0FBRztZQUMxQyxJQUFJO1NBQ0wsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBNUNELHdDQTRDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdEVycm9yLCBzbmFrZUNhc2VLZXlzLCBZYW1sRmlsZSwgWENvbnN0cnVjdCB9IGZyb20gXCJAcGRraXQvY29yZVwiO1xuaW1wb3J0IHsgR2l0aHViRXZlbnRQcm9wcyB9IGZyb20gXCIuL0dpdGh1YkV2ZW50XCI7XG5pbXBvcnQgeyBHaXRodWJKb2IsIEdpdGh1YkpvYlByb3BzIH0gZnJvbSBcIi4vR2l0aHViSm9iXCI7XG5cbi8vIEBzZWUgaHR0cHM6Ly9kb2NzLmdpdGh1Yi5jb20vZW4vYWN0aW9ucy9yZWZlcmVuY2Uvd29ya2Zsb3ctc3ludGF4LWZvci1naXRodWItYWN0aW9uc1xuXG5leHBvcnQgaW50ZXJmYWNlIEdpdGh1YldvcmtmbG93UHJvcHMge1xuICAvKipcbiAgICogQ29uY3VycmVuY3kgZW5zdXJlcyB0aGF0IG9ubHkgYSBzaW5nbGUgam9iIG9yIHdvcmtmbG93IHVzaW5nIHRoZSBzYW1lIGNvbmN1cnJlbmN5IGdyb3VwIHdpbGwgcnVuIGF0IGEgdGltZS5cbiAgICpcbiAgICogQGRlZmF1bHQgZGlzYWJsZWRcbiAgICogQGV4cGVyaW1lbnRhbFxuICAgKi9cbiAgcmVhZG9ubHkgY29uY3VycmVuY3k/OiB1bmtub3duO1xuXG4gIC8qKlxuICAgKiBTZXRzIGVudmlyb25tZW50IHZhcmlhYmxlcyBmb3Igc3RlcHMgdG8gdXNlIGluIHRoZSBydW5uZXIgZW52aXJvbm1lbnQuXG4gICAqIFlvdSBjYW4gYWxzbyBzZXQgZW52aXJvbm1lbnQgdmFyaWFibGVzIGZvciB0aGUgZW50aXJlIHdvcmtmbG93IG9yIGEgam9iLlxuICAgKi9cbiAgcmVhZG9ubHkgZW52PzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcblxuICAvKipcbiAgICogQSBsaXN0IG9mIEdpdGh1YiBKb2IgZGVmaW5pdGlvbnMuIEFkZGl0aW9uYWwgam9icyBtYXkgYmUgYWRkZWQgdmlhIHRoZSBHaXRodWJKb2IgY29uc3RydWN0LlxuICAgKi9cbiAgcmVhZG9ubHkgam9icz86IFJlY29yZDxzdHJpbmcsIEdpdGh1YkpvYlByb3BzPjtcblxuICAvKipcbiAgICogQSBsaXN0IG9mIEdpdGh1YiBKb2IgZGVmaW5pdGlvbnMuIEFkZGl0aW9uYWwgam9icyBtYXkgYmUgYWRkZWQgdmlhIHRoZSBHaXRodWJKb2IgY29uc3RydWN0LlxuICAgKi9cbiAgcmVhZG9ubHkgZXZlbnRzPzogR2l0aHViRXZlbnRQcm9wcztcbn1cblxuZXhwb3J0IGNsYXNzIEdpdGh1YldvcmtmbG93IGV4dGVuZHMgWWFtbEZpbGUge1xuICBwdWJsaWMgc3RhdGljIG9mKGNvbnN0cnVjdDogWENvbnN0cnVjdCk6IEdpdGh1YldvcmtmbG93IHtcbiAgICBjb25zdCB3b3JrZmxvdyA9IGNvbnN0cnVjdC5ub2RlLnNjb3Blcy5maW5kKChzKSA9PiBzIGluc3RhbmNlb2YgdGhpcykgYXMgR2l0aHViV29ya2Zsb3c7XG5cbiAgICBpZiAoIXdvcmtmbG93KSB7XG4gICAgICB0aHJvdyBuZXcgQ29uc3RydWN0RXJyb3IoY29uc3RydWN0LCBcIk5vdCBhIGNoaWxkIG9mIGEgR2l0aHViV29ya2Zsb3dcIik7XG4gICAgfVxuXG4gICAgcmV0dXJuIHdvcmtmbG93O1xuICB9XG5cbiAgcmVhZG9ubHkgcHJvcHM6IEdpdGh1YldvcmtmbG93UHJvcHM7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IFhDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBHaXRodWJXb3JrZmxvd1Byb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGAuZ2l0aHViL3dvcmtmbG93cy8ke2lkfS55bWxgKTtcblxuICAgIHRoaXMucHJvcHMgPSBwcm9wcztcblxuICAgIGlmIChwcm9wcyAmJiBwcm9wcy5qb2JzKSB7XG4gICAgICBjb25zdCBqb2JzID0gcHJvcHMuam9icztcblxuICAgICAgT2JqZWN0LmtleXMoam9icykuZm9yRWFjaCgoa2V5KSA9PiBuZXcgR2l0aHViSm9iKHRoaXMsIGtleSwgam9ic1trZXldKSk7XG4gICAgfVxuICB9XG5cbiAgZ2V0IGNvbnRlbnQoKSB7XG4gICAgY29uc3Qgam9icyA9IHRoaXMubm9kZVxuICAgICAgLmZpbmRBbGwoKVxuICAgICAgLmZpbHRlcigoYikgPT4gYiBpbnN0YW5jZW9mIEdpdGh1YkpvYilcbiAgICAgIC5yZWR1Y2UoKGNvbGwsIGpvYikgPT4ge1xuICAgICAgICBjb25zdCBnaGogPSBqb2IgYXMgR2l0aHViSm9iO1xuXG4gICAgICAgIGNvbGxbZ2hqLm5vZGUuaWRdID0gZ2hqLmNvbnRlbnQ7XG5cbiAgICAgICAgcmV0dXJuIGNvbGw7XG4gICAgICB9LCB7fSBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPik7XG5cbiAgICByZXR1cm4gdGhpcy50cmFuc2Zvcm0oe1xuICAgICAgZW52OiB0aGlzLnByb3BzLmVudixcbiAgICAgIG9uOiBzbmFrZUNhc2VLZXlzKHRoaXMucHJvcHMuZXZlbnRzKSxcbiAgICAgIGNvbmN1cnJlbmN5OiB0aGlzLnByb3BzLmNvbmN1cnJlbmN5ID8/IFwiMVwiLFxuICAgICAgam9icyxcbiAgICB9KTtcbiAgfVxufVxuIl19 | ||
| //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiR2l0aHViV29ya2Zsb3cuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJHaXRodWJXb3JrZmxvdy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxzQ0FBa0U7QUFFbEUsMkNBQXdEO0FBOEJ4RCxNQUFhLGNBQWUsU0FBUSxlQUFRO0lBYTFDLFlBQVksS0FBaUIsRUFBRSxFQUFVLEVBQUUsS0FBMEI7UUFDbkUsS0FBSyxDQUFDLEtBQUssRUFBRSxxQkFBcUIsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUU1QyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUVuQixJQUFJLEtBQUssSUFBSSxLQUFLLENBQUMsSUFBSSxFQUFFO1lBQ3ZCLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUM7WUFFeEIsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLElBQUkscUJBQVMsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDekU7SUFDSCxDQUFDO0lBdEJNLE1BQU0sQ0FBQyxFQUFFLENBQUMsU0FBcUI7UUFDcEMsTUFBTSxRQUFRLEdBQUcsU0FBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFlBQVksSUFBSSxDQUFtQixDQUFDO1FBRXhGLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixNQUFNLElBQUksS0FBSyxDQUFDLEdBQUcsU0FBUyxtQ0FBbUMsQ0FBQyxDQUFDO1NBQ2xFO1FBRUQsT0FBTyxRQUFRLENBQUM7SUFDbEIsQ0FBQztJQWdCRCxJQUFJLE9BQU87O1FBQ1QsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUk7YUFDbkIsT0FBTyxFQUFFO2FBQ1QsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFlBQVkscUJBQVMsQ0FBQzthQUNyQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEVBQUU7WUFDcEIsTUFBTSxHQUFHLEdBQUcsR0FBZ0IsQ0FBQztZQUU3QixJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDO1lBRWhDLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQyxFQUFFLEVBQTZCLENBQUMsQ0FBQztRQUVwQyxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDcEIsR0FBRyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRztZQUNuQixFQUFFLEVBQUUsSUFBQSxvQkFBYSxFQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDO1lBQ3BDLFdBQVcsRUFBRSxNQUFBLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxtQ0FBSSxHQUFHO1lBQzFDLElBQUk7U0FDTCxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUE1Q0Qsd0NBNENDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc25ha2VDYXNlS2V5cywgWWFtbEZpbGUsIFhDb25zdHJ1Y3QgfSBmcm9tIFwiQHBka2l0L2NvcmVcIjtcbmltcG9ydCB7IEdpdGh1YkV2ZW50UHJvcHMgfSBmcm9tIFwiLi9HaXRodWJFdmVudFwiO1xuaW1wb3J0IHsgR2l0aHViSm9iLCBHaXRodWJKb2JQcm9wcyB9IGZyb20gXCIuL0dpdGh1YkpvYlwiO1xuXG4vLyBAc2VlIGh0dHBzOi8vZG9jcy5naXRodWIuY29tL2VuL2FjdGlvbnMvcmVmZXJlbmNlL3dvcmtmbG93LXN5bnRheC1mb3ItZ2l0aHViLWFjdGlvbnNcblxuZXhwb3J0IGludGVyZmFjZSBHaXRodWJXb3JrZmxvd1Byb3BzIHtcbiAgLyoqXG4gICAqIENvbmN1cnJlbmN5IGVuc3VyZXMgdGhhdCBvbmx5IGEgc2luZ2xlIGpvYiBvciB3b3JrZmxvdyB1c2luZyB0aGUgc2FtZSBjb25jdXJyZW5jeSBncm91cCB3aWxsIHJ1biBhdCBhIHRpbWUuXG4gICAqXG4gICAqIEBkZWZhdWx0IGRpc2FibGVkXG4gICAqIEBleHBlcmltZW50YWxcbiAgICovXG4gIHJlYWRvbmx5IGNvbmN1cnJlbmN5PzogdW5rbm93bjtcblxuICAvKipcbiAgICogU2V0cyBlbnZpcm9ubWVudCB2YXJpYWJsZXMgZm9yIHN0ZXBzIHRvIHVzZSBpbiB0aGUgcnVubmVyIGVudmlyb25tZW50LlxuICAgKiBZb3UgY2FuIGFsc28gc2V0IGVudmlyb25tZW50IHZhcmlhYmxlcyBmb3IgdGhlIGVudGlyZSB3b3JrZmxvdyBvciBhIGpvYi5cbiAgICovXG4gIHJlYWRvbmx5IGVudj86IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBHaXRodWIgSm9iIGRlZmluaXRpb25zLiBBZGRpdGlvbmFsIGpvYnMgbWF5IGJlIGFkZGVkIHZpYSB0aGUgR2l0aHViSm9iIGNvbnN0cnVjdC5cbiAgICovXG4gIHJlYWRvbmx5IGpvYnM/OiBSZWNvcmQ8c3RyaW5nLCBHaXRodWJKb2JQcm9wcz47XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBHaXRodWIgSm9iIGRlZmluaXRpb25zLiBBZGRpdGlvbmFsIGpvYnMgbWF5IGJlIGFkZGVkIHZpYSB0aGUgR2l0aHViSm9iIGNvbnN0cnVjdC5cbiAgICovXG4gIHJlYWRvbmx5IGV2ZW50cz86IEdpdGh1YkV2ZW50UHJvcHM7XG59XG5cbmV4cG9ydCBjbGFzcyBHaXRodWJXb3JrZmxvdyBleHRlbmRzIFlhbWxGaWxlIHtcbiAgcHVibGljIHN0YXRpYyBvZihjb25zdHJ1Y3Q6IFhDb25zdHJ1Y3QpOiBHaXRodWJXb3JrZmxvdyB7XG4gICAgY29uc3Qgd29ya2Zsb3cgPSBjb25zdHJ1Y3Qubm9kZS5zY29wZXMuZmluZCgocykgPT4gcyBpbnN0YW5jZW9mIHRoaXMpIGFzIEdpdGh1YldvcmtmbG93O1xuXG4gICAgaWYgKCF3b3JrZmxvdykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGAke2NvbnN0cnVjdH06IE5vdCBhIGNoaWxkIG9mIGEgR2l0aHViV29ya2Zsb3dgKTtcbiAgICB9XG5cbiAgICByZXR1cm4gd29ya2Zsb3c7XG4gIH1cblxuICByZWFkb25seSBwcm9wczogR2l0aHViV29ya2Zsb3dQcm9wcztcblxuICBjb25zdHJ1Y3RvcihzY29wZTogWENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IEdpdGh1YldvcmtmbG93UHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgYC5naXRodWIvd29ya2Zsb3dzLyR7aWR9LnltbGApO1xuXG4gICAgdGhpcy5wcm9wcyA9IHByb3BzO1xuXG4gICAgaWYgKHByb3BzICYmIHByb3BzLmpvYnMpIHtcbiAgICAgIGNvbnN0IGpvYnMgPSBwcm9wcy5qb2JzO1xuXG4gICAgICBPYmplY3Qua2V5cyhqb2JzKS5mb3JFYWNoKChrZXkpID0+IG5ldyBHaXRodWJKb2IodGhpcywga2V5LCBqb2JzW2tleV0pKTtcbiAgICB9XG4gIH1cblxuICBnZXQgY29udGVudCgpIHtcbiAgICBjb25zdCBqb2JzID0gdGhpcy5ub2RlXG4gICAgICAuZmluZEFsbCgpXG4gICAgICAuZmlsdGVyKChiKSA9PiBiIGluc3RhbmNlb2YgR2l0aHViSm9iKVxuICAgICAgLnJlZHVjZSgoY29sbCwgam9iKSA9PiB7XG4gICAgICAgIGNvbnN0IGdoaiA9IGpvYiBhcyBHaXRodWJKb2I7XG5cbiAgICAgICAgY29sbFtnaGoubm9kZS5pZF0gPSBnaGouY29udGVudDtcblxuICAgICAgICByZXR1cm4gY29sbDtcbiAgICAgIH0sIHt9IGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+KTtcblxuICAgIHJldHVybiB0aGlzLnRyYW5zZm9ybSh7XG4gICAgICBlbnY6IHRoaXMucHJvcHMuZW52LFxuICAgICAgb246IHNuYWtlQ2FzZUtleXModGhpcy5wcm9wcy5ldmVudHMpLFxuICAgICAgY29uY3VycmVuY3k6IHRoaXMucHJvcHMuY29uY3VycmVuY3kgPz8gXCIxXCIsXG4gICAgICBqb2JzLFxuICAgIH0pO1xuICB9XG59XG4iXX0= |
+8
-8
| { | ||
| "name": "@pdkit/github", | ||
| "version": "1.1.8", | ||
| "version": "1.2.0", | ||
| "main": "./index.js", | ||
| "scripts": { | ||
| "yalc": "yarn compile && npx yalc publish", | ||
| "lint": "eslint --ext .ts --fix --no-error-on-unmatched-pattern .", | ||
| "compile": "tsc -p ./tsconfig.json", | ||
| "clean": "find . -name \"*.js\" -not -path \"./node_modules/*\" -delete && find . -name \"*.d.ts\" -not -path \"./node_modules/*\" -delete" | ||
| "clean": "find . -name \"*.js\" -not -path \"./node_modules/*\" -delete && find . -name \"*.d.ts\" -not -path \"./node_modules/*\" -delete", | ||
| "lint": "eslint --ext .ts --fix --no-error-on-unmatched-pattern ." | ||
| }, | ||
@@ -170,7 +170,2 @@ "files": [ | ||
| }, | ||
| "dependencies": { | ||
| "@pdkit/core": "1.2.4", | ||
| "@pdkit/nodejs": "1.1.7", | ||
| "constructs": "10.0.97" | ||
| }, | ||
| "jest": { | ||
@@ -212,3 +207,8 @@ "clearMocks": true, | ||
| "preset": "ts-jest" | ||
| }, | ||
| "dependencies": { | ||
| "@pdkit/core": "1.3.0", | ||
| "@pdkit/nodejs": "1.2.0", | ||
| "constructs": "10.0.97" | ||
| } | ||
| } |
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
196021
0.17%+ Added
+ Added
- Removed
- Removed
Updated
Updated