UNPKG

projen

Version:

CDK for software projects

270 lines • 44.5 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.Dependabot = exports.VersioningStrategy = exports.DependabotScheduleInterval = exports.DependabotGroupUpdateType = exports.DependabotGroupDependencyType = exports.DependabotGroupAppliesTo = exports.DependabotRegistryType = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const component_1 = require("../component"); const util_1 = require("../util"); const yaml_1 = require("../yaml"); /** * Each configuration type requires you to provide particular settings. * Some types allow more than one way to connect * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#configuration-options-for-private-registries */ var DependabotRegistryType; (function (DependabotRegistryType) { /** * The composer-repository type supports username and password. * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#composer-repository */ DependabotRegistryType["COMPOSER_REGISTRY"] = "composer-registry"; /** * The docker-registry type supports username and password. * The docker-registry type can also be used to pull from Amazon ECR using static AWS credentials * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#docker-registry */ DependabotRegistryType["DOCKER_REGISTRY"] = "docker-registry"; /** * The git type supports username and password * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#git */ DependabotRegistryType["GIT"] = "git"; /** * The hex-organization type supports organization and key * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#hex-organization */ DependabotRegistryType["HEX_ORGANIZATION"] = "hex-organization"; /** * The maven-repository type supports username and password, or token * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#maven-repository */ DependabotRegistryType["MAVEN_REPOSITORY"] = "maven-repository"; /** * The npm-registry type supports username and password, or token * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#npm-registry */ DependabotRegistryType["NPM_REGISTRY"] = "npm-registry"; /** * The nuget-feed type supports username and password, or token * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#nuget-feed */ DependabotRegistryType["NUGET_FEED"] = "nuget-feed"; /** * The python-index type supports username and password, or token * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#python-index */ DependabotRegistryType["PYTHON_INDEX"] = "python-index"; /** * The rubygems-server type supports username and password, or token * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#rubygems-server */ DependabotRegistryType["RUBYGEMS_SERVER"] = "rubygems-server"; /** * The terraform-registry type supports a token * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#terraform-registry */ DependabotRegistryType["TERRAFORM_REGISTRY"] = "terraform-registry"; })(DependabotRegistryType || (exports.DependabotRegistryType = DependabotRegistryType = {})); /** * The type of update a group applies to. */ var DependabotGroupAppliesTo; (function (DependabotGroupAppliesTo) { /** * Apply only to version updates. */ DependabotGroupAppliesTo["VERSION_UPDATES"] = "version-updates"; /** * Apply only to security updates. */ DependabotGroupAppliesTo["SECURITY_UPDATES"] = "security-updates"; })(DependabotGroupAppliesTo || (exports.DependabotGroupAppliesTo = DependabotGroupAppliesTo = {})); /** * The type of dependency a group may be limited to. */ var DependabotGroupDependencyType; (function (DependabotGroupDependencyType) { /** * Include only dependencies in the "Development dependency group". */ DependabotGroupDependencyType["DEVELOPMENT"] = "development"; /** * Include only dependencies in the "Production dependency group". */ DependabotGroupDependencyType["PRODUCTION"] = "production"; })(DependabotGroupDependencyType || (exports.DependabotGroupDependencyType = DependabotGroupDependencyType = {})); /** * The semantic versioning levels a group may be limited to. */ var DependabotGroupUpdateType; (function (DependabotGroupUpdateType) { /** * Include major releases. */ DependabotGroupUpdateType["MAJOR"] = "major"; /** * Include minor releases. */ DependabotGroupUpdateType["MINOR"] = "minor"; /** * Include patch releases. */ DependabotGroupUpdateType["PATCH"] = "patch"; })(DependabotGroupUpdateType || (exports.DependabotGroupUpdateType = DependabotGroupUpdateType = {})); /** * How often to check for new versions and raise pull requests for version * updates. */ var DependabotScheduleInterval; (function (DependabotScheduleInterval) { /** * Runs on every weekday, Monday to Friday. */ DependabotScheduleInterval["DAILY"] = "daily"; /** * Runs once each week. By default, this is on Monday. */ DependabotScheduleInterval["WEEKLY"] = "weekly"; /** * Runs once each month. This is on the first day of the month. */ DependabotScheduleInterval["MONTHLY"] = "monthly"; })(DependabotScheduleInterval || (exports.DependabotScheduleInterval = DependabotScheduleInterval = {})); /** * The strategy to use when edits manifest and lock files. */ var VersioningStrategy; (function (VersioningStrategy) { /** * Only create pull requests to update lockfiles updates. Ignore any new * versions that would require package manifest changes. */ VersioningStrategy["LOCKFILE_ONLY"] = "lockfile-only"; /** * - For apps, the version requirements are increased. * - For libraries, the range of versions is widened. */ VersioningStrategy["AUTO"] = "auto"; /** * Relax the version requirement to include both the new and old version, when * possible. */ VersioningStrategy["WIDEN"] = "widen"; /** * Always increase the version requirement to match the new version. */ VersioningStrategy["INCREASE"] = "increase"; /** * Increase the version requirement only when required by the new version. */ VersioningStrategy["INCREASE_IF_NECESSARY"] = "increase-if-necessary"; })(VersioningStrategy || (exports.VersioningStrategy = VersioningStrategy = {})); /** * Defines dependabot configuration for node projects. * * Since module versions are managed in projen, the versioning strategy will be * configured to "lockfile-only" which means that only updates that can be done * on the lockfile itself will be proposed. */ class Dependabot extends component_1.Component { constructor(github, options = {}) { super(github.project); const project = github.project; this.allow = []; this.ignore = []; this.ignoresProjen = options.ignoreProjen ?? true; const registries = options.registries ? (0, util_1.kebabCaseKeys)(options.registries) : undefined; for (const [name, group] of Object.entries(options.groups ?? {})) { validateGroup(name, group); } const groups = options.groups ? (0, util_1.kebabCaseKeys)(options.groups) : undefined; this.config = { version: 2, registries, updates: [ { "package-ecosystem": "npm", "versioning-strategy": "lockfile-only", directory: "/", schedule: { interval: options.scheduleInterval ?? DependabotScheduleInterval.DAILY, }, allow: () => (this.allow.length > 0 ? this.allow : undefined), ignore: () => (this.ignore.length > 0 ? this.ignore : undefined), labels: options.labels ? options.labels : undefined, registries: registries ? Object.keys(registries) : undefined, groups: groups ? groups : undefined, assignees: options.assignees && options.assignees.length > 0 ? options.assignees : undefined, reviewers: options.reviewers && options.reviewers.length > 0 ? options.reviewers : undefined, "open-pull-requests-limit": options.openPullRequestsLimit !== undefined ? options.openPullRequestsLimit : undefined, "target-branch": options.targetBranch, cooldown: options.cooldown ? (0, util_1.kebabCaseKeys)(options.cooldown) : undefined, }, ], }; new yaml_1.YamlFile(project, ".github/dependabot.yml", { obj: this.config, committed: true, }); for (const i of options.allow ?? []) { this.addAllow(i.dependencyName); } for (const i of options.ignore ?? []) { this.addIgnore(i.dependencyName, ...(i.versions ?? [])); } if (this.ignoresProjen) { this.addIgnore("projen"); } } /** * Allows a dependency from automatic updates. * * @param dependencyName Use to allow updates for dependencies with matching * names, optionally using `*` to match zero or more characters. */ addAllow(dependencyName) { this.allow.push({ "dependency-name": dependencyName, }); } /** * Ignores a dependency from automatic updates. * * @param dependencyName Use to ignore updates for dependencies with matching * names, optionally using `*` to match zero or more characters. * @param versions Use to ignore specific versions or ranges of versions. If * you want to define a range, use the standard pattern for the package * manager (for example: `^1.0.0` for npm, or `~> 2.0` for Bundler). */ addIgnore(dependencyName, ...versions) { this.ignore.push({ "dependency-name": dependencyName, versions: () => (versions.length > 0 ? versions : undefined), }); } } exports.Dependabot = Dependabot; _a = JSII_RTTI_SYMBOL_1; Dependabot[_a] = { fqn: "projen.github.Dependabot", version: "0.99.51" }; function validateGroup(name, group) { // update types if (group.updateTypes !== undefined) { if (group.updateTypes.length < 1) { throw new Error(`Dependabot group "${name}" must not have an empty array of update types.`); } if (new Set(group.updateTypes).size !== group.updateTypes.length) { throw new Error(`Dependabot group "${name}" must not have duplicate update types.`); } } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependabot.js","sourceRoot":"","sources":["../../src/github/dependabot.ts"],"names":[],"mappings":"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","sourcesContent":["import type { GitHub } from \"./github\";\nimport { Component } from \"../component\";\nimport { kebabCaseKeys } from \"../util\";\nimport { YamlFile } from \"../yaml\";\n\nexport interface DependabotOptions {\n  /**\n   * How often to check for new versions and raise pull requests.\n   *\n   * @default ScheduleInterval.DAILY\n   */\n  readonly scheduleInterval?: DependabotScheduleInterval;\n\n  /**\n   * The strategy to use when edits manifest and lock files.\n   *\n   * @default VersioningStrategy.LOCKFILE_ONLY The default is to only update the\n   * lock file because package.json is controlled by projen and any outside\n   * updates will fail the build.\n   */\n  readonly versioningStrategy?: VersioningStrategy;\n\n  /**\n   * https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#allow\n   *\n   * Use the allow option to customize which dependencies are updated. This\n   * applies to both version and security updates.\n   *\n   * @default []\n   */\n  readonly allow?: DependabotAllow[];\n\n  /**\n   * You can use the `ignore` option to customize which dependencies are updated.\n   * The ignore option supports the following options.\n   * @default []\n   */\n  readonly ignore?: DependabotIgnore[];\n\n  /**\n   * Ignores updates to `projen`.\n   *\n   * This is required since projen updates may cause changes in committed files\n   * and anti-tamper checks will fail.\n   *\n   * Projen upgrades are covered through the `ProjenUpgrade` class.\n   *\n   * @default true\n   */\n  readonly ignoreProjen?: boolean;\n\n  /**\n   * List of labels to apply to the created PR's.\n   */\n  readonly labels?: string[];\n\n  /**\n   * Map of package registries to use\n   * @default - use public registries\n   */\n  readonly registries?: { [name: string]: DependabotRegistry };\n\n  /**\n   * Sets the maximum of pull requests Dependabot opens for version updates.\n   * Dependabot will not open any new requests until some of those open requests\n   * are merged or closed.\n   *\n   * @default 5\n   */\n  readonly openPullRequestsLimit?: number;\n\n  /**\n   * Specify individual assignees or teams of assignees for all pull requests raised\n   * for a package manager.\n   * @default []\n   */\n  readonly assignees?: string[];\n\n  /**\n   * Specify individual reviewers or teams of reviewers for all pull requests raised\n   * for a package manager.\n   * @default []\n   */\n  readonly reviewers?: string[];\n\n  /**\n   * https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#groups\n   *\n   * You can create groups to package dependency updates together into a single PR.\n   *\n   * @default []\n   */\n  readonly groups?: { [name: string]: DependabotGroup };\n\n  /**\n   * https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#target-branch\n   * You can configure the target branch for raising pull requests for version updates against\n   */\n  readonly targetBranch?: string;\n\n  /**\n   * Defines a cooldown period for dependency version updates.\n   *\n   * During the cooldown, Dependabot will not propose updates for a dependency.\n   * This only applies to version updates, not security updates.\n   *\n   * @see https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#cooldown-\n   * @default - no cooldown\n   */\n  readonly cooldown?: DependabotCooldown;\n}\n\n/**\n * Defines a cooldown period for dependency version updates.\n *\n * @see https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#cooldown-\n */\nexport interface DependabotCooldown {\n  /**\n   * Default cooldown period (in days) for all dependencies without specific semver rules.\n   * @default - no default cooldown\n   */\n  readonly defaultDays?: number;\n\n  /**\n   * Cooldown period (in days) for major version updates.\n   * @default - uses defaultDays\n   */\n  readonly semverMajorDays?: number;\n\n  /**\n   * Cooldown period (in days) for minor version updates.\n   * @default - uses defaultDays\n   */\n  readonly semverMinorDays?: number;\n\n  /**\n   * Cooldown period (in days) for patch version updates.\n   * @default - uses defaultDays\n   */\n  readonly semverPatchDays?: number;\n\n  /**\n   * List of dependencies to apply cooldown to. Supports wildcards.\n   * @default - all dependencies\n   */\n  readonly include?: string[];\n\n  /**\n   * List of dependencies excluded from cooldown. Supports wildcards.\n   * Takes precedence over `include`.\n   * @default - no exclusions\n   */\n  readonly exclude?: string[];\n}\n\n/**\n * Use to add private registry support for dependabot\n * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#configuration-options-for-private-registries\n */\nexport interface DependabotRegistry {\n  /**\n   * Registry type e.g. 'npm-registry' or 'docker-registry'\n   */\n  readonly type: DependabotRegistryType;\n\n  /**\n   * Url for the registry e.g. 'https://npm.pkg.github.com' or 'registry.hub.docker.com'\n   */\n  readonly url: string;\n\n  /**\n   * The username that Dependabot uses to access the registry\n   * @default - do not authenticate\n   */\n  readonly username?: string;\n\n  /**\n   * A reference to a Dependabot secret containing the password for the specified user\n   * @default undefined\n   */\n  readonly password?: string;\n\n  /**\n   * A reference to a Dependabot secret containing an access key for this registry\n   * @default undefined\n   */\n  readonly key?: string;\n\n  /**\n   * Secret token for dependabot access e.g. '${{ secrets.DEPENDABOT_PACKAGE_TOKEN }}'\n   * @default undefined\n   */\n  readonly token?: string;\n\n  /**\n   * For registries with type: python-index, if the boolean value is true, pip\n   * esolves dependencies by using the specified URL rather than the base URL of\n   * the Python Package Index (by default https://pypi.org/simple)\n   * @default undefined\n   */\n  readonly replacesBase?: boolean;\n\n  /**\n   * Used with the hex-organization registry type.\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#hex-organization\n   * @default undefined\n   */\n  readonly organization?: string;\n}\n\n/**\n * Each configuration type requires you to provide particular settings.\n * Some types allow more than one way to connect\n * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#configuration-options-for-private-registries\n */\nexport enum DependabotRegistryType {\n  /**\n   * The composer-repository type supports username and password.\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#composer-repository\n   */\n  COMPOSER_REGISTRY = \"composer-registry\",\n\n  /**\n   * The docker-registry type supports username and password.\n   * The docker-registry type can also be used to pull from Amazon ECR using static AWS credentials\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#docker-registry\n   */\n  DOCKER_REGISTRY = \"docker-registry\",\n\n  /**\n   * The git type supports username and password\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#git\n   */\n  GIT = \"git\",\n\n  /**\n   * The hex-organization type supports organization and key\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#hex-organization\n   */\n  HEX_ORGANIZATION = \"hex-organization\",\n\n  /**\n   * The maven-repository type supports username and password, or token\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#maven-repository\n   */\n  MAVEN_REPOSITORY = \"maven-repository\",\n\n  /**\n   * The npm-registry type supports username and password, or token\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#npm-registry\n   */\n  NPM_REGISTRY = \"npm-registry\",\n\n  /**\n   * The nuget-feed type supports username and password, or token\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#nuget-feed\n   */\n  NUGET_FEED = \"nuget-feed\",\n\n  /**\n   * The python-index type supports username and password, or token\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#python-index\n   */\n  PYTHON_INDEX = \"python-index\",\n\n  /**\n   * The rubygems-server type supports username and password, or token\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#rubygems-server\n   */\n  RUBYGEMS_SERVER = \"rubygems-server\",\n\n  /**\n   * The terraform-registry type supports a token\n   * @see https://docs.github.com/en/code-security/supply-chain-security/keeping-your-dependencies-updated-automatically/configuration-options-for-dependency-updates#terraform-registry\n   */\n  TERRAFORM_REGISTRY = \"terraform-registry\",\n}\n\n/**\n * You can use the `allow` option to customize which dependencies are updated.\n * The allow option supports the following options.\n */\nexport interface DependabotAllow {\n  /**\n   * Use to allow updates for dependencies with matching names, optionally\n   * using `*` to match zero or more characters.\n   *\n   * For Java dependencies, the format of the dependency-name attribute is:\n   * `groupId:artifactId`, for example: `org.kohsuke:github-api`.\n   */\n  readonly dependencyName: string;\n}\n\n/**\n * You can use the `ignore` option to customize which dependencies are updated.\n * The ignore option supports the following options.\n */\nexport interface DependabotIgnore {\n  /**\n   * Use to ignore updates for dependencies with matching names, optionally\n   * using `*` to match zero or more characters.\n   *\n   * For Java dependencies, the format of the dependency-name attribute is:\n   * `groupId:artifactId`, for example: `org.kohsuke:github-api`.\n   */\n  readonly dependencyName: string;\n\n  /**\n   * Use to ignore specific versions or ranges of versions. If you want to\n   * define a range, use the standard pattern for the package manager (for\n   * example: `^1.0.0` for npm, or `~> 2.0` for Bundler).\n   */\n  readonly versions?: string[];\n}\n\n/**\n * Defines a single group for dependency updates\n * @see https://docs.github.com/en/code-security/dependabot/working-with-dependabot/dependabot-options-reference#groups--\n */\nexport interface DependabotGroup {\n  /**\n   * Specify which type of update the group applies to.\n   * @default - version updates\n   */\n  readonly appliesTo?: DependabotGroupAppliesTo;\n\n  /**\n   * Limit the group to a type of dependency.\n   * @see https://docs.github.com/en/code-security/dependabot/working-with-dependabot/dependabot-options-reference#dependency-type-groups\n   * @default - all types of dependencies\n   */\n  readonly dependencyType?: DependabotGroupDependencyType;\n\n  /**\n   * Define a list of strings (with or without wildcards) that will match\n   * package names to form this dependency group.\n   */\n  readonly patterns: string[];\n\n  /**\n   * Optionally you can use this to exclude certain dependencies from the\n   * group.\n   */\n  readonly excludePatterns?: string[];\n\n  /**\n   * Limit the group to one or more semantic versioning levels.\n   *\n   * If specified, must contain at least one element and elements must be unique.\n   *\n   * @see https://docs.github.com/en/code-security/dependabot/working-with-dependabot/dependabot-options-reference#update-types-groups\n   * @default - all semantic versioning levels\n   */\n  readonly updateTypes?: DependabotGroupUpdateType[];\n}\n\n/**\n * The type of update a group applies to.\n */\nexport enum DependabotGroupAppliesTo {\n  /**\n   * Apply only to version updates.\n   */\n  VERSION_UPDATES = \"version-updates\",\n\n  /**\n   * Apply only to security updates.\n   */\n  SECURITY_UPDATES = \"security-updates\",\n}\n\n/**\n * The type of dependency a group may be limited to.\n */\nexport enum DependabotGroupDependencyType {\n  /**\n   * Include only dependencies in the \"Development dependency group\".\n   */\n  DEVELOPMENT = \"development\",\n\n  /**\n   * Include only dependencies in the \"Production dependency group\".\n   */\n  PRODUCTION = \"production\",\n}\n\n/**\n * The semantic versioning levels a group may be limited to.\n */\nexport enum DependabotGroupUpdateType {\n  /**\n   * Include major releases.\n   */\n  MAJOR = \"major\",\n\n  /**\n   * Include minor releases.\n   */\n  MINOR = \"minor\",\n\n  /**\n   * Include patch releases.\n   */\n  PATCH = \"patch\",\n}\n\n/**\n * How often to check for new versions and raise pull requests for version\n * updates.\n */\nexport enum DependabotScheduleInterval {\n  /**\n   * Runs on every weekday, Monday to Friday.\n   */\n  DAILY = \"daily\",\n\n  /**\n   * Runs once each week. By default, this is on Monday.\n   */\n  WEEKLY = \"weekly\",\n\n  /**\n   * Runs once each month. This is on the first day of the month.\n   */\n  MONTHLY = \"monthly\",\n}\n\n/**\n * The strategy to use when edits manifest and lock files.\n */\nexport enum VersioningStrategy {\n  /**\n   * Only create pull requests to update lockfiles updates. Ignore any new\n   * versions that would require package manifest changes.\n   */\n  LOCKFILE_ONLY = \"lockfile-only\",\n\n  /**\n   * - For apps, the version requirements are increased.\n   * - For libraries, the range of versions is widened.\n   */\n  AUTO = \"auto\",\n\n  /**\n   * Relax the version requirement to include both the new and old version, when\n   * possible.\n   */\n  WIDEN = \"widen\",\n\n  /**\n   * Always increase the version requirement to match the new version.\n   */\n  INCREASE = \"increase\",\n\n  /**\n   * Increase the version requirement only when required by the new version.\n   */\n  INCREASE_IF_NECESSARY = \"increase-if-necessary\",\n}\n\n/**\n * Defines dependabot configuration for node projects.\n *\n * Since module versions are managed in projen, the versioning strategy will be\n * configured to \"lockfile-only\" which means that only updates that can be done\n * on the lockfile itself will be proposed.\n */\nexport class Dependabot extends Component {\n  /**\n   * The raw dependabot configuration.\n   * @see https://docs.github.com/en/github/administering-a-repository/configuration-options-for-dependency-updates\n   */\n  public readonly config: any;\n\n  /**\n   * Whether or not projen is also upgraded in this config,\n   */\n  public readonly ignoresProjen: boolean;\n\n  private readonly allow: any[];\n  private readonly ignore: any[];\n\n  constructor(github: GitHub, options: DependabotOptions = {}) {\n    super(github.project);\n\n    const project = github.project;\n\n    this.allow = [];\n    this.ignore = [];\n    this.ignoresProjen = options.ignoreProjen ?? true;\n\n    const registries = options.registries\n      ? kebabCaseKeys(options.registries)\n      : undefined;\n\n    for (const [name, group] of Object.entries(options.groups ?? {})) {\n      validateGroup(name, group);\n    }\n    const groups = options.groups ? kebabCaseKeys(options.groups) : undefined;\n\n    this.config = {\n      version: 2,\n      registries,\n      updates: [\n        {\n          \"package-ecosystem\": \"npm\",\n          \"versioning-strategy\": \"lockfile-only\",\n          directory: \"/\",\n          schedule: {\n            interval:\n              options.scheduleInterval ?? DependabotScheduleInterval.DAILY,\n          },\n          allow: () => (this.allow.length > 0 ? this.allow : undefined),\n          ignore: () => (this.ignore.length > 0 ? this.ignore : undefined),\n          labels: options.labels ? options.labels : undefined,\n          registries: registries ? Object.keys(registries) : undefined,\n          groups: groups ? groups : undefined,\n          assignees:\n            options.assignees && options.assignees.length > 0\n              ? options.assignees\n              : undefined,\n          reviewers:\n            options.reviewers && options.reviewers.length > 0\n              ? options.reviewers\n              : undefined,\n          \"open-pull-requests-limit\":\n            options.openPullRequestsLimit !== undefined\n              ? options.openPullRequestsLimit\n              : undefined,\n          \"target-branch\": options.targetBranch,\n          cooldown: options.cooldown\n            ? kebabCaseKeys(options.cooldown)\n            : undefined,\n        },\n      ],\n    };\n\n    new YamlFile(project, \".github/dependabot.yml\", {\n      obj: this.config,\n      committed: true,\n    });\n\n    for (const i of options.allow ?? []) {\n      this.addAllow(i.dependencyName);\n    }\n\n    for (const i of options.ignore ?? []) {\n      this.addIgnore(i.dependencyName, ...(i.versions ?? []));\n    }\n\n    if (this.ignoresProjen) {\n      this.addIgnore(\"projen\");\n    }\n  }\n\n  /**\n   * Allows a dependency from automatic updates.\n   *\n   * @param dependencyName Use to allow updates for dependencies with matching\n   * names, optionally using `*` to match zero or more characters.\n   */\n  public addAllow(dependencyName: string) {\n    this.allow.push({\n      \"dependency-name\": dependencyName,\n    });\n  }\n\n  /**\n   * Ignores a dependency from automatic updates.\n   *\n   * @param dependencyName Use to ignore updates for dependencies with matching\n   * names, optionally using `*` to match zero or more characters.\n   * @param versions Use to ignore specific versions or ranges of versions. If\n   * you want to define a range, use the standard pattern for the package\n   * manager (for example: `^1.0.0` for npm, or `~> 2.0` for Bundler).\n   */\n  public addIgnore(dependencyName: string, ...versions: string[]) {\n    this.ignore.push({\n      \"dependency-name\": dependencyName,\n      versions: () => (versions.length > 0 ? versions : undefined),\n    });\n  }\n}\n\nfunction validateGroup(name: string, group: DependabotGroup) {\n  // update types\n  if (group.updateTypes !== undefined) {\n    if (group.updateTypes.length < 1) {\n      throw new Error(\n        `Dependabot group \"${name}\" must not have an empty array of update types.`,\n      );\n    }\n    if (new Set(group.updateTypes).size !== group.updateTypes.length) {\n      throw new Error(\n        `Dependabot group \"${name}\" must not have duplicate update types.`,\n      );\n    }\n  }\n}\n"]}