projen
Version:
CDK for software projects
55 lines • 10.5 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Mergify = 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");
class Mergify extends component_1.Component {
constructor(github, options = {}) {
super(github.project);
this.rules = new Array();
this.queues = new Array();
for (const rule of options.rules ?? []) {
this.addRule(rule);
}
for (const queue of options.queues ?? []) {
this.addQueue(queue);
}
}
createYamlFile() {
if (this.yamlFile == null) {
this.yamlFile = new yaml_1.YamlFile(this.project, ".mergify.yml", {
obj: {
queue_rules: () => this.queues.map((q) => (0, util_1.snakeCaseKeys)(q, false)),
pull_request_rules: this.rules,
merge_queue: {
max_parallel_checks: 1,
},
},
// Mergify needs to read the file from the repository in order to work.
committed: true,
});
}
}
addRule(rule) {
this.rules.push(rule);
this.createYamlFile();
}
addQueue(queue) {
if (queue.conditions && !queue.queueConditions) {
queue = {
...queue,
queueConditions: queue.conditions,
conditions: undefined,
};
}
this.queues.push(queue);
this.createYamlFile();
}
}
exports.Mergify = Mergify;
_a = JSII_RTTI_SYMBOL_1;
Mergify[_a] = { fqn: "projen.github.Mergify", version: "0.99.51" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mergify.js","sourceRoot":"","sources":["../../src/github/mergify.ts"],"names":[],"mappings":";;;;;AACA,4CAAyC;AACzC,kCAAwC;AACxC,kCAAmC;AA8GnC,MAAa,OAAQ,SAAQ,qBAAS;IAMpC,YAAY,MAAc,EAAE,UAA0B,EAAE;QACtD,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QANP,UAAK,GAAG,IAAI,KAAK,EAAe,CAAC;QACjC,WAAM,GAAG,IAAI,KAAK,EAAgB,CAAC;QAOlD,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,KAAK,IAAI,EAAE,EAAE,CAAC;YACvC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACrB,CAAC;QAED,KAAK,MAAM,KAAK,IAAI,OAAO,CAAC,MAAM,IAAI,EAAE,EAAE,CAAC;YACzC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE,CAAC;YAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,eAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,cAAc,EAAE;gBACzD,GAAG,EAAE;oBACH,WAAW,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,oBAAa,EAAC,CAAC,EAAE,KAAK,CAAC,CAAC;oBAClE,kBAAkB,EAAE,IAAI,CAAC,KAAK;oBAC9B,WAAW,EAAE;wBACX,mBAAmB,EAAE,CAAC;qBACvB;iBACF;gBACD,uEAAuE;gBACvE,SAAS,EAAE,IAAI;aAChB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEM,OAAO,CAAC,IAAiB;QAC9B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,QAAQ,CAAC,KAAmB;QACjC,IAAI,KAAK,CAAC,UAAU,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;YAC/C,KAAK,GAAG;gBACN,GAAG,KAAK;gBACR,eAAe,EAAE,KAAK,CAAC,UAAU;gBACjC,UAAU,EAAE,SAAS;aACtB,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;;AAjDH,0BAkDC","sourcesContent":["import type { GitHub } from \"./github\";\nimport { Component } from \"../component\";\nimport { snakeCaseKeys } from \"../util\";\nimport { YamlFile } from \"../yaml\";\n\n/**\n * The Mergify conditional operators that can be used are: `or` and `and`.\n * Note: The number of nested conditions is limited to 3.\n * @see https://docs.mergify.io/conditions/#combining-conditions-with-operators\n */\nexport interface MergifyConditionalOperator {\n  readonly or?: MergifyCondition[];\n  readonly and?: MergifyCondition[];\n}\n\nexport type MergifyCondition = string | MergifyConditionalOperator;\n\nexport interface MergifyRule {\n  /**\n   * The name of the rule. This is not used by the engine directly,\n   * but is used when reporting information about a rule.\n   */\n  readonly name: string;\n  /**\n   * A list of Conditions string that must match against the\n   * pull request for the rule to be applied.\n   * @see https://docs.mergify.io/conditions/#conditions\n   */\n  readonly conditions: MergifyCondition[];\n  /**\n   * A dictionary made of Actions that will be executed on the\n   * matching pull requests.\n   * @see https://docs.mergify.io/actions/#actions\n   */\n  readonly actions: { [action: string]: any };\n}\n\nexport interface MergifyQueue {\n  /**\n   * The name of the queue.\n   */\n  readonly name: string;\n\n  /**\n   * Merge method to use.\n   *\n   * Possible values are `merge`, `squash`, `rebase` or `fast-forward`.\n   * `fast-forward` is not supported on queues with `speculative_checks` > 1, `batch_size` > 1, or with `allow_inplace_checks` set to false.\n   *\n   * @default \"merge\"\n   */\n  readonly mergeMethod?: string;\n\n  /**\n   * Method to use to update the pull request with its base branch when the speculative check is done in-place.\n   *\n   * Possible values:\n   *  - `merge` to merge the base branch into the pull request.\n   *  - `rebase` to rebase the pull request against its base branch.\n   *\n   * Note that the `rebase` method has some drawbacks, see Mergify docs for details.\n   *\n   * @see https://docs.mergify.com/actions/queue/#queue-rules\n   *\n   * @default - `merge` for all merge methods except `fast-forward` where `rebase` is used\n   */\n  readonly updateMethod?: string;\n\n  /**\n   * The list of conditions that needs to match to queue the pull request.\n   * @see https://docs.mergify.com/configuration/file-format/#queue-rules\n   *\n   * @deprecated use `queueConditions` instead\n   */\n  readonly conditions?: MergifyCondition[];\n\n  /**\n   * The list of conditions that needs to match to queue the pull request.\n   * @see https://docs.mergify.com/conditions/#conditions\n   */\n  readonly queueConditions?: MergifyCondition[];\n\n  /**\n   * The list of conditions to match to get the queued pull request merged.\n   * This automatically includes the queueConditions.\n   * In case of speculative merge pull request, the merge conditions are evaluated against the temporary pull request instead of the original one.\n   * @see https://docs.mergify.com/conditions/#conditions\n   */\n  readonly mergeConditions?: MergifyCondition[];\n\n  /**\n   * Template to use as the commit message when using the merge or squash merge method.\n   */\n  readonly commitMessageTemplate: string;\n}\n\n/**\n * Configure Mergify.\n *\n * This currently only offers a subset of options available.\n * @see https://docs.mergify.com/configuration/file-format/\n */\nexport interface MergifyOptions {\n  /**\n   * Pull request automation rules.\n   */\n  readonly rules?: MergifyRule[];\n  /**\n   * The available merge queues.\n   */\n  readonly queues?: MergifyQueue[];\n}\n\nexport class Mergify extends Component {\n  private readonly rules = new Array<MergifyRule>();\n  private readonly queues = new Array<MergifyQueue>();\n  // The actual YAML file will only be created if at least 1 rule is added.\n  private yamlFile?: YamlFile;\n\n  constructor(github: GitHub, options: MergifyOptions = {}) {\n    super(github.project);\n\n    for (const rule of options.rules ?? []) {\n      this.addRule(rule);\n    }\n\n    for (const queue of options.queues ?? []) {\n      this.addQueue(queue);\n    }\n  }\n\n  private createYamlFile() {\n    if (this.yamlFile == null) {\n      this.yamlFile = new YamlFile(this.project, \".mergify.yml\", {\n        obj: {\n          queue_rules: () => this.queues.map((q) => snakeCaseKeys(q, false)),\n          pull_request_rules: this.rules,\n          merge_queue: {\n            max_parallel_checks: 1,\n          },\n        },\n        // Mergify needs to read the file from the repository in order to work.\n        committed: true,\n      });\n    }\n  }\n\n  public addRule(rule: MergifyRule) {\n    this.rules.push(rule);\n    this.createYamlFile();\n  }\n\n  public addQueue(queue: MergifyQueue) {\n    if (queue.conditions && !queue.queueConditions) {\n      queue = {\n        ...queue,\n        queueConditions: queue.conditions,\n        conditions: undefined,\n      };\n    }\n    this.queues.push(queue);\n    this.createYamlFile();\n  }\n}\n"]}