projen
Version:
CDK for software projects
267 lines • 41.8 kB
JavaScript
;
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,
},
],
};
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.98.32" };
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 { 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/**\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        },\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"]}