renovate 43.217.1 → 43.218.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -132,9 +132,9 @@ const platform = {
132
132
  let gitAuthor;
133
133
  try {
134
134
  const user = await getCurrentUser({ token });
135
- gitAuthor = `${user.full_name || user.username} <${user.email}>`;
135
+ gitAuthor = `${user.full_name || user.login} <${user.email}>`;
136
136
  botUserID = user.id;
137
- botUserName = user.username;
137
+ botUserName = user.login;
138
138
  const env = getEnv();
139
139
  /* v8 ignore if: experimental feature */
140
140
  if (semver.valid(env.RENOVATE_X_PLATFORM_VERSION)) defaults.version = env.RENOVATE_X_PLATFORM_VERSION;
@@ -202,7 +202,7 @@ const platform = {
202
202
  throw new Error(REPOSITORY_BLOCKED);
203
203
  }
204
204
  try {
205
- config.isOrgRepo = await isOrg(repo.owner.username);
205
+ config.isOrgRepo = await isOrg(repo.owner.login);
206
206
  } catch (err) {
207
207
  logger.debug({ err }, "Forgejo initRepo() error");
208
208
  throw err;
@@ -217,7 +217,7 @@ const platform = {
217
217
  config.issueList = null;
218
218
  config.labelList = null;
219
219
  config.hasIssuesEnabled = !repo.external_tracker && repo.has_issues;
220
- config.orgName = repo.owner.username;
220
+ config.orgName = repo.owner.login;
221
221
  return {
222
222
  defaultBranch: config.defaultBranch,
223
223
  isFork: !!repo.fork,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["helper\n .getRepoLabels","helper\n .getOrgLabels","helper.searchRepos","helper.getCurrentUser","helper.getVersion","helper.getRepoContents","helper.getRepo","helper.isOrg","git.initRepo","helper.orgListRepos","git.getBranchCommit","helper.createCommitStatus","helper.renovateToForgejoStatusMapping","helper.getCombinedCommitStatus","helper.forgejoToRenovateStatusMapping","helper.getPR","helper.getPRByBranch","helper.createPR","helper.mergePR","helper.updatePR","helper\n .searchIssues","helper.getIssue","helper.closeIssue","helper.updateIssue","helper.updateIssueLabels","helper.createIssue","helper.unassignLabel","helper.getComments","helper.createComment","helper.updateComment","helper.deleteComment","helper.requestPrReviewers"],"sources":["../../../../lib/modules/platform/forgejo/index.ts"],"sourcesContent":["import { isNumber, isString } from '@sindresorhus/is';\nimport semver from 'semver';\nimport { GlobalConfig } from '../../../config/global.ts';\nimport {\n REPOSITORY_ACCESS_FORBIDDEN,\n REPOSITORY_ARCHIVED,\n REPOSITORY_BLOCKED,\n REPOSITORY_CHANGED,\n REPOSITORY_EMPTY,\n REPOSITORY_MIRRORED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport type { BranchStatus } from '../../../types/index.ts';\nimport { deduplicateArray } from '../../../util/array.ts';\nimport { parseJson } from '../../../util/common.ts';\nimport { getEnv } from '../../../util/env.ts';\nimport * as git from '../../../util/git/index.ts';\nimport { setBaseUrl } from '../../../util/http/forgejo.ts';\nimport { map } from '../../../util/promises.ts';\nimport { sanitize } from '../../../util/sanitize.ts';\nimport { ensureTrailingSlash } from '../../../util/url.ts';\nimport { getPrBodyStruct, hashBody } from '../pr-body.ts';\nimport type {\n AutodiscoverConfig,\n BranchStatusConfig,\n CreatePRConfig,\n EnsureCommentConfig,\n EnsureCommentRemovalConfig,\n EnsureIssueConfig,\n FindPRConfig,\n Issue,\n MergePRConfig,\n Platform,\n PlatformParams,\n PlatformResult,\n Pr,\n RepoParams,\n RepoResult,\n RepoSortMethod,\n SortMethod,\n UpdatePrConfig,\n} from '../types.ts';\nimport { repoFingerprint } from '../util.ts';\nimport { smartTruncate } from '../utils/pr-body.ts';\nimport * as helper from './forgejo-helper.ts';\nimport { forgejoHttp } from './forgejo-helper.ts';\nimport { ForgejoPrCache } from './pr-cache.ts';\nimport type {\n CombinedCommitStatus,\n Comment,\n Label,\n PRMergeMethod,\n PRUpdateParams,\n Repo,\n} from './types.ts';\nimport {\n DRAFT_PREFIX,\n getMergeMethod,\n getRepoUrl,\n isAllowed,\n smartLinks,\n toRenovatePR,\n trimTrailingApiPath,\n usableRepo,\n} from './utils.ts';\n\ninterface ForgejoRepoConfig {\n ignorePrAuthor: boolean;\n repository: string;\n mergeMethod: PRMergeMethod;\n\n issueList: Promise<Issue[]> | null;\n labelList: Promise<Label[]> | null;\n defaultBranch: string;\n cloneSubmodules: boolean;\n cloneSubmodulesFilter: string[] | undefined;\n hasIssuesEnabled: boolean;\n isOrgRepo: boolean;\n orgName: string;\n}\n\nexport const id = 'forgejo';\n\nconst defaults = {\n hostType: 'forgejo',\n endpoint: 'https://code.forgejo.org/',\n version: '0.0.0',\n};\n\nlet config: ForgejoRepoConfig = {} as any;\nlet botUserID: number;\nlet botUserName: string;\n\nexport function resetPlatform(): void {\n config = {} as any;\n botUserID = undefined as never;\n botUserName = undefined as never;\n defaults.hostType = 'forgejo';\n defaults.endpoint = 'https://code.forgejo.org/';\n defaults.version = '0.0.0';\n setBaseUrl(defaults.endpoint);\n}\n\nfunction toRenovateIssue(data: Issue): Issue {\n return {\n number: data.number,\n state: data.state,\n title: data.title,\n body: data.body,\n };\n}\n\nfunction matchesState(actual: string, expected: string): boolean {\n if (expected === 'all') {\n return true;\n }\n if (expected.startsWith('!')) {\n return actual !== expected.substring(1);\n }\n\n return actual === expected;\n}\n\nfunction findCommentByTopic(\n comments: Comment[],\n topic: string,\n): Comment | null {\n return comments.find((c) => c.body.startsWith(`### ${topic}\\n\\n`)) ?? null;\n}\n\nfunction findCommentByContent(\n comments: Comment[],\n content: string,\n): Comment | null {\n return comments.find((c) => c.body.trim() === content) ?? null;\n}\n\nfunction getLabelList(): Promise<Label[]> {\n if (config.labelList === null) {\n const repoLabels = helper\n .getRepoLabels(config.repository, {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} repo labels`);\n return labels;\n });\n\n const orgLabels = config.isOrgRepo\n ? helper\n .getOrgLabels(config.orgName, {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} org labels`);\n return labels;\n })\n .catch((err) => {\n // Will fail if owner of repo is not org\n logger.debug({ err }, `Unable to fetch organization labels`);\n return [] as Label[];\n })\n : Promise.resolve([]);\n\n config.labelList = Promise.all([repoLabels, orgLabels]).then((labels) =>\n ([] as Label[]).concat(...labels),\n );\n }\n\n return config.labelList;\n}\n\nasync function lookupLabelByName(name: string): Promise<number | null> {\n logger.debug(`lookupLabelByName(${name})`);\n const labelList = await getLabelList();\n return labelList.find((l) => l.name === name)?.id ?? null;\n}\n\ninterface FetchRepositoriesArgs {\n topic?: string;\n sort?: RepoSortMethod;\n order?: SortMethod;\n}\n\nasync function fetchRepositories({\n topic,\n sort,\n order,\n}: FetchRepositoriesArgs): Promise<string[]> {\n const repos = await helper.searchRepos({\n uid: botUserID,\n archived: false,\n ...(topic && {\n topic: true,\n q: topic,\n }),\n ...(sort && {\n sort,\n }),\n ...(order && {\n order,\n }),\n });\n return repos.filter(usableRepo).map((r) => r.full_name);\n}\n\nconst platform: Platform = {\n async initPlatform({\n endpoint,\n token,\n }: PlatformParams): Promise<PlatformResult> {\n if (!token) {\n throw new Error(\n 'Init: You must configure a Forgejo personal access token',\n );\n }\n\n if (endpoint) {\n let baseEndpoint = trimTrailingApiPath(endpoint);\n baseEndpoint = ensureTrailingSlash(baseEndpoint);\n defaults.endpoint = baseEndpoint;\n } else {\n logger.debug(`Using default Forgejo endpoint: ${defaults.endpoint}`);\n }\n setBaseUrl(defaults.endpoint);\n\n let gitAuthor: string;\n try {\n const user = await helper.getCurrentUser({ token });\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing -- `full_name` can be emtpy string\n gitAuthor = `${user.full_name || user.username} <${user.email}>`;\n botUserID = user.id;\n botUserName = user.username;\n const env = getEnv();\n /* v8 ignore if: experimental feature */\n if (semver.valid(env.RENOVATE_X_PLATFORM_VERSION)) {\n defaults.version = env.RENOVATE_X_PLATFORM_VERSION!;\n } else {\n defaults.version = await helper.getVersion({ token });\n }\n\n logger.debug(`Forgejo version: ${defaults.version}`);\n } catch (err) {\n logger.debug(\n { err },\n 'Error authenticating with Forgejo. Check your token',\n );\n throw new Error('Init: Authentication failure');\n }\n\n return {\n endpoint: defaults.endpoint,\n gitAuthor,\n };\n },\n\n async getRawFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<string | null> {\n const repo = repoName ?? config.repository;\n const contents = await helper.getRepoContents(repo, fileName, branchOrTag);\n return contents.contentString ?? null;\n },\n\n async getJsonFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<any> {\n // TODO #22198\n const raw = await platform.getRawFile(fileName, repoName, branchOrTag);\n return parseJson(raw, fileName);\n },\n\n async initRepo({\n repository,\n cloneSubmodules,\n cloneSubmodulesFilter,\n gitUrl,\n }: RepoParams): Promise<RepoResult> {\n let repo: Repo;\n\n config = {} as any;\n config.repository = repository;\n config.cloneSubmodules = !!cloneSubmodules;\n config.cloneSubmodulesFilter = cloneSubmodulesFilter;\n config.ignorePrAuthor = GlobalConfig.get('ignorePrAuthor');\n\n // Try to fetch information about repository\n try {\n repo = await helper.getRepo(repository);\n } catch (err) {\n logger.debug({ err }, 'Unknown Forgejo initRepo error');\n throw err;\n }\n\n // Ensure appropriate repository state and permissions\n if (repo.archived) {\n logger.debug('Repository is archived - aborting renovation');\n throw new Error(REPOSITORY_ARCHIVED);\n }\n if (repo.mirror) {\n logger.debug('Repository is a mirror - aborting renovation');\n throw new Error(REPOSITORY_MIRRORED);\n }\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n 'Repository does not permit pull or push - aborting renovation',\n );\n throw new Error(REPOSITORY_ACCESS_FORBIDDEN);\n }\n if (repo.empty) {\n logger.debug('Repository is empty - aborting renovation');\n throw new Error(REPOSITORY_EMPTY);\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug('Repo has disabled pull requests - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n // similar to forgejo behaviour- if default merge style is allowed, use this;\n // else fall back to predefined order. Order chosen to minimize commits - see\n // https://github.com/renovatebot/renovate/pull/37768 for discussion.\n const preferredOrder: PRMergeMethod[] = [\n repo.default_merge_style,\n 'fast-forward-only',\n 'squash',\n 'merge',\n 'rebase',\n 'rebase-merge',\n ];\n\n const mergeStyle = preferredOrder.find((style) => isAllowed(style, repo));\n\n if (mergeStyle) {\n config.mergeMethod = mergeStyle;\n } else {\n logger.debug(\n 'Repository has no allowed merge methods - aborting renovation',\n );\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n try {\n config.isOrgRepo = await helper.isOrg(repo.owner.username);\n } catch (err) {\n logger.debug({ err }, 'Forgejo initRepo() error');\n throw err;\n }\n\n // Determine author email and branches\n config.defaultBranch = repo.default_branch;\n logger.debug(`${repository} default branch = ${config.defaultBranch}`);\n\n const url = getRepoUrl(repo, gitUrl, defaults.endpoint);\n\n // Initialize Git storage\n await git.initRepo({\n ...config,\n url,\n });\n\n // Reset cached resources\n config.issueList = null;\n config.labelList = null;\n config.hasIssuesEnabled = !repo.external_tracker && repo.has_issues;\n config.orgName = repo.owner.username;\n\n return {\n defaultBranch: config.defaultBranch,\n isFork: !!repo.fork,\n repoFingerprint: repoFingerprint(repo.id, defaults.endpoint),\n };\n },\n\n async getRepos(config?: AutodiscoverConfig): Promise<string[]> {\n logger.debug('Auto-discovering Forgejo repositories');\n try {\n if (config?.topics) {\n logger.debug({ topics: config.topics }, 'Auto-discovering by topics');\n const fetchRepoArgs: FetchRepositoriesArgs[] = config.topics.map(\n (topic) => {\n return {\n topic,\n sort: config.sort,\n order: config.order,\n };\n },\n );\n const repos = await map(fetchRepoArgs, fetchRepositories);\n return deduplicateArray(repos.flat());\n } else if (config?.namespaces) {\n logger.debug(\n { namespaces: config.namespaces },\n 'Auto-discovering by organization',\n );\n const repos = await map(\n config.namespaces,\n async (organization: string) => {\n const orgRepos = await helper.orgListRepos(organization);\n return orgRepos\n .filter((r) => !r.mirror && !r.archived)\n .map((r) => r.full_name);\n },\n );\n return deduplicateArray(repos.flat());\n } else {\n return await fetchRepositories({\n sort: config?.sort,\n order: config?.order,\n });\n }\n } catch (err) {\n logger.error({ err }, 'Forgejo getRepos() error');\n throw err;\n }\n },\n\n async setBranchStatus({\n branchName,\n context,\n description,\n state,\n url: target_url,\n }: BranchStatusConfig): Promise<void> {\n try {\n // Create new status for branch commit\n const branchCommit = git.getBranchCommit(branchName);\n // TODO: check branchCommit\n\n await helper.createCommitStatus(config.repository, branchCommit!, {\n state: helper.renovateToForgejoStatusMapping[state] || 'pending',\n context,\n description,\n ...(target_url && { target_url }),\n });\n\n // Refresh caches by re-fetching commit status for branch\n await helper.getCombinedCommitStatus(config.repository, branchName, {\n memCache: false,\n });\n } catch (err) {\n logger.warn({ err }, 'Failed to set branch status');\n }\n },\n\n async getBranchStatus(\n branchName: string,\n internalChecksAsSuccess: boolean,\n ): Promise<BranchStatus> {\n let ccs: CombinedCommitStatus;\n try {\n ccs = await helper.getCombinedCommitStatus(config.repository, branchName);\n } catch (err) {\n if (err.statusCode === 404) {\n logger.debug(\n 'Received 404 when checking branch status, assuming branch deletion',\n );\n throw new Error(REPOSITORY_CHANGED);\n }\n\n logger.debug('Unknown error when checking branch status');\n throw err;\n }\n\n logger.debug({ ccs }, 'Branch status check result');\n if (\n !internalChecksAsSuccess &&\n ccs.worstStatus === 'success' &&\n ccs.statuses.every((status) => status.context?.startsWith('renovate/'))\n ) {\n logger.debug(\n 'Successful checks are all internal renovate/ checks, so returning \"pending\" branch status',\n );\n return 'yellow';\n }\n\n /* v8 ignore next */\n return helper.forgejoToRenovateStatusMapping[ccs.worstStatus] ?? 'yellow';\n },\n\n async getBranchStatusCheck(\n branchName: string,\n context: string,\n ): Promise<BranchStatus | null> {\n const ccs = await helper.getCombinedCommitStatus(\n config.repository,\n branchName,\n );\n const cs = ccs.statuses.find((s) => s.context === context);\n if (!cs) {\n return null;\n } // no status check exists\n const status = helper.forgejoToRenovateStatusMapping[cs.status];\n if (status) {\n return status;\n }\n logger.warn(\n { check: cs },\n 'Could not map Forgejo status value to Renovate status',\n );\n return 'yellow';\n },\n\n getPrList(): Promise<Pr[]> {\n return ForgejoPrCache.getPrs(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n );\n },\n\n async getPr(number: number): Promise<Pr | null> {\n // Search for pull request in cached list or attempt to query directly\n const prList = await platform.getPrList();\n let pr = prList.find((p) => p.number === number) ?? null;\n if (pr) {\n logger.debug('Returning from cached PRs');\n } else {\n logger.debug('PR not found in cached PRs - trying to fetch directly');\n const gpr = await helper.getPR(config.repository, number);\n pr = toRenovatePR(gpr, botUserName);\n\n // Add pull request to cache for further lookups / queries\n if (pr) {\n await ForgejoPrCache.setPr(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n }\n\n // Abort and return null if no match was found\n if (!pr) {\n return null;\n }\n\n return pr;\n },\n\n async findPr({\n branchName,\n prTitle: title,\n state = 'all',\n includeOtherAuthors,\n targetBranch,\n }: FindPRConfig): Promise<Pr | null> {\n logger.debug(`findPr(${branchName}, ${title!}, ${state})`);\n if (includeOtherAuthors && isString(targetBranch)) {\n // do not use pr cache as it only fetches prs created by the bot account\n const pr = await helper.getPRByBranch(\n config.repository,\n targetBranch,\n branchName,\n );\n if (!pr) {\n return null;\n }\n\n return toRenovatePR(pr, null);\n }\n const prList = await platform.getPrList();\n const pr = prList.find(\n (p) =>\n p.sourceRepo === config.repository &&\n p.sourceBranch === branchName &&\n matchesState(p.state, state) &&\n (!title || p.title === title),\n );\n\n if (pr) {\n logger.debug(`Found PR #${pr.number}`);\n }\n return pr ?? null;\n },\n\n async createPr({\n sourceBranch,\n targetBranch,\n prTitle,\n prBody: rawBody,\n labels: labelNames,\n platformPrOptions,\n draftPR,\n }: CreatePRConfig): Promise<Pr> {\n let title = prTitle;\n const base = targetBranch;\n const head = sourceBranch;\n const body = sanitize(rawBody);\n if (draftPR) {\n title = DRAFT_PREFIX + title;\n }\n\n logger.debug(`Creating pull request: ${title} (${head} => ${base})`);\n try {\n const labels = Array.isArray(labelNames)\n ? await map(labelNames, lookupLabelByName)\n : [];\n const gpr = await helper.createPR(config.repository, {\n base,\n head,\n title,\n body,\n labels: labels.filter(isNumber),\n });\n\n if (platformPrOptions?.usePlatformAutomerge) {\n // Only Forgejo v10.0.0+ support delete_branch_after_merge.\n // This is required to not have undesired behavior when renovate finds existing branches on next run.\n // Codeberg usees git versioning like `11.0.1-99-c504062+gitea-1.22.0` so allow any version >= 10.0.0-0.\n if (semver.gte(defaults.version, '10.0.0-0')) {\n try {\n await helper.mergePR(config.repository, gpr.number, {\n Do:\n getMergeMethod(platformPrOptions?.automergeStrategy) ??\n config.mergeMethod,\n merge_when_checks_succeed: true,\n delete_branch_after_merge: true,\n });\n\n logger.debug(\n { prNumber: gpr.number },\n 'Forgejo-native automerge: success',\n );\n } catch (err) {\n logger.warn(\n { err, prNumber: gpr.number },\n 'Forgejo-native automerge: fail',\n );\n }\n } else {\n logger.debug(\n { prNumber: gpr.number },\n `Forgejo-native automerge: not supported on this version of Forgejo. Use 10.0.0 or newer.`,\n );\n }\n }\n\n const pr = toRenovatePR(gpr, botUserName);\n if (!pr) {\n throw new Error('Can not parse newly created Pull Request');\n }\n\n await ForgejoPrCache.setPr(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n return pr;\n } catch (err) {\n // When the user manually deletes a branch from Renovate, the PR remains but is no longer linked to any branch. In\n // the most recent versions of Forgejo, the PR gets automatically closed when that happens, but older versions do\n // not handle this properly and keep the PR open. As pushing a branch with the same name resurrects the PR, this\n // would cause a HTTP 409 conflict error, which we hereby gracefully handle.\n if (err.statusCode === 409) {\n logger.warn(\n { prTitle: title, sourceBranch },\n 'Attempting to gracefully recover from 409 Conflict response in createPr()',\n );\n\n // Refresh cached PR list and search for pull request with matching information\n ForgejoPrCache.forceSync();\n const pr = await platform.findPr({\n branchName: sourceBranch,\n state: 'open',\n });\n\n // If a valid PR was found, return and gracefully recover from the error. Otherwise, abort and throw error.\n // v8 ignore else -- TODO: add test #40625\n if (pr?.bodyStruct) {\n if (pr.title !== title || pr.bodyStruct.hash !== hashBody(body)) {\n logger.debug(\n `Recovered from 409 Conflict, but PR for ${sourceBranch} is outdated. Updating...`,\n );\n await platform.updatePr({\n number: pr.number,\n prTitle: title,\n prBody: body,\n });\n pr.title = title;\n pr.bodyStruct = getPrBodyStruct(body);\n } else {\n logger.debug(\n `Recovered from 409 Conflict and PR for ${sourceBranch} is up-to-date`,\n );\n }\n\n return pr;\n }\n }\n\n throw err;\n }\n },\n\n async updatePr({\n number,\n prTitle,\n prBody: body,\n labels,\n state,\n targetBranch,\n }: UpdatePrConfig): Promise<void> {\n let title = prTitle;\n if ((await getPrList()).find((pr) => pr.number === number)?.isDraft) {\n title = DRAFT_PREFIX + title;\n }\n\n const prUpdateParams: PRUpdateParams = {\n title,\n ...(body && { body }),\n ...(state && { state }),\n };\n if (targetBranch) {\n prUpdateParams.base = targetBranch;\n }\n\n /**\n * Update PR labels.\n * In the Forgejo API, labels are replaced on each update if the field is present.\n * If the field is not present (i.e., undefined), labels aren't updated.\n * However, the labels array must contain label IDs instead of names,\n * so a lookup is performed to fetch the details (including the ID) of each label.\n */\n if (Array.isArray(labels)) {\n prUpdateParams.labels = (await map(labels, lookupLabelByName)).filter(\n isNumber,\n );\n if (labels.length !== prUpdateParams.labels.length) {\n logger.warn(\n 'Some labels could not be looked up. Renovate may halt label updates assuming changes by others.',\n );\n }\n }\n\n const gpr = await helper.updatePR(\n config.repository,\n number,\n prUpdateParams,\n );\n const pr = toRenovatePR(gpr, botUserName);\n if (pr) {\n await ForgejoPrCache.setPr(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n },\n\n async mergePr({ id, strategy }: MergePRConfig): Promise<boolean> {\n try {\n await helper.mergePR(config.repository, id, {\n Do: getMergeMethod(strategy) ?? config.mergeMethod,\n });\n return true;\n } catch (err) {\n logger.warn({ err, id }, 'Merging of PR failed');\n return false;\n }\n },\n\n getIssueList(): Promise<Issue[]> {\n if (config.hasIssuesEnabled === false) {\n return Promise.resolve([]);\n }\n config.issueList ??= helper\n .searchIssues(config.repository, { state: 'all' }, { memCache: false })\n .then((issues) => {\n const issueList = issues.map(toRenovateIssue);\n logger.debug(`Retrieved ${issueList.length} Issues`);\n return issueList;\n });\n\n return config.issueList;\n },\n\n async getIssue(number: number, memCache = true): Promise<Issue | null> {\n if (config.hasIssuesEnabled === false) {\n return null;\n }\n try {\n const body = (\n await helper.getIssue(config.repository, number, { memCache })\n ).body;\n return {\n number,\n body,\n };\n } catch (err) {\n logger.debug({ err, number }, 'Error getting issue');\n return null;\n }\n },\n\n async findIssue(title: string): Promise<Issue | null> {\n const issueList = await platform.getIssueList();\n const issue = issueList.find(\n (i) => i.state === 'open' && i.title === title,\n );\n\n if (!issue) {\n return null;\n }\n // TODO: types (#22198)\n logger.debug(`Found Issue #${issue.number!}`);\n // TODO #22198\n return getIssue!(issue.number!);\n },\n\n async ensureIssue({\n title,\n reuseTitle,\n body: content,\n labels: labelNames,\n shouldReOpen,\n once,\n }: EnsureIssueConfig): Promise<'updated' | 'created' | null> {\n logger.debug(`ensureIssue(${title})`);\n if (config.hasIssuesEnabled === false) {\n logger.info(\n 'Cannot ensure issue because issues are disabled in this repository',\n );\n return null;\n }\n try {\n const body = smartLinks(content);\n\n const issueList = await platform.getIssueList();\n let issues = issueList.filter((i) => i.title === title);\n if (!issues.length) {\n issues = issueList.filter((i) => i.title === reuseTitle);\n }\n\n const labels = Array.isArray(labelNames)\n ? (await Promise.all(labelNames.map(lookupLabelByName))).filter(\n isNumber,\n )\n : undefined;\n\n // Update any matching issues which currently exist\n if (issues.length) {\n let activeIssue = issues.find((i) => i.state === 'open');\n\n // If no active issue was found, decide if it shall be skipped, re-opened or updated without state change\n if (!activeIssue) {\n if (once) {\n logger.debug('Issue already closed - skipping update');\n return null;\n }\n if (shouldReOpen) {\n logger.debug('Reopening previously closed Issue');\n }\n\n // Pick the last issue in the list as the active one\n activeIssue = issues[issues.length - 1];\n }\n\n // Close any duplicate issues\n for (const issue of issues) {\n if (issue.state === 'open' && issue.number !== activeIssue.number) {\n // TODO: types (#22198)\n logger.warn({ issueNo: issue.number! }, 'Closing duplicate issue');\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n\n // Check if issue has already correct state\n if (\n activeIssue.title === title &&\n activeIssue.body === body &&\n activeIssue.state === 'open'\n ) {\n logger.debug(\n // TODO: types (#22198)\n `Issue #${activeIssue.number!} is open and up to date - nothing to do`,\n );\n return null;\n }\n\n if (shouldReOpen || activeIssue.state === 'open') {\n // Update issue body and re-open\n logger.debug(`Updating Issue #${activeIssue.number}`);\n const existingIssue = await helper.updateIssue(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n body,\n title,\n state: 'open',\n },\n );\n\n // Test whether the issues need to be updated\n const existingLabelIds = (existingIssue.labels ?? []).map(\n (label) => label.id,\n );\n if (\n labels &&\n (labels.length !== existingLabelIds.length ||\n labels.filter((labelId) => !existingLabelIds.includes(labelId))\n .length !== 0)\n ) {\n await helper.updateIssueLabels(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n labels,\n },\n );\n }\n\n return 'updated';\n }\n }\n\n // Create new issue and reset cache\n const issue = await helper.createIssue(config.repository, {\n body,\n title,\n labels,\n });\n logger.debug(`Created new Issue #${issue.number}`);\n config.issueList = null;\n\n return 'created';\n } catch (err) {\n logger.warn({ err }, 'Could not ensure issue');\n }\n\n return null;\n },\n\n async ensureIssueClosing(title: string): Promise<void> {\n logger.debug(`ensureIssueClosing(${title})`);\n if (config.hasIssuesEnabled === false) {\n return;\n }\n const issueList = await platform.getIssueList();\n for (const issue of issueList) {\n if (issue.state === 'open' && issue.title === title) {\n logger.debug(`Closing issue...issueNo: ${issue.number!}`);\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n },\n\n async deleteLabel(issue: number, labelName: string): Promise<void> {\n logger.debug(`Deleting label ${labelName} from Issue #${issue}`);\n const label = await lookupLabelByName(labelName);\n if (label) {\n await helper.unassignLabel(config.repository, issue, label);\n } else {\n logger.warn({ issue, labelName }, 'Failed to lookup label for deletion');\n }\n },\n\n async ensureComment({\n number: issue,\n topic,\n content,\n }: EnsureCommentConfig): Promise<boolean> {\n try {\n let body = sanitize(content);\n const commentList = await helper.getComments(config.repository, issue);\n\n // Search comment by either topic or exact body\n let comment: Comment | null = null;\n if (topic) {\n comment = findCommentByTopic(commentList, topic);\n body = `### ${topic}\\n\\n${body}`;\n } else {\n comment = findCommentByContent(commentList, body);\n }\n\n // Create a new comment if no match has been found, otherwise update if necessary\n if (!comment) {\n comment = await helper.createComment(config.repository, issue, body);\n logger.info(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment added',\n );\n } else if (comment.body === body) {\n logger.debug(`Comment #${comment.id} is already up-to-date`);\n } else {\n await helper.updateComment(config.repository, comment.id, body);\n logger.debug(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment updated',\n );\n }\n\n return true;\n } catch (err) {\n logger.warn({ err, issue, subject: topic }, 'Error ensuring comment');\n return false;\n }\n },\n\n async ensureCommentRemoval(\n deleteConfig: EnsureCommentRemovalConfig,\n ): Promise<void> {\n const { number: issue } = deleteConfig;\n const key =\n deleteConfig.type === 'by-topic'\n ? deleteConfig.topic\n : deleteConfig.content;\n logger.debug(`Ensuring comment \"${key}\" in #${issue} is removed`);\n const commentList = await helper.getComments(config.repository, issue);\n\n let comment: Comment | null = null;\n // v8 ignore else -- TODO: add test #40625\n if (deleteConfig.type === 'by-topic') {\n comment = findCommentByTopic(commentList, deleteConfig.topic);\n } else if (deleteConfig.type === 'by-content') {\n const body = sanitize(deleteConfig.content);\n comment = findCommentByContent(commentList, body);\n }\n\n // Abort and do nothing if no matching comment was found\n if (!comment) {\n return;\n }\n\n // Try to delete comment\n try {\n await helper.deleteComment(config.repository, comment.id);\n } catch (err) {\n logger.warn(\n { err, issue, config: deleteConfig },\n 'Error deleting comment',\n );\n }\n },\n\n async getBranchPr(branchName: string): Promise<Pr | null> {\n logger.debug(`getBranchPr(${branchName})`);\n const pr = await platform.findPr({ branchName, state: 'open' });\n return pr ? platform.getPr(pr.number) : null;\n },\n\n async addAssignees(number: number, assignees: string[]): Promise<void> {\n logger.debug(\n `Updating assignees '${assignees?.join(', ')}' on Issue #${number}`,\n );\n await helper.updateIssue(config.repository, number, {\n assignees,\n });\n },\n\n async addReviewers(number: number, reviewers: string[]): Promise<void> {\n logger.debug(`Adding reviewers '${reviewers?.join(', ')}' to #${number}`);\n try {\n const teamReviewers = new Set(\n reviewers\n .filter((r) => r.startsWith('team:'))\n .map((r) => r.substring(5)),\n );\n const userReviewers = new Set(\n reviewers.filter((r) => !r.startsWith('team:')),\n );\n\n await helper.requestPrReviewers(config.repository, number, {\n reviewers: [...userReviewers],\n ...(teamReviewers.size && {\n team_reviewers: [...teamReviewers],\n }),\n });\n } catch (err) {\n logger.warn({ err, number, reviewers }, 'Failed to assign reviewer');\n }\n },\n\n massageMarkdown(prBody: string): string {\n return smartTruncate(smartLinks(prBody), maxBodyLength());\n },\n\n maxBodyLength,\n};\n\nexport function maxBodyLength(): number {\n return 1000000;\n}\n\n/* oxlint-disable typescript/unbound-method */\nexport const {\n addAssignees,\n addReviewers,\n createPr,\n deleteLabel,\n ensureComment,\n ensureCommentRemoval,\n ensureIssue,\n ensureIssueClosing,\n findIssue,\n findPr,\n getBranchPr,\n getBranchStatus,\n getBranchStatusCheck,\n getIssue,\n getRawFile,\n getJsonFile,\n getIssueList,\n getPr,\n massageMarkdown,\n getPrList,\n getRepos,\n initPlatform,\n initRepo,\n mergePr,\n setBranchStatus,\n updatePr,\n} = platform;\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":["helper\n .getRepoLabels","helper\n .getOrgLabels","helper.searchRepos","helper.getCurrentUser","helper.getVersion","helper.getRepoContents","helper.getRepo","helper.isOrg","git.initRepo","helper.orgListRepos","git.getBranchCommit","helper.createCommitStatus","helper.renovateToForgejoStatusMapping","helper.getCombinedCommitStatus","helper.forgejoToRenovateStatusMapping","helper.getPR","helper.getPRByBranch","helper.createPR","helper.mergePR","helper.updatePR","helper\n .searchIssues","helper.getIssue","helper.closeIssue","helper.updateIssue","helper.updateIssueLabels","helper.createIssue","helper.unassignLabel","helper.getComments","helper.createComment","helper.updateComment","helper.deleteComment","helper.requestPrReviewers"],"sources":["../../../../lib/modules/platform/forgejo/index.ts"],"sourcesContent":["import { isNumber, isString } from '@sindresorhus/is';\nimport semver from 'semver';\nimport { GlobalConfig } from '../../../config/global.ts';\nimport {\n REPOSITORY_ACCESS_FORBIDDEN,\n REPOSITORY_ARCHIVED,\n REPOSITORY_BLOCKED,\n REPOSITORY_CHANGED,\n REPOSITORY_EMPTY,\n REPOSITORY_MIRRORED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport type { BranchStatus } from '../../../types/index.ts';\nimport { deduplicateArray } from '../../../util/array.ts';\nimport { parseJson } from '../../../util/common.ts';\nimport { getEnv } from '../../../util/env.ts';\nimport * as git from '../../../util/git/index.ts';\nimport { setBaseUrl } from '../../../util/http/forgejo.ts';\nimport { map } from '../../../util/promises.ts';\nimport { sanitize } from '../../../util/sanitize.ts';\nimport { ensureTrailingSlash } from '../../../util/url.ts';\nimport { getPrBodyStruct, hashBody } from '../pr-body.ts';\nimport type {\n AutodiscoverConfig,\n BranchStatusConfig,\n CreatePRConfig,\n EnsureCommentConfig,\n EnsureCommentRemovalConfig,\n EnsureIssueConfig,\n FindPRConfig,\n Issue,\n MergePRConfig,\n Platform,\n PlatformParams,\n PlatformResult,\n Pr,\n RepoParams,\n RepoResult,\n RepoSortMethod,\n SortMethod,\n UpdatePrConfig,\n} from '../types.ts';\nimport { repoFingerprint } from '../util.ts';\nimport { smartTruncate } from '../utils/pr-body.ts';\nimport * as helper from './forgejo-helper.ts';\nimport { forgejoHttp } from './forgejo-helper.ts';\nimport { ForgejoPrCache } from './pr-cache.ts';\nimport type {\n CombinedCommitStatus,\n Comment,\n Label,\n PRMergeMethod,\n PRUpdateParams,\n Repo,\n} from './types.ts';\nimport {\n DRAFT_PREFIX,\n getMergeMethod,\n getRepoUrl,\n isAllowed,\n smartLinks,\n toRenovatePR,\n trimTrailingApiPath,\n usableRepo,\n} from './utils.ts';\n\ninterface ForgejoRepoConfig {\n ignorePrAuthor: boolean;\n repository: string;\n mergeMethod: PRMergeMethod;\n\n issueList: Promise<Issue[]> | null;\n labelList: Promise<Label[]> | null;\n defaultBranch: string;\n cloneSubmodules: boolean;\n cloneSubmodulesFilter: string[] | undefined;\n hasIssuesEnabled: boolean;\n isOrgRepo: boolean;\n orgName: string;\n}\n\nexport const id = 'forgejo';\n\nconst defaults = {\n hostType: 'forgejo',\n endpoint: 'https://code.forgejo.org/',\n version: '0.0.0',\n};\n\nlet config: ForgejoRepoConfig = {} as any;\nlet botUserID: number;\nlet botUserName: string;\n\nexport function resetPlatform(): void {\n config = {} as any;\n botUserID = undefined as never;\n botUserName = undefined as never;\n defaults.hostType = 'forgejo';\n defaults.endpoint = 'https://code.forgejo.org/';\n defaults.version = '0.0.0';\n setBaseUrl(defaults.endpoint);\n}\n\nfunction toRenovateIssue(data: Issue): Issue {\n return {\n number: data.number,\n state: data.state,\n title: data.title,\n body: data.body,\n };\n}\n\nfunction matchesState(actual: string, expected: string): boolean {\n if (expected === 'all') {\n return true;\n }\n if (expected.startsWith('!')) {\n return actual !== expected.substring(1);\n }\n\n return actual === expected;\n}\n\nfunction findCommentByTopic(\n comments: Comment[],\n topic: string,\n): Comment | null {\n return comments.find((c) => c.body.startsWith(`### ${topic}\\n\\n`)) ?? null;\n}\n\nfunction findCommentByContent(\n comments: Comment[],\n content: string,\n): Comment | null {\n return comments.find((c) => c.body.trim() === content) ?? null;\n}\n\nfunction getLabelList(): Promise<Label[]> {\n if (config.labelList === null) {\n const repoLabels = helper\n .getRepoLabels(config.repository, {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} repo labels`);\n return labels;\n });\n\n const orgLabels = config.isOrgRepo\n ? helper\n .getOrgLabels(config.orgName, {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} org labels`);\n return labels;\n })\n .catch((err) => {\n // Will fail if owner of repo is not org\n logger.debug({ err }, `Unable to fetch organization labels`);\n return [] as Label[];\n })\n : Promise.resolve([]);\n\n config.labelList = Promise.all([repoLabels, orgLabels]).then((labels) =>\n ([] as Label[]).concat(...labels),\n );\n }\n\n return config.labelList;\n}\n\nasync function lookupLabelByName(name: string): Promise<number | null> {\n logger.debug(`lookupLabelByName(${name})`);\n const labelList = await getLabelList();\n return labelList.find((l) => l.name === name)?.id ?? null;\n}\n\ninterface FetchRepositoriesArgs {\n topic?: string;\n sort?: RepoSortMethod;\n order?: SortMethod;\n}\n\nasync function fetchRepositories({\n topic,\n sort,\n order,\n}: FetchRepositoriesArgs): Promise<string[]> {\n const repos = await helper.searchRepos({\n uid: botUserID,\n archived: false,\n ...(topic && {\n topic: true,\n q: topic,\n }),\n ...(sort && {\n sort,\n }),\n ...(order && {\n order,\n }),\n });\n return repos.filter(usableRepo).map((r) => r.full_name);\n}\n\nconst platform: Platform = {\n async initPlatform({\n endpoint,\n token,\n }: PlatformParams): Promise<PlatformResult> {\n if (!token) {\n throw new Error(\n 'Init: You must configure a Forgejo personal access token',\n );\n }\n\n if (endpoint) {\n let baseEndpoint = trimTrailingApiPath(endpoint);\n baseEndpoint = ensureTrailingSlash(baseEndpoint);\n defaults.endpoint = baseEndpoint;\n } else {\n logger.debug(`Using default Forgejo endpoint: ${defaults.endpoint}`);\n }\n setBaseUrl(defaults.endpoint);\n\n let gitAuthor: string;\n try {\n const user = await helper.getCurrentUser({ token });\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing -- `full_name` can be emtpy string\n gitAuthor = `${user.full_name || user.login} <${user.email}>`;\n botUserID = user.id;\n botUserName = user.login;\n const env = getEnv();\n /* v8 ignore if: experimental feature */\n if (semver.valid(env.RENOVATE_X_PLATFORM_VERSION)) {\n defaults.version = env.RENOVATE_X_PLATFORM_VERSION!;\n } else {\n defaults.version = await helper.getVersion({ token });\n }\n\n logger.debug(`Forgejo version: ${defaults.version}`);\n } catch (err) {\n logger.debug(\n { err },\n 'Error authenticating with Forgejo. Check your token',\n );\n throw new Error('Init: Authentication failure');\n }\n\n return {\n endpoint: defaults.endpoint,\n gitAuthor,\n };\n },\n\n async getRawFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<string | null> {\n const repo = repoName ?? config.repository;\n const contents = await helper.getRepoContents(repo, fileName, branchOrTag);\n return contents.contentString ?? null;\n },\n\n async getJsonFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<any> {\n // TODO #22198\n const raw = await platform.getRawFile(fileName, repoName, branchOrTag);\n return parseJson(raw, fileName);\n },\n\n async initRepo({\n repository,\n cloneSubmodules,\n cloneSubmodulesFilter,\n gitUrl,\n }: RepoParams): Promise<RepoResult> {\n let repo: Repo;\n\n config = {} as any;\n config.repository = repository;\n config.cloneSubmodules = !!cloneSubmodules;\n config.cloneSubmodulesFilter = cloneSubmodulesFilter;\n config.ignorePrAuthor = GlobalConfig.get('ignorePrAuthor');\n\n // Try to fetch information about repository\n try {\n repo = await helper.getRepo(repository);\n } catch (err) {\n logger.debug({ err }, 'Unknown Forgejo initRepo error');\n throw err;\n }\n\n // Ensure appropriate repository state and permissions\n if (repo.archived) {\n logger.debug('Repository is archived - aborting renovation');\n throw new Error(REPOSITORY_ARCHIVED);\n }\n if (repo.mirror) {\n logger.debug('Repository is a mirror - aborting renovation');\n throw new Error(REPOSITORY_MIRRORED);\n }\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n 'Repository does not permit pull or push - aborting renovation',\n );\n throw new Error(REPOSITORY_ACCESS_FORBIDDEN);\n }\n if (repo.empty) {\n logger.debug('Repository is empty - aborting renovation');\n throw new Error(REPOSITORY_EMPTY);\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug('Repo has disabled pull requests - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n // similar to forgejo behaviour- if default merge style is allowed, use this;\n // else fall back to predefined order. Order chosen to minimize commits - see\n // https://github.com/renovatebot/renovate/pull/37768 for discussion.\n const preferredOrder: PRMergeMethod[] = [\n repo.default_merge_style,\n 'fast-forward-only',\n 'squash',\n 'merge',\n 'rebase',\n 'rebase-merge',\n ];\n\n const mergeStyle = preferredOrder.find((style) => isAllowed(style, repo));\n\n if (mergeStyle) {\n config.mergeMethod = mergeStyle;\n } else {\n logger.debug(\n 'Repository has no allowed merge methods - aborting renovation',\n );\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n try {\n config.isOrgRepo = await helper.isOrg(repo.owner.login);\n } catch (err) {\n logger.debug({ err }, 'Forgejo initRepo() error');\n throw err;\n }\n\n // Determine author email and branches\n config.defaultBranch = repo.default_branch;\n logger.debug(`${repository} default branch = ${config.defaultBranch}`);\n\n const url = getRepoUrl(repo, gitUrl, defaults.endpoint);\n\n // Initialize Git storage\n await git.initRepo({\n ...config,\n url,\n });\n\n // Reset cached resources\n config.issueList = null;\n config.labelList = null;\n config.hasIssuesEnabled = !repo.external_tracker && repo.has_issues;\n config.orgName = repo.owner.login;\n\n return {\n defaultBranch: config.defaultBranch,\n isFork: !!repo.fork,\n repoFingerprint: repoFingerprint(repo.id, defaults.endpoint),\n };\n },\n\n async getRepos(config?: AutodiscoverConfig): Promise<string[]> {\n logger.debug('Auto-discovering Forgejo repositories');\n try {\n if (config?.topics) {\n logger.debug({ topics: config.topics }, 'Auto-discovering by topics');\n const fetchRepoArgs: FetchRepositoriesArgs[] = config.topics.map(\n (topic) => {\n return {\n topic,\n sort: config.sort,\n order: config.order,\n };\n },\n );\n const repos = await map(fetchRepoArgs, fetchRepositories);\n return deduplicateArray(repos.flat());\n } else if (config?.namespaces) {\n logger.debug(\n { namespaces: config.namespaces },\n 'Auto-discovering by organization',\n );\n const repos = await map(\n config.namespaces,\n async (organization: string) => {\n const orgRepos = await helper.orgListRepos(organization);\n return orgRepos\n .filter((r) => !r.mirror && !r.archived)\n .map((r) => r.full_name);\n },\n );\n return deduplicateArray(repos.flat());\n } else {\n return await fetchRepositories({\n sort: config?.sort,\n order: config?.order,\n });\n }\n } catch (err) {\n logger.error({ err }, 'Forgejo getRepos() error');\n throw err;\n }\n },\n\n async setBranchStatus({\n branchName,\n context,\n description,\n state,\n url: target_url,\n }: BranchStatusConfig): Promise<void> {\n try {\n // Create new status for branch commit\n const branchCommit = git.getBranchCommit(branchName);\n // TODO: check branchCommit\n\n await helper.createCommitStatus(config.repository, branchCommit!, {\n state: helper.renovateToForgejoStatusMapping[state] || 'pending',\n context,\n description,\n ...(target_url && { target_url }),\n });\n\n // Refresh caches by re-fetching commit status for branch\n await helper.getCombinedCommitStatus(config.repository, branchName, {\n memCache: false,\n });\n } catch (err) {\n logger.warn({ err }, 'Failed to set branch status');\n }\n },\n\n async getBranchStatus(\n branchName: string,\n internalChecksAsSuccess: boolean,\n ): Promise<BranchStatus> {\n let ccs: CombinedCommitStatus;\n try {\n ccs = await helper.getCombinedCommitStatus(config.repository, branchName);\n } catch (err) {\n if (err.statusCode === 404) {\n logger.debug(\n 'Received 404 when checking branch status, assuming branch deletion',\n );\n throw new Error(REPOSITORY_CHANGED);\n }\n\n logger.debug('Unknown error when checking branch status');\n throw err;\n }\n\n logger.debug({ ccs }, 'Branch status check result');\n if (\n !internalChecksAsSuccess &&\n ccs.worstStatus === 'success' &&\n ccs.statuses.every((status) => status.context?.startsWith('renovate/'))\n ) {\n logger.debug(\n 'Successful checks are all internal renovate/ checks, so returning \"pending\" branch status',\n );\n return 'yellow';\n }\n\n /* v8 ignore next */\n return helper.forgejoToRenovateStatusMapping[ccs.worstStatus] ?? 'yellow';\n },\n\n async getBranchStatusCheck(\n branchName: string,\n context: string,\n ): Promise<BranchStatus | null> {\n const ccs = await helper.getCombinedCommitStatus(\n config.repository,\n branchName,\n );\n const cs = ccs.statuses.find((s) => s.context === context);\n if (!cs) {\n return null;\n } // no status check exists\n const status = helper.forgejoToRenovateStatusMapping[cs.status];\n if (status) {\n return status;\n }\n logger.warn(\n { check: cs },\n 'Could not map Forgejo status value to Renovate status',\n );\n return 'yellow';\n },\n\n getPrList(): Promise<Pr[]> {\n return ForgejoPrCache.getPrs(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n );\n },\n\n async getPr(number: number): Promise<Pr | null> {\n // Search for pull request in cached list or attempt to query directly\n const prList = await platform.getPrList();\n let pr = prList.find((p) => p.number === number) ?? null;\n if (pr) {\n logger.debug('Returning from cached PRs');\n } else {\n logger.debug('PR not found in cached PRs - trying to fetch directly');\n const gpr = await helper.getPR(config.repository, number);\n pr = toRenovatePR(gpr, botUserName);\n\n // Add pull request to cache for further lookups / queries\n if (pr) {\n await ForgejoPrCache.setPr(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n }\n\n // Abort and return null if no match was found\n if (!pr) {\n return null;\n }\n\n return pr;\n },\n\n async findPr({\n branchName,\n prTitle: title,\n state = 'all',\n includeOtherAuthors,\n targetBranch,\n }: FindPRConfig): Promise<Pr | null> {\n logger.debug(`findPr(${branchName}, ${title!}, ${state})`);\n if (includeOtherAuthors && isString(targetBranch)) {\n // do not use pr cache as it only fetches prs created by the bot account\n const pr = await helper.getPRByBranch(\n config.repository,\n targetBranch,\n branchName,\n );\n if (!pr) {\n return null;\n }\n\n return toRenovatePR(pr, null);\n }\n const prList = await platform.getPrList();\n const pr = prList.find(\n (p) =>\n p.sourceRepo === config.repository &&\n p.sourceBranch === branchName &&\n matchesState(p.state, state) &&\n (!title || p.title === title),\n );\n\n if (pr) {\n logger.debug(`Found PR #${pr.number}`);\n }\n return pr ?? null;\n },\n\n async createPr({\n sourceBranch,\n targetBranch,\n prTitle,\n prBody: rawBody,\n labels: labelNames,\n platformPrOptions,\n draftPR,\n }: CreatePRConfig): Promise<Pr> {\n let title = prTitle;\n const base = targetBranch;\n const head = sourceBranch;\n const body = sanitize(rawBody);\n if (draftPR) {\n title = DRAFT_PREFIX + title;\n }\n\n logger.debug(`Creating pull request: ${title} (${head} => ${base})`);\n try {\n const labels = Array.isArray(labelNames)\n ? await map(labelNames, lookupLabelByName)\n : [];\n const gpr = await helper.createPR(config.repository, {\n base,\n head,\n title,\n body,\n labels: labels.filter(isNumber),\n });\n\n if (platformPrOptions?.usePlatformAutomerge) {\n // Only Forgejo v10.0.0+ support delete_branch_after_merge.\n // This is required to not have undesired behavior when renovate finds existing branches on next run.\n // Codeberg usees git versioning like `11.0.1-99-c504062+gitea-1.22.0` so allow any version >= 10.0.0-0.\n if (semver.gte(defaults.version, '10.0.0-0')) {\n try {\n await helper.mergePR(config.repository, gpr.number, {\n Do:\n getMergeMethod(platformPrOptions?.automergeStrategy) ??\n config.mergeMethod,\n merge_when_checks_succeed: true,\n delete_branch_after_merge: true,\n });\n\n logger.debug(\n { prNumber: gpr.number },\n 'Forgejo-native automerge: success',\n );\n } catch (err) {\n logger.warn(\n { err, prNumber: gpr.number },\n 'Forgejo-native automerge: fail',\n );\n }\n } else {\n logger.debug(\n { prNumber: gpr.number },\n `Forgejo-native automerge: not supported on this version of Forgejo. Use 10.0.0 or newer.`,\n );\n }\n }\n\n const pr = toRenovatePR(gpr, botUserName);\n if (!pr) {\n throw new Error('Can not parse newly created Pull Request');\n }\n\n await ForgejoPrCache.setPr(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n return pr;\n } catch (err) {\n // When the user manually deletes a branch from Renovate, the PR remains but is no longer linked to any branch. In\n // the most recent versions of Forgejo, the PR gets automatically closed when that happens, but older versions do\n // not handle this properly and keep the PR open. As pushing a branch with the same name resurrects the PR, this\n // would cause a HTTP 409 conflict error, which we hereby gracefully handle.\n if (err.statusCode === 409) {\n logger.warn(\n { prTitle: title, sourceBranch },\n 'Attempting to gracefully recover from 409 Conflict response in createPr()',\n );\n\n // Refresh cached PR list and search for pull request with matching information\n ForgejoPrCache.forceSync();\n const pr = await platform.findPr({\n branchName: sourceBranch,\n state: 'open',\n });\n\n // If a valid PR was found, return and gracefully recover from the error. Otherwise, abort and throw error.\n // v8 ignore else -- TODO: add test #40625\n if (pr?.bodyStruct) {\n if (pr.title !== title || pr.bodyStruct.hash !== hashBody(body)) {\n logger.debug(\n `Recovered from 409 Conflict, but PR for ${sourceBranch} is outdated. Updating...`,\n );\n await platform.updatePr({\n number: pr.number,\n prTitle: title,\n prBody: body,\n });\n pr.title = title;\n pr.bodyStruct = getPrBodyStruct(body);\n } else {\n logger.debug(\n `Recovered from 409 Conflict and PR for ${sourceBranch} is up-to-date`,\n );\n }\n\n return pr;\n }\n }\n\n throw err;\n }\n },\n\n async updatePr({\n number,\n prTitle,\n prBody: body,\n labels,\n state,\n targetBranch,\n }: UpdatePrConfig): Promise<void> {\n let title = prTitle;\n if ((await getPrList()).find((pr) => pr.number === number)?.isDraft) {\n title = DRAFT_PREFIX + title;\n }\n\n const prUpdateParams: PRUpdateParams = {\n title,\n ...(body && { body }),\n ...(state && { state }),\n };\n if (targetBranch) {\n prUpdateParams.base = targetBranch;\n }\n\n /**\n * Update PR labels.\n * In the Forgejo API, labels are replaced on each update if the field is present.\n * If the field is not present (i.e., undefined), labels aren't updated.\n * However, the labels array must contain label IDs instead of names,\n * so a lookup is performed to fetch the details (including the ID) of each label.\n */\n if (Array.isArray(labels)) {\n prUpdateParams.labels = (await map(labels, lookupLabelByName)).filter(\n isNumber,\n );\n if (labels.length !== prUpdateParams.labels.length) {\n logger.warn(\n 'Some labels could not be looked up. Renovate may halt label updates assuming changes by others.',\n );\n }\n }\n\n const gpr = await helper.updatePR(\n config.repository,\n number,\n prUpdateParams,\n );\n const pr = toRenovatePR(gpr, botUserName);\n if (pr) {\n await ForgejoPrCache.setPr(\n forgejoHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n },\n\n async mergePr({ id, strategy }: MergePRConfig): Promise<boolean> {\n try {\n await helper.mergePR(config.repository, id, {\n Do: getMergeMethod(strategy) ?? config.mergeMethod,\n });\n return true;\n } catch (err) {\n logger.warn({ err, id }, 'Merging of PR failed');\n return false;\n }\n },\n\n getIssueList(): Promise<Issue[]> {\n if (config.hasIssuesEnabled === false) {\n return Promise.resolve([]);\n }\n config.issueList ??= helper\n .searchIssues(config.repository, { state: 'all' }, { memCache: false })\n .then((issues) => {\n const issueList = issues.map(toRenovateIssue);\n logger.debug(`Retrieved ${issueList.length} Issues`);\n return issueList;\n });\n\n return config.issueList;\n },\n\n async getIssue(number: number, memCache = true): Promise<Issue | null> {\n if (config.hasIssuesEnabled === false) {\n return null;\n }\n try {\n const body = (\n await helper.getIssue(config.repository, number, { memCache })\n ).body;\n return {\n number,\n body,\n };\n } catch (err) {\n logger.debug({ err, number }, 'Error getting issue');\n return null;\n }\n },\n\n async findIssue(title: string): Promise<Issue | null> {\n const issueList = await platform.getIssueList();\n const issue = issueList.find(\n (i) => i.state === 'open' && i.title === title,\n );\n\n if (!issue) {\n return null;\n }\n // TODO: types (#22198)\n logger.debug(`Found Issue #${issue.number!}`);\n // TODO #22198\n return getIssue!(issue.number!);\n },\n\n async ensureIssue({\n title,\n reuseTitle,\n body: content,\n labels: labelNames,\n shouldReOpen,\n once,\n }: EnsureIssueConfig): Promise<'updated' | 'created' | null> {\n logger.debug(`ensureIssue(${title})`);\n if (config.hasIssuesEnabled === false) {\n logger.info(\n 'Cannot ensure issue because issues are disabled in this repository',\n );\n return null;\n }\n try {\n const body = smartLinks(content);\n\n const issueList = await platform.getIssueList();\n let issues = issueList.filter((i) => i.title === title);\n if (!issues.length) {\n issues = issueList.filter((i) => i.title === reuseTitle);\n }\n\n const labels = Array.isArray(labelNames)\n ? (await Promise.all(labelNames.map(lookupLabelByName))).filter(\n isNumber,\n )\n : undefined;\n\n // Update any matching issues which currently exist\n if (issues.length) {\n let activeIssue = issues.find((i) => i.state === 'open');\n\n // If no active issue was found, decide if it shall be skipped, re-opened or updated without state change\n if (!activeIssue) {\n if (once) {\n logger.debug('Issue already closed - skipping update');\n return null;\n }\n if (shouldReOpen) {\n logger.debug('Reopening previously closed Issue');\n }\n\n // Pick the last issue in the list as the active one\n activeIssue = issues[issues.length - 1];\n }\n\n // Close any duplicate issues\n for (const issue of issues) {\n if (issue.state === 'open' && issue.number !== activeIssue.number) {\n // TODO: types (#22198)\n logger.warn({ issueNo: issue.number! }, 'Closing duplicate issue');\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n\n // Check if issue has already correct state\n if (\n activeIssue.title === title &&\n activeIssue.body === body &&\n activeIssue.state === 'open'\n ) {\n logger.debug(\n // TODO: types (#22198)\n `Issue #${activeIssue.number!} is open and up to date - nothing to do`,\n );\n return null;\n }\n\n if (shouldReOpen || activeIssue.state === 'open') {\n // Update issue body and re-open\n logger.debug(`Updating Issue #${activeIssue.number}`);\n const existingIssue = await helper.updateIssue(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n body,\n title,\n state: 'open',\n },\n );\n\n // Test whether the issues need to be updated\n const existingLabelIds = (existingIssue.labels ?? []).map(\n (label) => label.id,\n );\n if (\n labels &&\n (labels.length !== existingLabelIds.length ||\n labels.filter((labelId) => !existingLabelIds.includes(labelId))\n .length !== 0)\n ) {\n await helper.updateIssueLabels(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n labels,\n },\n );\n }\n\n return 'updated';\n }\n }\n\n // Create new issue and reset cache\n const issue = await helper.createIssue(config.repository, {\n body,\n title,\n labels,\n });\n logger.debug(`Created new Issue #${issue.number}`);\n config.issueList = null;\n\n return 'created';\n } catch (err) {\n logger.warn({ err }, 'Could not ensure issue');\n }\n\n return null;\n },\n\n async ensureIssueClosing(title: string): Promise<void> {\n logger.debug(`ensureIssueClosing(${title})`);\n if (config.hasIssuesEnabled === false) {\n return;\n }\n const issueList = await platform.getIssueList();\n for (const issue of issueList) {\n if (issue.state === 'open' && issue.title === title) {\n logger.debug(`Closing issue...issueNo: ${issue.number!}`);\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n },\n\n async deleteLabel(issue: number, labelName: string): Promise<void> {\n logger.debug(`Deleting label ${labelName} from Issue #${issue}`);\n const label = await lookupLabelByName(labelName);\n if (label) {\n await helper.unassignLabel(config.repository, issue, label);\n } else {\n logger.warn({ issue, labelName }, 'Failed to lookup label for deletion');\n }\n },\n\n async ensureComment({\n number: issue,\n topic,\n content,\n }: EnsureCommentConfig): Promise<boolean> {\n try {\n let body = sanitize(content);\n const commentList = await helper.getComments(config.repository, issue);\n\n // Search comment by either topic or exact body\n let comment: Comment | null = null;\n if (topic) {\n comment = findCommentByTopic(commentList, topic);\n body = `### ${topic}\\n\\n${body}`;\n } else {\n comment = findCommentByContent(commentList, body);\n }\n\n // Create a new comment if no match has been found, otherwise update if necessary\n if (!comment) {\n comment = await helper.createComment(config.repository, issue, body);\n logger.info(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment added',\n );\n } else if (comment.body === body) {\n logger.debug(`Comment #${comment.id} is already up-to-date`);\n } else {\n await helper.updateComment(config.repository, comment.id, body);\n logger.debug(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment updated',\n );\n }\n\n return true;\n } catch (err) {\n logger.warn({ err, issue, subject: topic }, 'Error ensuring comment');\n return false;\n }\n },\n\n async ensureCommentRemoval(\n deleteConfig: EnsureCommentRemovalConfig,\n ): Promise<void> {\n const { number: issue } = deleteConfig;\n const key =\n deleteConfig.type === 'by-topic'\n ? deleteConfig.topic\n : deleteConfig.content;\n logger.debug(`Ensuring comment \"${key}\" in #${issue} is removed`);\n const commentList = await helper.getComments(config.repository, issue);\n\n let comment: Comment | null = null;\n // v8 ignore else -- TODO: add test #40625\n if (deleteConfig.type === 'by-topic') {\n comment = findCommentByTopic(commentList, deleteConfig.topic);\n } else if (deleteConfig.type === 'by-content') {\n const body = sanitize(deleteConfig.content);\n comment = findCommentByContent(commentList, body);\n }\n\n // Abort and do nothing if no matching comment was found\n if (!comment) {\n return;\n }\n\n // Try to delete comment\n try {\n await helper.deleteComment(config.repository, comment.id);\n } catch (err) {\n logger.warn(\n { err, issue, config: deleteConfig },\n 'Error deleting comment',\n );\n }\n },\n\n async getBranchPr(branchName: string): Promise<Pr | null> {\n logger.debug(`getBranchPr(${branchName})`);\n const pr = await platform.findPr({ branchName, state: 'open' });\n return pr ? platform.getPr(pr.number) : null;\n },\n\n async addAssignees(number: number, assignees: string[]): Promise<void> {\n logger.debug(\n `Updating assignees '${assignees?.join(', ')}' on Issue #${number}`,\n );\n await helper.updateIssue(config.repository, number, {\n assignees,\n });\n },\n\n async addReviewers(number: number, reviewers: string[]): Promise<void> {\n logger.debug(`Adding reviewers '${reviewers?.join(', ')}' to #${number}`);\n try {\n const teamReviewers = new Set(\n reviewers\n .filter((r) => r.startsWith('team:'))\n .map((r) => r.substring(5)),\n );\n const userReviewers = new Set(\n reviewers.filter((r) => !r.startsWith('team:')),\n );\n\n await helper.requestPrReviewers(config.repository, number, {\n reviewers: [...userReviewers],\n ...(teamReviewers.size && {\n team_reviewers: [...teamReviewers],\n }),\n });\n } catch (err) {\n logger.warn({ err, number, reviewers }, 'Failed to assign reviewer');\n }\n },\n\n massageMarkdown(prBody: string): string {\n return smartTruncate(smartLinks(prBody), maxBodyLength());\n },\n\n maxBodyLength,\n};\n\nexport function maxBodyLength(): number {\n return 1000000;\n}\n\n/* oxlint-disable typescript/unbound-method */\nexport const {\n addAssignees,\n addReviewers,\n createPr,\n deleteLabel,\n ensureComment,\n ensureCommentRemoval,\n ensureIssue,\n ensureIssueClosing,\n findIssue,\n findPr,\n getBranchPr,\n getBranchStatus,\n getBranchStatusCheck,\n getIssue,\n getRawFile,\n getJsonFile,\n getIssueList,\n getPr,\n massageMarkdown,\n getPrList,\n getRepos,\n initPlatform,\n initRepo,\n mergePr,\n setBranchStatus,\n updatePr,\n} = platform;\n"],"mappings":"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"}
@@ -55,7 +55,7 @@ function toRenovatePR(data, author) {
55
55
  logger.trace(`Skipping Pull Request #${data.number} due to missing base and/or head branch`);
56
56
  return null;
57
57
  }
58
- const createdBy = data.user?.username;
58
+ const createdBy = data.user?.login;
59
59
  if (createdBy && author && !reconfigurePrRegex.test(data.head.label) && createdBy !== author) return null;
60
60
  let title = data.title;
61
61
  let isDraft = false;
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","names":["hostRules.find"],"sources":["../../../../lib/modules/platform/forgejo/utils.ts"],"sourcesContent":["import { isNonEmptyArray } from '@sindresorhus/is';\nimport type { MergeStrategy } from '../../../config/types.ts';\nimport {\n CONFIG_GIT_URL_UNAVAILABLE,\n REPOSITORY_BLOCKED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport * as hostRules from '../../../util/host-rules.ts';\nimport { regEx } from '../../../util/regex.ts';\nimport { parseUrl } from '../../../util/url.ts';\nimport { getPrBodyStruct } from '../pr-body.ts';\nimport type { GitUrlOption, Pr } from '../types.ts';\nimport type { PR, PRMergeMethod, Repo } from './types.ts';\n\nexport function smartLinks(body: string): string {\n return body\n ?.replace(regEx(/\\]\\(\\.\\.\\/issues\\//g), '](issues/')\n .replace(regEx(/\\]\\(\\.\\.\\/pull\\//g), '](pulls/');\n}\n\nexport function trimTrailingApiPath(url: string): string {\n return url?.replace(regEx(/api\\/v1\\/?$/g), '');\n}\n\nexport function getRepoUrl(\n repo: Repo,\n gitUrl: GitUrlOption | undefined,\n endpoint: string,\n): string {\n if (gitUrl === 'ssh') {\n if (!repo.ssh_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n logger.debug(`Using SSH URL: ${repo.ssh_url}`);\n return repo.ssh_url;\n }\n\n // Find options for current host and determine Git endpoint\n const opts = hostRules.find({\n hostType: 'forgejo',\n url: endpoint,\n });\n\n if (gitUrl === 'endpoint') {\n const url = parseUrl(endpoint);\n if (!url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n url.username = opts.token ?? '';\n url.pathname = `${url.pathname}${repo.full_name}.git`;\n logger.debug(\n { url: url.toString() },\n 'using URL based on configured endpoint',\n );\n return url.toString();\n }\n\n if (!repo.clone_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n\n logger.debug(`Using HTTP URL: ${repo.clone_url}`);\n const repoUrl = parseUrl(repo.clone_url);\n if (!repoUrl) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n repoUrl.username = opts.token ?? '';\n return repoUrl.toString();\n}\n\nexport function getMergeMethod(\n strategy: MergeStrategy | undefined,\n): PRMergeMethod | null {\n switch (strategy) {\n case 'fast-forward':\n return 'rebase';\n case 'merge-commit':\n return 'merge';\n case 'rebase':\n return 'rebase-merge';\n case 'squash':\n return strategy;\n case 'auto':\n default:\n return null;\n }\n}\n\nexport const API_PATH = '/api/v1';\n\nexport const DRAFT_PREFIX = 'WIP: ';\nconst reconfigurePrRegex = regEx(/reconfigure$/g);\n\nexport function toRenovatePR(data: PR, author: string | null): Pr | null {\n if (!data) {\n return null;\n }\n\n if (\n !data.base?.ref ||\n !data.head?.label ||\n !data.head?.sha ||\n !data.head?.repo?.full_name\n ) {\n logger.trace(\n `Skipping Pull Request #${data.number} due to missing base and/or head branch`,\n );\n return null;\n }\n\n const createdBy = data.user?.username;\n if (\n createdBy &&\n author &&\n !reconfigurePrRegex.test(data.head.label) &&\n createdBy !== author\n ) {\n return null;\n }\n\n let title = data.title;\n let isDraft = false;\n if (title.startsWith(DRAFT_PREFIX)) {\n title = title.substring(DRAFT_PREFIX.length);\n isDraft = true;\n }\n const labels = (data?.labels ?? []).map((l) => l.name);\n\n return {\n labels,\n number: data.number,\n state: data.merged ? 'merged' : data.state,\n title,\n isDraft,\n bodyStruct: getPrBodyStruct(data.body),\n sha: data.head.sha,\n sourceBranch: data.head.label,\n targetBranch: data.base.ref,\n sourceRepo: data.head.repo.full_name,\n createdAt: data.created_at,\n cannotMergeReason: data.mergeable\n ? undefined\n : `pr.mergeable=\"${data.mergeable}\"`,\n hasAssignees: !!(data.assignee?.login ?? isNonEmptyArray(data.assignees)),\n };\n}\n\n/**\n * Check if a repository is usable.\n * A repo isn't usable if one of the following conditions is met:\n * - The repo is a `mirror`\n * - We don't have pull or push permissions\n * - Pull requests are disabled\n * @param repo Repo to check\n * @returns `true` if the repository is usable, `false` otherwise\n */\nexport function usableRepo(repo: Repo): boolean {\n if (repo.mirror === true) {\n return false;\n }\n\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because of missing pull or push permissions`,\n );\n return false;\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because pull requests are disabled`,\n );\n return false;\n }\n return true;\n}\n\nexport function isAllowed(style: PRMergeMethod, repo: Repo): boolean {\n switch (style) {\n case 'merge':\n return repo.allow_merge_commits;\n case 'rebase':\n return repo.allow_rebase;\n case 'rebase-merge':\n return repo.allow_rebase_explicit;\n case 'squash':\n return repo.allow_squash_merge;\n case 'fast-forward-only':\n return repo.allow_fast_forward_only_merge;\n }\n logger.debug('Repo has unknown merge style - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"utils.js","names":["hostRules.find"],"sources":["../../../../lib/modules/platform/forgejo/utils.ts"],"sourcesContent":["import { isNonEmptyArray } from '@sindresorhus/is';\nimport type { MergeStrategy } from '../../../config/types.ts';\nimport {\n CONFIG_GIT_URL_UNAVAILABLE,\n REPOSITORY_BLOCKED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport * as hostRules from '../../../util/host-rules.ts';\nimport { regEx } from '../../../util/regex.ts';\nimport { parseUrl } from '../../../util/url.ts';\nimport { getPrBodyStruct } from '../pr-body.ts';\nimport type { GitUrlOption, Pr } from '../types.ts';\nimport type { PR, PRMergeMethod, Repo } from './types.ts';\n\nexport function smartLinks(body: string): string {\n return body\n ?.replace(regEx(/\\]\\(\\.\\.\\/issues\\//g), '](issues/')\n .replace(regEx(/\\]\\(\\.\\.\\/pull\\//g), '](pulls/');\n}\n\nexport function trimTrailingApiPath(url: string): string {\n return url?.replace(regEx(/api\\/v1\\/?$/g), '');\n}\n\nexport function getRepoUrl(\n repo: Repo,\n gitUrl: GitUrlOption | undefined,\n endpoint: string,\n): string {\n if (gitUrl === 'ssh') {\n if (!repo.ssh_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n logger.debug(`Using SSH URL: ${repo.ssh_url}`);\n return repo.ssh_url;\n }\n\n // Find options for current host and determine Git endpoint\n const opts = hostRules.find({\n hostType: 'forgejo',\n url: endpoint,\n });\n\n if (gitUrl === 'endpoint') {\n const url = parseUrl(endpoint);\n if (!url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n url.username = opts.token ?? '';\n url.pathname = `${url.pathname}${repo.full_name}.git`;\n logger.debug(\n { url: url.toString() },\n 'using URL based on configured endpoint',\n );\n return url.toString();\n }\n\n if (!repo.clone_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n\n logger.debug(`Using HTTP URL: ${repo.clone_url}`);\n const repoUrl = parseUrl(repo.clone_url);\n if (!repoUrl) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n repoUrl.username = opts.token ?? '';\n return repoUrl.toString();\n}\n\nexport function getMergeMethod(\n strategy: MergeStrategy | undefined,\n): PRMergeMethod | null {\n switch (strategy) {\n case 'fast-forward':\n return 'rebase';\n case 'merge-commit':\n return 'merge';\n case 'rebase':\n return 'rebase-merge';\n case 'squash':\n return strategy;\n case 'auto':\n default:\n return null;\n }\n}\n\nexport const API_PATH = '/api/v1';\n\nexport const DRAFT_PREFIX = 'WIP: ';\nconst reconfigurePrRegex = regEx(/reconfigure$/g);\n\nexport function toRenovatePR(data: PR, author: string | null): Pr | null {\n if (!data) {\n return null;\n }\n\n if (\n !data.base?.ref ||\n !data.head?.label ||\n !data.head?.sha ||\n !data.head?.repo?.full_name\n ) {\n logger.trace(\n `Skipping Pull Request #${data.number} due to missing base and/or head branch`,\n );\n return null;\n }\n\n const createdBy = data.user?.login;\n if (\n createdBy &&\n author &&\n !reconfigurePrRegex.test(data.head.label) &&\n createdBy !== author\n ) {\n return null;\n }\n\n let title = data.title;\n let isDraft = false;\n if (title.startsWith(DRAFT_PREFIX)) {\n title = title.substring(DRAFT_PREFIX.length);\n isDraft = true;\n }\n const labels = (data?.labels ?? []).map((l) => l.name);\n\n return {\n labels,\n number: data.number,\n state: data.merged ? 'merged' : data.state,\n title,\n isDraft,\n bodyStruct: getPrBodyStruct(data.body),\n sha: data.head.sha,\n sourceBranch: data.head.label,\n targetBranch: data.base.ref,\n sourceRepo: data.head.repo.full_name,\n createdAt: data.created_at,\n cannotMergeReason: data.mergeable\n ? undefined\n : `pr.mergeable=\"${data.mergeable}\"`,\n hasAssignees: !!(data.assignee?.login ?? isNonEmptyArray(data.assignees)),\n };\n}\n\n/**\n * Check if a repository is usable.\n * A repo isn't usable if one of the following conditions is met:\n * - The repo is a `mirror`\n * - We don't have pull or push permissions\n * - Pull requests are disabled\n * @param repo Repo to check\n * @returns `true` if the repository is usable, `false` otherwise\n */\nexport function usableRepo(repo: Repo): boolean {\n if (repo.mirror === true) {\n return false;\n }\n\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because of missing pull or push permissions`,\n );\n return false;\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because pull requests are disabled`,\n );\n return false;\n }\n return true;\n}\n\nexport function isAllowed(style: PRMergeMethod, repo: Repo): boolean {\n switch (style) {\n case 'merge':\n return repo.allow_merge_commits;\n case 'rebase':\n return repo.allow_rebase;\n case 'rebase-merge':\n return repo.allow_rebase_explicit;\n case 'squash':\n return repo.allow_squash_merge;\n case 'fast-forward-only':\n return repo.allow_fast_forward_only_merge;\n }\n logger.debug('Repo has unknown merge style - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n}\n"],"mappings":";;;;;;;;AAcA,SAAgB,WAAW,MAAsB;CAC/C,OAAO,MACH,QAAQ,MAAM,qBAAqB,GAAG,WAAW,EAClD,QAAQ,MAAM,mBAAmB,GAAG,UAAU;AACnD;AAEA,SAAgB,oBAAoB,KAAqB;CACvD,OAAO,KAAK,QAAQ,MAAM,cAAc,GAAG,EAAE;AAC/C;AAEA,SAAgB,WACd,MACA,QACA,UACQ;CACR,IAAI,WAAW,OAAO;EACpB,IAAI,CAAC,KAAK,SACR,MAAM,IAAI,MAAM,0BAA0B;EAE5C,OAAO,MAAM,kBAAkB,KAAK,SAAS;EAC7C,OAAO,KAAK;CACd;CAGA,MAAM,OAAOA,KAAe;EAC1B,UAAU;EACV,KAAK;CACP,CAAC;CAED,IAAI,WAAW,YAAY;EACzB,MAAM,MAAM,SAAS,QAAQ;EAC7B,IAAI,CAAC,KACH,MAAM,IAAI,MAAM,0BAA0B;EAE5C,IAAI,WAAW,KAAK,SAAS;EAC7B,IAAI,WAAW,GAAG,IAAI,WAAW,KAAK,UAAU;EAChD,OAAO,MACL,EAAE,KAAK,IAAI,SAAS,EAAE,GACtB,wCACF;EACA,OAAO,IAAI,SAAS;CACtB;CAEA,IAAI,CAAC,KAAK,WACR,MAAM,IAAI,MAAM,0BAA0B;CAG5C,OAAO,MAAM,mBAAmB,KAAK,WAAW;CAChD,MAAM,UAAU,SAAS,KAAK,SAAS;CACvC,IAAI,CAAC,SACH,MAAM,IAAI,MAAM,0BAA0B;CAE5C,QAAQ,WAAW,KAAK,SAAS;CACjC,OAAO,QAAQ,SAAS;AAC1B;AAEA,SAAgB,eACd,UACsB;CACtB,QAAQ,UAAR;EACE,KAAK,gBACH,OAAO;EACT,KAAK,gBACH,OAAO;EACT,KAAK,UACH,OAAO;EACT,KAAK,UACH,OAAO;EAET,SACE,OAAO;CACX;AACF;AAEA,MAAa,WAAW;AAExB,MAAa,eAAe;AAC5B,MAAM,qBAAqB,MAAM,eAAe;AAEhD,SAAgB,aAAa,MAAU,QAAkC;CACvE,IAAI,CAAC,MACH,OAAO;CAGT,IACE,CAAC,KAAK,MAAM,OACZ,CAAC,KAAK,MAAM,SACZ,CAAC,KAAK,MAAM,OACZ,CAAC,KAAK,MAAM,MAAM,WAClB;EACA,OAAO,MACL,0BAA0B,KAAK,OAAO,wCACxC;EACA,OAAO;CACT;CAEA,MAAM,YAAY,KAAK,MAAM;CAC7B,IACE,aACA,UACA,CAAC,mBAAmB,KAAK,KAAK,KAAK,KAAK,KACxC,cAAc,QAEd,OAAO;CAGT,IAAI,QAAQ,KAAK;CACjB,IAAI,UAAU;CACd,IAAI,MAAM,WAAA,OAAuB,GAAG;EAClC,QAAQ,MAAM,UAAU,CAAmB;EAC3C,UAAU;CACZ;CAGA,OAAO;EACL,SAHc,MAAM,UAAU,CAAC,GAAG,KAAK,MAAM,EAAE,IAG1C;EACL,QAAQ,KAAK;EACb,OAAO,KAAK,SAAS,WAAW,KAAK;EACrC;EACA;EACA,YAAY,gBAAgB,KAAK,IAAI;EACrC,KAAK,KAAK,KAAK;EACf,cAAc,KAAK,KAAK;EACxB,cAAc,KAAK,KAAK;EACxB,YAAY,KAAK,KAAK,KAAK;EAC3B,WAAW,KAAK;EAChB,mBAAmB,KAAK,YACpB,KAAA,IACA,iBAAiB,KAAK,UAAU;EACpC,cAAc,CAAC,EAAE,KAAK,UAAU,SAAS,gBAAgB,KAAK,SAAS;CACzE;AACF;;;;;;;;;;AAWA,SAAgB,WAAW,MAAqB;CAC9C,IAAI,KAAK,WAAW,MAClB,OAAO;CAGT,IAAI,KAAK,YAAY,SAAS,SAAS,KAAK,YAAY,SAAS,OAAO;EACtE,OAAO,MACL,uBAAuB,KAAK,UAAU,6CACxC;EACA,OAAO;CACT;CAEA,IAAI,KAAK,sBAAsB,OAAO;EACpC,OAAO,MACL,uBAAuB,KAAK,UAAU,oCACxC;EACA,OAAO;CACT;CACA,OAAO;AACT;AAEA,SAAgB,UAAU,OAAsB,MAAqB;CACnE,QAAQ,OAAR;EACE,KAAK,SACH,OAAO,KAAK;EACd,KAAK,UACH,OAAO,KAAK;EACd,KAAK,gBACH,OAAO,KAAK;EACd,KAAK,UACH,OAAO,KAAK;EACd,KAAK,qBACH,OAAO,KAAK;CAChB;CACA,OAAO,MAAM,oDAAoD;CACjE,MAAM,IAAI,MAAM,kBAAkB;AACpC"}
@@ -134,9 +134,9 @@ const platform = {
134
134
  let gitAuthor;
135
135
  try {
136
136
  const user = await getCurrentUser({ token });
137
- gitAuthor = `${user.full_name || user.username} <${user.email}>`;
137
+ gitAuthor = `${user.full_name || user.login} <${user.email}>`;
138
138
  botUserID = user.id;
139
- botUserName = user.username;
139
+ botUserName = user.login;
140
140
  const env = getEnv();
141
141
  /* v8 ignore next: experimental feature */
142
142
  if (semver.valid(env.RENOVATE_X_PLATFORM_VERSION)) defaults.version = env.RENOVATE_X_PLATFORM_VERSION;
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["helper\n .getRepoLabels","helper\n .getOrgLabels","helper.searchRepos","helper.getCurrentUser","helper.getVersion","helper.getRepoContents","helper.getRepo","git.initRepo","helper.orgListRepos","git.getBranchCommit","helper.createCommitStatus","helper.renovateToGiteaStatusMapping","helper.getCombinedCommitStatus","helper.giteaToRenovateStatusMapping","helper.getPR","helper.getPRByBranch","helper.createPR","helper.mergePR","helper.updatePR","helper\n .searchIssues","helper.getIssue","helper.closeIssue","helper.updateIssue","helper.updateIssueLabels","helper.createIssue","helper.unassignLabel","helper.getComments","helper.createComment","helper.updateComment","helper.deleteComment","helper.requestPrReviewers"],"sources":["../../../../lib/modules/platform/gitea/index.ts"],"sourcesContent":["import { isNumber, isString } from '@sindresorhus/is';\nimport semver from 'semver';\nimport { GlobalConfig } from '../../../config/global.ts';\nimport {\n REPOSITORY_ACCESS_FORBIDDEN,\n REPOSITORY_ARCHIVED,\n REPOSITORY_BLOCKED,\n REPOSITORY_CHANGED,\n REPOSITORY_EMPTY,\n REPOSITORY_MIRRORED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport type { BranchStatus } from '../../../types/index.ts';\nimport { deduplicateArray } from '../../../util/array.ts';\nimport { parseJson } from '../../../util/common.ts';\nimport { getEnv } from '../../../util/env.ts';\nimport * as git from '../../../util/git/index.ts';\nimport { setBaseUrl } from '../../../util/http/gitea.ts';\nimport { map } from '../../../util/promises.ts';\nimport { sanitize } from '../../../util/sanitize.ts';\nimport { ensureTrailingSlash } from '../../../util/url.ts';\nimport { getPrBodyStruct, hashBody } from '../pr-body.ts';\nimport type {\n AutodiscoverConfig,\n BranchStatusConfig,\n CreatePRConfig,\n EnsureCommentConfig,\n EnsureCommentRemovalConfig,\n EnsureIssueConfig,\n FindPRConfig,\n Issue,\n MergePRConfig,\n Platform,\n PlatformParams,\n PlatformResult,\n Pr,\n RepoParams,\n RepoResult,\n RepoSortMethod,\n SortMethod,\n UpdatePrConfig,\n} from '../types.ts';\nimport { repoFingerprint } from '../util.ts';\nimport { smartTruncate } from '../utils/pr-body.ts';\nimport * as helper from './gitea-helper.ts';\nimport { giteaHttp } from './gitea-helper.ts';\nimport { GiteaPrCache } from './pr-cache.ts';\nimport type {\n CombinedCommitStatus,\n Comment,\n Label,\n PRMergeMethod,\n PRUpdateParams,\n Repo,\n} from './types.ts';\nimport {\n DRAFT_PREFIX,\n getMergeMethod,\n getRepoUrl,\n isAllowed,\n smartLinks,\n toRenovatePR,\n trimTrailingApiPath,\n usableRepo,\n} from './utils.ts';\n\ninterface GiteaRepoConfig {\n ignorePrAuthor: boolean;\n repository: string;\n mergeMethod: PRMergeMethod;\n\n issueList: Promise<Issue[]> | null;\n labelList: Promise<Label[]> | null;\n defaultBranch: string;\n cloneSubmodules: boolean;\n cloneSubmodulesFilter: string[] | undefined;\n hasIssuesEnabled: boolean;\n}\n\nexport const id = 'gitea';\n\nconst defaults = {\n hostType: 'gitea',\n endpoint: 'https://gitea.com/',\n version: '0.0.0',\n isForgejo: false,\n};\n\nlet config: GiteaRepoConfig = {} as any;\nlet botUserID: number;\nlet botUserName: string;\n\nexport function resetPlatform(): void {\n config = {} as any;\n botUserID = undefined as never;\n botUserName = undefined as never;\n defaults.hostType = 'gitea';\n defaults.endpoint = 'https://gitea.com/';\n defaults.version = '0.0.0';\n defaults.isForgejo = false;\n setBaseUrl(defaults.endpoint);\n}\n\nfunction toRenovateIssue(data: Issue): Issue {\n return {\n number: data.number,\n state: data.state,\n title: data.title,\n body: data.body,\n };\n}\n\nfunction matchesState(actual: string, expected: string): boolean {\n if (expected === 'all') {\n return true;\n }\n if (expected.startsWith('!')) {\n return actual !== expected.substring(1);\n }\n\n return actual === expected;\n}\n\nfunction findCommentByTopic(\n comments: Comment[],\n topic: string,\n): Comment | null {\n return comments.find((c) => c.body.startsWith(`### ${topic}\\n\\n`)) ?? null;\n}\n\nfunction findCommentByContent(\n comments: Comment[],\n content: string,\n): Comment | null {\n return comments.find((c) => c.body.trim() === content) ?? null;\n}\n\nfunction getLabelList(): Promise<Label[]> {\n if (config.labelList === null) {\n const repoLabels = helper\n .getRepoLabels(config.repository, {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} repo labels`);\n return labels;\n });\n\n const orgLabels = helper\n .getOrgLabels(config.repository.split('/')[0], {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} org labels`);\n return labels;\n })\n .catch(() => {\n // Will fail if owner of repo is not org or Gitea version < 1.12\n logger.debug(`Unable to fetch organization labels`);\n return [] as Label[];\n });\n\n config.labelList = Promise.all([repoLabels, orgLabels]).then((labels) =>\n ([] as Label[]).concat(...labels),\n );\n }\n\n return config.labelList;\n}\n\nasync function lookupLabelByName(name: string): Promise<number | null> {\n logger.debug(`lookupLabelByName(${name})`);\n const labelList = await getLabelList();\n return labelList.find((l) => l.name === name)?.id ?? null;\n}\n\ninterface FetchRepositoriesArgs {\n topic?: string;\n sort?: RepoSortMethod;\n order?: SortMethod;\n}\n\nasync function fetchRepositories({\n topic,\n sort,\n order,\n}: FetchRepositoriesArgs): Promise<string[]> {\n const repos = await helper.searchRepos({\n uid: botUserID,\n archived: false,\n ...(topic && {\n topic: true,\n q: topic,\n }),\n ...(sort && {\n sort,\n }),\n ...(order && {\n order,\n }),\n });\n return repos.filter(usableRepo).map((r) => r.full_name);\n}\n\nconst platform: Platform = {\n async initPlatform({\n endpoint,\n token,\n }: PlatformParams): Promise<PlatformResult> {\n if (!token) {\n throw new Error('Init: You must configure a Gitea personal access token');\n }\n\n if (endpoint) {\n let baseEndpoint = trimTrailingApiPath(endpoint);\n baseEndpoint = ensureTrailingSlash(baseEndpoint);\n defaults.endpoint = baseEndpoint;\n } else {\n logger.debug(`Using default Gitea endpoint: ${defaults.endpoint}`);\n }\n setBaseUrl(defaults.endpoint);\n\n let gitAuthor: string;\n try {\n const user = await helper.getCurrentUser({ token });\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing -- `full_name` can be emtpy string\n gitAuthor = `${user.full_name || user.username} <${user.email}>`;\n botUserID = user.id;\n botUserName = user.username;\n const env = getEnv();\n /* v8 ignore next: experimental feature */\n if (semver.valid(env.RENOVATE_X_PLATFORM_VERSION)) {\n defaults.version = env.RENOVATE_X_PLATFORM_VERSION!;\n } else {\n defaults.version = await helper.getVersion({ token });\n }\n if (defaults.version?.includes('gitea-')) {\n defaults.isForgejo = true;\n logger.info(\n `Detected Forgejo instance, please use 'forgejo' platform instead`,\n );\n }\n logger.debug(\n `${defaults.isForgejo ? 'Forgejo' : 'Gitea'} version: ${defaults.version}`,\n );\n } catch (err) {\n logger.debug(\n { err },\n 'Error authenticating with Gitea. Check your token',\n );\n throw new Error('Init: Authentication failure');\n }\n\n return {\n endpoint: defaults.endpoint,\n gitAuthor,\n };\n },\n\n async getRawFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<string | null> {\n const repo = repoName ?? config.repository;\n const contents = await helper.getRepoContents(repo, fileName, branchOrTag);\n return contents.contentString ?? null;\n },\n\n async getJsonFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<any> {\n // TODO #22198\n const raw = await platform.getRawFile(fileName, repoName, branchOrTag);\n return parseJson(raw, fileName);\n },\n\n async initRepo({\n repository,\n cloneSubmodules,\n cloneSubmodulesFilter,\n gitUrl,\n }: RepoParams): Promise<RepoResult> {\n let repo: Repo;\n\n config = {} as any;\n config.repository = repository;\n config.cloneSubmodules = !!cloneSubmodules;\n config.cloneSubmodulesFilter = cloneSubmodulesFilter;\n config.ignorePrAuthor = GlobalConfig.get('ignorePrAuthor');\n\n // Try to fetch information about repository\n try {\n repo = await helper.getRepo(repository);\n } catch (err) {\n logger.debug({ err }, 'Unknown Gitea initRepo error');\n throw err;\n }\n\n // Ensure appropriate repository state and permissions\n if (repo.archived) {\n logger.debug('Repository is archived - aborting renovation');\n throw new Error(REPOSITORY_ARCHIVED);\n }\n if (repo.mirror) {\n logger.debug('Repository is a mirror - aborting renovation');\n throw new Error(REPOSITORY_MIRRORED);\n }\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n 'Repository does not permit pull or push - aborting renovation',\n );\n throw new Error(REPOSITORY_ACCESS_FORBIDDEN);\n }\n if (repo.empty) {\n logger.debug('Repository is empty - aborting renovation');\n throw new Error(REPOSITORY_EMPTY);\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug('Repo has disabled pull requests - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n // similar to gitea behaviour- if default merge style is allowed, use this;\n // else fall back to predefined order. Order chosen to minimize commits - see\n // https://github.com/renovatebot/renovate/pull/37768 for discussion.\n const preferredOrder: PRMergeMethod[] = [\n repo.default_merge_style,\n 'fast-forward-only',\n 'squash',\n 'merge',\n 'rebase',\n 'rebase-merge',\n ];\n\n const mergeStyle = preferredOrder.find((style) => isAllowed(style, repo));\n\n if (mergeStyle) {\n config.mergeMethod = mergeStyle;\n } else {\n logger.debug(\n 'Repository has no allowed merge methods - aborting renovation',\n );\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n // Determine author email and branches\n config.defaultBranch = repo.default_branch;\n logger.debug(`${repository} default branch = ${config.defaultBranch}`);\n\n const url = getRepoUrl(repo, gitUrl, defaults.endpoint);\n\n // Initialize Git storage\n await git.initRepo({\n ...config,\n url,\n });\n\n // Reset cached resources\n config.issueList = null;\n config.labelList = null;\n config.hasIssuesEnabled = !repo.external_tracker && repo.has_issues;\n\n return {\n defaultBranch: config.defaultBranch,\n isFork: !!repo.fork,\n repoFingerprint: repoFingerprint(repo.id, defaults.endpoint),\n };\n },\n\n async getRepos(config?: AutodiscoverConfig): Promise<string[]> {\n logger.debug('Auto-discovering Gitea repositories');\n try {\n if (config?.topics) {\n logger.debug({ topics: config.topics }, 'Auto-discovering by topics');\n const fetchRepoArgs: FetchRepositoriesArgs[] = config.topics.map(\n (topic) => {\n return {\n topic,\n sort: config.sort,\n order: config.order,\n };\n },\n );\n const repos = await map(fetchRepoArgs, fetchRepositories);\n return deduplicateArray(repos.flat());\n } else if (config?.namespaces) {\n logger.debug(\n { namespaces: config.namespaces },\n 'Auto-discovering by organization',\n );\n const repos = await map(\n config.namespaces,\n async (organization: string) => {\n const orgRepos = await helper.orgListRepos(organization);\n return orgRepos\n .filter((r) => !r.mirror && !r.archived)\n .map((r) => r.full_name);\n },\n );\n return deduplicateArray(repos.flat());\n } else {\n return await fetchRepositories({\n sort: config?.sort,\n order: config?.order,\n });\n }\n } catch (err) {\n logger.error({ err }, 'Gitea getRepos() error');\n throw err;\n }\n },\n\n async setBranchStatus({\n branchName,\n context,\n description,\n state,\n url: target_url,\n }: BranchStatusConfig): Promise<void> {\n try {\n // Create new status for branch commit\n const branchCommit = git.getBranchCommit(branchName);\n // TODO: check branchCommit\n\n await helper.createCommitStatus(config.repository, branchCommit!, {\n state: helper.renovateToGiteaStatusMapping[state] || 'pending',\n context,\n description,\n ...(target_url && { target_url }),\n });\n\n // Refresh caches by re-fetching commit status for branch\n await helper.getCombinedCommitStatus(config.repository, branchName, {\n memCache: false,\n });\n } catch (err) {\n logger.warn({ err }, 'Failed to set branch status');\n }\n },\n\n async getBranchStatus(\n branchName: string,\n internalChecksAsSuccess: boolean,\n ): Promise<BranchStatus> {\n let ccs: CombinedCommitStatus;\n try {\n ccs = await helper.getCombinedCommitStatus(config.repository, branchName);\n } catch (err) {\n if (err.statusCode === 404) {\n logger.debug(\n 'Received 404 when checking branch status, assuming branch deletion',\n );\n throw new Error(REPOSITORY_CHANGED);\n }\n\n logger.debug('Unknown error when checking branch status');\n throw err;\n }\n\n logger.debug({ ccs }, 'Branch status check result');\n if (\n !internalChecksAsSuccess &&\n ccs.worstStatus === 'success' &&\n ccs.statuses.every((status) => status.context?.startsWith('renovate/'))\n ) {\n logger.debug(\n 'Successful checks are all internal renovate/ checks, so returning \"pending\" branch status',\n );\n return 'yellow';\n }\n\n /* v8 ignore next */\n return helper.giteaToRenovateStatusMapping[ccs.worstStatus] ?? 'yellow';\n },\n\n async getBranchStatusCheck(\n branchName: string,\n context: string,\n ): Promise<BranchStatus | null> {\n const ccs = await helper.getCombinedCommitStatus(\n config.repository,\n branchName,\n );\n const cs = ccs.statuses.find((s) => s.context === context);\n if (!cs) {\n return null;\n } // no status check exists\n const status = helper.giteaToRenovateStatusMapping[cs.status];\n if (status) {\n return status;\n }\n logger.warn(\n { check: cs },\n 'Could not map Gitea status value to Renovate status',\n );\n return 'yellow';\n },\n\n getPrList(): Promise<Pr[]> {\n return GiteaPrCache.getPrs(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n );\n },\n\n async getPr(number: number): Promise<Pr | null> {\n // Search for pull request in cached list or attempt to query directly\n const prList = await platform.getPrList();\n let pr = prList.find((p) => p.number === number) ?? null;\n if (pr) {\n logger.debug('Returning from cached PRs');\n } else {\n logger.debug('PR not found in cached PRs - trying to fetch directly');\n const gpr = await helper.getPR(config.repository, number);\n pr = toRenovatePR(gpr, botUserName);\n\n // Add pull request to cache for further lookups / queries\n if (pr) {\n await GiteaPrCache.setPr(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n }\n\n // Abort and return null if no match was found\n if (!pr) {\n return null;\n }\n\n return pr;\n },\n\n async findPr({\n branchName,\n prTitle: title,\n state = 'all',\n includeOtherAuthors,\n targetBranch,\n }: FindPRConfig): Promise<Pr | null> {\n logger.debug(`findPr(${branchName}, ${title!}, ${state})`);\n if (includeOtherAuthors && isString(targetBranch)) {\n // do not use pr cache as it only fetches prs created by the bot account\n const pr = await helper.getPRByBranch(\n config.repository,\n targetBranch,\n branchName,\n );\n if (!pr) {\n return null;\n }\n\n return toRenovatePR(pr, null);\n }\n const prList = await platform.getPrList();\n const pr = prList.find(\n (p) =>\n p.sourceRepo === config.repository &&\n p.sourceBranch === branchName &&\n matchesState(p.state, state) &&\n (!title || p.title === title),\n );\n\n if (pr) {\n logger.debug(`Found PR #${pr.number}`);\n }\n return pr ?? null;\n },\n\n async createPr({\n sourceBranch,\n targetBranch,\n prTitle,\n prBody: rawBody,\n labels: labelNames,\n platformPrOptions,\n draftPR,\n }: CreatePRConfig): Promise<Pr> {\n let title = prTitle;\n const base = targetBranch;\n const head = sourceBranch;\n const body = sanitize(rawBody);\n if (draftPR) {\n title = DRAFT_PREFIX + title;\n }\n\n logger.debug(`Creating pull request: ${title} (${head} => ${base})`);\n try {\n const labels = Array.isArray(labelNames)\n ? await map(labelNames, lookupLabelByName)\n : [];\n const gpr = await helper.createPR(config.repository, {\n base,\n head,\n title,\n body,\n labels: labels.filter(isNumber),\n });\n\n if (platformPrOptions?.usePlatformAutomerge) {\n // Only Gitea v1.24.0+ and Forgejo v10.0.0+ support delete_branch_after_merge.\n // This is required to not have undesired behavior when renovate finds existing branches on next run.\n if (\n semver.gte(defaults.version, defaults.isForgejo ? '10.0.0' : '1.24.0')\n ) {\n try {\n await helper.mergePR(config.repository, gpr.number, {\n Do:\n getMergeMethod(platformPrOptions?.automergeStrategy) ??\n config.mergeMethod,\n merge_when_checks_succeed: true,\n delete_branch_after_merge: true,\n });\n\n logger.debug(\n { prNumber: gpr.number },\n 'Gitea-native automerge: success',\n );\n } catch (err) {\n logger.warn(\n { err, prNumber: gpr.number },\n 'Gitea-native automerge: fail',\n );\n }\n } else {\n logger.debug(\n { prNumber: gpr.number },\n `Gitea-native automerge: not supported on this version of ${defaults.isForgejo ? 'Forgejo' : 'Gitea'}. Use ${defaults.isForgejo ? '10.0.0' : '1.24.0'} or newer.`,\n );\n }\n }\n\n const pr = toRenovatePR(gpr, botUserName);\n if (!pr) {\n throw new Error('Can not parse newly created Pull Request');\n }\n\n await GiteaPrCache.setPr(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n return pr;\n } catch (err) {\n // When the user manually deletes a branch from Renovate, the PR remains but is no longer linked to any branch. In\n // the most recent versions of Gitea, the PR gets automatically closed when that happens, but older versions do\n // not handle this properly and keep the PR open. As pushing a branch with the same name resurrects the PR, this\n // would cause a HTTP 409 conflict error, which we hereby gracefully handle.\n if (err.statusCode === 409) {\n logger.warn(\n { prTitle: title, sourceBranch },\n 'Attempting to gracefully recover from 409 Conflict response in createPr()',\n );\n\n // Refresh cached PR list and search for pull request with matching information\n GiteaPrCache.forceSync();\n const pr = await platform.findPr({\n branchName: sourceBranch,\n state: 'open',\n });\n\n // If a valid PR was found, return and gracefully recover from the error. Otherwise, abort and throw error.\n // v8 ignore else -- TODO: add test #40625\n if (pr?.bodyStruct) {\n if (pr.title !== title || pr.bodyStruct.hash !== hashBody(body)) {\n logger.debug(\n `Recovered from 409 Conflict, but PR for ${sourceBranch} is outdated. Updating...`,\n );\n await platform.updatePr({\n number: pr.number,\n prTitle: title,\n prBody: body,\n });\n pr.title = title;\n pr.bodyStruct = getPrBodyStruct(body);\n } else {\n logger.debug(\n `Recovered from 409 Conflict and PR for ${sourceBranch} is up-to-date`,\n );\n }\n\n return pr;\n }\n }\n\n throw err;\n }\n },\n\n async updatePr({\n number,\n prTitle,\n prBody: body,\n labels,\n state,\n targetBranch,\n }: UpdatePrConfig): Promise<void> {\n let title = prTitle;\n if ((await getPrList()).find((pr) => pr.number === number)?.isDraft) {\n title = DRAFT_PREFIX + title;\n }\n\n const prUpdateParams: PRUpdateParams = {\n title,\n ...(body && { body }),\n ...(state && { state }),\n };\n if (targetBranch) {\n prUpdateParams.base = targetBranch;\n }\n\n /**\n * Update PR labels.\n * In the Gitea API, labels are replaced on each update if the field is present.\n * If the field is not present (i.e., undefined), labels aren't updated.\n * However, the labels array must contain label IDs instead of names,\n * so a lookup is performed to fetch the details (including the ID) of each label.\n */\n if (Array.isArray(labels)) {\n prUpdateParams.labels = (await map(labels, lookupLabelByName)).filter(\n isNumber,\n );\n if (labels.length !== prUpdateParams.labels.length) {\n logger.warn(\n 'Some labels could not be looked up. Renovate may halt label updates assuming changes by others.',\n );\n }\n }\n\n const gpr = await helper.updatePR(\n config.repository,\n number,\n prUpdateParams,\n );\n const pr = toRenovatePR(gpr, botUserName);\n if (pr) {\n await GiteaPrCache.setPr(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n },\n\n async mergePr({ id, strategy }: MergePRConfig): Promise<boolean> {\n try {\n await helper.mergePR(config.repository, id, {\n Do: getMergeMethod(strategy) ?? config.mergeMethod,\n });\n return true;\n } catch (err) {\n logger.warn({ err, id }, 'Merging of PR failed');\n return false;\n }\n },\n\n getIssueList(): Promise<Issue[]> {\n if (config.hasIssuesEnabled === false) {\n return Promise.resolve([]);\n }\n config.issueList ??= helper\n .searchIssues(config.repository, { state: 'all' }, { memCache: false })\n .then((issues) => {\n const issueList = issues.map(toRenovateIssue);\n logger.debug(`Retrieved ${issueList.length} Issues`);\n return issueList;\n });\n\n return config.issueList;\n },\n\n async getIssue(number: number, memCache = true): Promise<Issue | null> {\n if (config.hasIssuesEnabled === false) {\n return null;\n }\n try {\n const body = (\n await helper.getIssue(config.repository, number, { memCache })\n ).body;\n return {\n number,\n body,\n };\n } catch (err) /* v8 ignore next */ {\n logger.debug({ err, number }, 'Error getting issue');\n return null;\n }\n },\n\n async findIssue(title: string): Promise<Issue | null> {\n const issueList = await platform.getIssueList();\n const issue = issueList.find(\n (i) => i.state === 'open' && i.title === title,\n );\n\n if (!issue) {\n return null;\n }\n // TODO: types (#22198)\n logger.debug(`Found Issue #${issue.number!}`);\n // TODO #22198\n return getIssue!(issue.number!);\n },\n\n async ensureIssue({\n title,\n reuseTitle,\n body: content,\n labels: labelNames,\n shouldReOpen,\n once,\n }: EnsureIssueConfig): Promise<'updated' | 'created' | null> {\n logger.debug(`ensureIssue(${title})`);\n if (config.hasIssuesEnabled === false) {\n logger.info(\n 'Cannot ensure issue because issues are disabled in this repository',\n );\n return null;\n }\n try {\n const body = smartLinks(content);\n\n const issueList = await platform.getIssueList();\n let issues = issueList.filter((i) => i.title === title);\n if (!issues.length) {\n issues = issueList.filter((i) => i.title === reuseTitle);\n }\n\n const labels = Array.isArray(labelNames)\n ? (await Promise.all(labelNames.map(lookupLabelByName))).filter(\n isNumber,\n )\n : undefined;\n\n // Update any matching issues which currently exist\n if (issues.length) {\n let activeIssue = issues.find((i) => i.state === 'open');\n\n // If no active issue was found, decide if it shall be skipped, re-opened or updated without state change\n if (!activeIssue) {\n if (once) {\n logger.debug('Issue already closed - skipping update');\n return null;\n }\n if (shouldReOpen) {\n logger.debug('Reopening previously closed Issue');\n }\n\n // Pick the last issue in the list as the active one\n activeIssue = issues[issues.length - 1];\n }\n\n // Close any duplicate issues\n for (const issue of issues) {\n if (issue.state === 'open' && issue.number !== activeIssue.number) {\n // TODO: types (#22198)\n logger.warn({ issueNo: issue.number! }, 'Closing duplicate issue');\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n\n // Check if issue has already correct state\n if (\n activeIssue.title === title &&\n activeIssue.body === body &&\n activeIssue.state === 'open'\n ) {\n logger.debug(\n // TODO: types (#22198)\n `Issue #${activeIssue.number!} is open and up to date - nothing to do`,\n );\n return null;\n }\n\n if (shouldReOpen || activeIssue.state === 'open') {\n // Update issue body and re-open\n logger.debug(`Updating Issue #${activeIssue.number}`);\n const existingIssue = await helper.updateIssue(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n body,\n title,\n state: 'open',\n },\n );\n\n // Test whether the issues need to be updated\n const existingLabelIds = (existingIssue.labels ?? []).map(\n (label) => label.id,\n );\n if (\n labels &&\n (labels.length !== existingLabelIds.length ||\n labels.filter((labelId) => !existingLabelIds.includes(labelId))\n .length !== 0)\n ) {\n await helper.updateIssueLabels(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n labels,\n },\n );\n }\n\n return 'updated';\n }\n }\n\n // Create new issue and reset cache\n const issue = await helper.createIssue(config.repository, {\n body,\n title,\n labels,\n });\n logger.debug(`Created new Issue #${issue.number}`);\n config.issueList = null;\n\n return 'created';\n } catch (err) {\n logger.warn({ err }, 'Could not ensure issue');\n }\n\n return null;\n },\n\n async ensureIssueClosing(title: string): Promise<void> {\n logger.debug(`ensureIssueClosing(${title})`);\n if (config.hasIssuesEnabled === false) {\n return;\n }\n const issueList = await platform.getIssueList();\n for (const issue of issueList) {\n if (issue.state === 'open' && issue.title === title) {\n logger.debug(`Closing issue...issueNo: ${issue.number!}`);\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n },\n\n async deleteLabel(issue: number, labelName: string): Promise<void> {\n logger.debug(`Deleting label ${labelName} from Issue #${issue}`);\n const label = await lookupLabelByName(labelName);\n if (label) {\n await helper.unassignLabel(config.repository, issue, label);\n } else {\n logger.warn({ issue, labelName }, 'Failed to lookup label for deletion');\n }\n },\n\n async ensureComment({\n number: issue,\n topic,\n content,\n }: EnsureCommentConfig): Promise<boolean> {\n try {\n let body = sanitize(content);\n const commentList = await helper.getComments(config.repository, issue);\n\n // Search comment by either topic or exact body\n let comment: Comment | null = null;\n if (topic) {\n comment = findCommentByTopic(commentList, topic);\n body = `### ${topic}\\n\\n${body}`;\n } else {\n comment = findCommentByContent(commentList, body);\n }\n\n // Create a new comment if no match has been found, otherwise update if necessary\n if (!comment) {\n comment = await helper.createComment(config.repository, issue, body);\n logger.info(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment added',\n );\n } else if (comment.body === body) {\n logger.debug(`Comment #${comment.id} is already up-to-date`);\n } else {\n await helper.updateComment(config.repository, comment.id, body);\n logger.debug(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment updated',\n );\n }\n\n return true;\n } catch (err) {\n logger.warn({ err, issue, subject: topic }, 'Error ensuring comment');\n return false;\n }\n },\n\n async ensureCommentRemoval(\n deleteConfig: EnsureCommentRemovalConfig,\n ): Promise<void> {\n const { number: issue } = deleteConfig;\n const key =\n deleteConfig.type === 'by-topic'\n ? deleteConfig.topic\n : deleteConfig.content;\n logger.debug(`Ensuring comment \"${key}\" in #${issue} is removed`);\n const commentList = await helper.getComments(config.repository, issue);\n\n let comment: Comment | null = null;\n // v8 ignore else -- TODO: add test #40625\n if (deleteConfig.type === 'by-topic') {\n comment = findCommentByTopic(commentList, deleteConfig.topic);\n } else if (deleteConfig.type === 'by-content') {\n const body = sanitize(deleteConfig.content);\n comment = findCommentByContent(commentList, body);\n }\n\n // Abort and do nothing if no matching comment was found\n if (!comment) {\n return;\n }\n\n // Try to delete comment\n try {\n await helper.deleteComment(config.repository, comment.id);\n } catch (err) {\n logger.warn(\n { err, issue, config: deleteConfig },\n 'Error deleting comment',\n );\n }\n },\n\n async getBranchPr(branchName: string): Promise<Pr | null> {\n logger.debug(`getBranchPr(${branchName})`);\n const pr = await platform.findPr({ branchName, state: 'open' });\n return pr ? platform.getPr(pr.number) : null;\n },\n\n async addAssignees(number: number, assignees: string[]): Promise<void> {\n logger.debug(\n `Updating assignees '${assignees?.join(', ')}' on Issue #${number}`,\n );\n await helper.updateIssue(config.repository, number, {\n assignees,\n });\n },\n\n async addReviewers(number: number, reviewers: string[]): Promise<void> {\n logger.debug(`Adding reviewers '${reviewers?.join(', ')}' to #${number}`);\n if (semver.lt(defaults.version, '1.14.0')) {\n logger.debug(\n { version: defaults.version },\n 'Adding reviewer not yet supported.',\n );\n return;\n }\n try {\n await helper.requestPrReviewers(config.repository, number, { reviewers });\n } catch (err) {\n logger.warn({ err, number, reviewers }, 'Failed to assign reviewer');\n }\n },\n\n massageMarkdown(prBody: string): string {\n return smartTruncate(smartLinks(prBody), maxBodyLength());\n },\n\n maxBodyLength,\n};\n\nexport function maxBodyLength(): number {\n return 1000000;\n}\n\n/* oxlint-disable typescript/unbound-method */\nexport const {\n addAssignees,\n addReviewers,\n createPr,\n deleteLabel,\n ensureComment,\n ensureCommentRemoval,\n ensureIssue,\n ensureIssueClosing,\n findIssue,\n findPr,\n getBranchPr,\n getBranchStatus,\n getBranchStatusCheck,\n getIssue,\n getRawFile,\n getJsonFile,\n getIssueList,\n getPr,\n massageMarkdown,\n getPrList,\n getRepos,\n initPlatform,\n initRepo,\n mergePr,\n setBranchStatus,\n updatePr,\n} = platform;\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":["helper\n .getRepoLabels","helper\n .getOrgLabels","helper.searchRepos","helper.getCurrentUser","helper.getVersion","helper.getRepoContents","helper.getRepo","git.initRepo","helper.orgListRepos","git.getBranchCommit","helper.createCommitStatus","helper.renovateToGiteaStatusMapping","helper.getCombinedCommitStatus","helper.giteaToRenovateStatusMapping","helper.getPR","helper.getPRByBranch","helper.createPR","helper.mergePR","helper.updatePR","helper\n .searchIssues","helper.getIssue","helper.closeIssue","helper.updateIssue","helper.updateIssueLabels","helper.createIssue","helper.unassignLabel","helper.getComments","helper.createComment","helper.updateComment","helper.deleteComment","helper.requestPrReviewers"],"sources":["../../../../lib/modules/platform/gitea/index.ts"],"sourcesContent":["import { isNumber, isString } from '@sindresorhus/is';\nimport semver from 'semver';\nimport { GlobalConfig } from '../../../config/global.ts';\nimport {\n REPOSITORY_ACCESS_FORBIDDEN,\n REPOSITORY_ARCHIVED,\n REPOSITORY_BLOCKED,\n REPOSITORY_CHANGED,\n REPOSITORY_EMPTY,\n REPOSITORY_MIRRORED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport type { BranchStatus } from '../../../types/index.ts';\nimport { deduplicateArray } from '../../../util/array.ts';\nimport { parseJson } from '../../../util/common.ts';\nimport { getEnv } from '../../../util/env.ts';\nimport * as git from '../../../util/git/index.ts';\nimport { setBaseUrl } from '../../../util/http/gitea.ts';\nimport { map } from '../../../util/promises.ts';\nimport { sanitize } from '../../../util/sanitize.ts';\nimport { ensureTrailingSlash } from '../../../util/url.ts';\nimport { getPrBodyStruct, hashBody } from '../pr-body.ts';\nimport type {\n AutodiscoverConfig,\n BranchStatusConfig,\n CreatePRConfig,\n EnsureCommentConfig,\n EnsureCommentRemovalConfig,\n EnsureIssueConfig,\n FindPRConfig,\n Issue,\n MergePRConfig,\n Platform,\n PlatformParams,\n PlatformResult,\n Pr,\n RepoParams,\n RepoResult,\n RepoSortMethod,\n SortMethod,\n UpdatePrConfig,\n} from '../types.ts';\nimport { repoFingerprint } from '../util.ts';\nimport { smartTruncate } from '../utils/pr-body.ts';\nimport * as helper from './gitea-helper.ts';\nimport { giteaHttp } from './gitea-helper.ts';\nimport { GiteaPrCache } from './pr-cache.ts';\nimport type {\n CombinedCommitStatus,\n Comment,\n Label,\n PRMergeMethod,\n PRUpdateParams,\n Repo,\n} from './types.ts';\nimport {\n DRAFT_PREFIX,\n getMergeMethod,\n getRepoUrl,\n isAllowed,\n smartLinks,\n toRenovatePR,\n trimTrailingApiPath,\n usableRepo,\n} from './utils.ts';\n\ninterface GiteaRepoConfig {\n ignorePrAuthor: boolean;\n repository: string;\n mergeMethod: PRMergeMethod;\n\n issueList: Promise<Issue[]> | null;\n labelList: Promise<Label[]> | null;\n defaultBranch: string;\n cloneSubmodules: boolean;\n cloneSubmodulesFilter: string[] | undefined;\n hasIssuesEnabled: boolean;\n}\n\nexport const id = 'gitea';\n\nconst defaults = {\n hostType: 'gitea',\n endpoint: 'https://gitea.com/',\n version: '0.0.0',\n isForgejo: false,\n};\n\nlet config: GiteaRepoConfig = {} as any;\nlet botUserID: number;\nlet botUserName: string;\n\nexport function resetPlatform(): void {\n config = {} as any;\n botUserID = undefined as never;\n botUserName = undefined as never;\n defaults.hostType = 'gitea';\n defaults.endpoint = 'https://gitea.com/';\n defaults.version = '0.0.0';\n defaults.isForgejo = false;\n setBaseUrl(defaults.endpoint);\n}\n\nfunction toRenovateIssue(data: Issue): Issue {\n return {\n number: data.number,\n state: data.state,\n title: data.title,\n body: data.body,\n };\n}\n\nfunction matchesState(actual: string, expected: string): boolean {\n if (expected === 'all') {\n return true;\n }\n if (expected.startsWith('!')) {\n return actual !== expected.substring(1);\n }\n\n return actual === expected;\n}\n\nfunction findCommentByTopic(\n comments: Comment[],\n topic: string,\n): Comment | null {\n return comments.find((c) => c.body.startsWith(`### ${topic}\\n\\n`)) ?? null;\n}\n\nfunction findCommentByContent(\n comments: Comment[],\n content: string,\n): Comment | null {\n return comments.find((c) => c.body.trim() === content) ?? null;\n}\n\nfunction getLabelList(): Promise<Label[]> {\n if (config.labelList === null) {\n const repoLabels = helper\n .getRepoLabels(config.repository, {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} repo labels`);\n return labels;\n });\n\n const orgLabels = helper\n .getOrgLabels(config.repository.split('/')[0], {\n memCache: false,\n })\n .then((labels) => {\n logger.debug(`Retrieved ${labels.length} org labels`);\n return labels;\n })\n .catch(() => {\n // Will fail if owner of repo is not org or Gitea version < 1.12\n logger.debug(`Unable to fetch organization labels`);\n return [] as Label[];\n });\n\n config.labelList = Promise.all([repoLabels, orgLabels]).then((labels) =>\n ([] as Label[]).concat(...labels),\n );\n }\n\n return config.labelList;\n}\n\nasync function lookupLabelByName(name: string): Promise<number | null> {\n logger.debug(`lookupLabelByName(${name})`);\n const labelList = await getLabelList();\n return labelList.find((l) => l.name === name)?.id ?? null;\n}\n\ninterface FetchRepositoriesArgs {\n topic?: string;\n sort?: RepoSortMethod;\n order?: SortMethod;\n}\n\nasync function fetchRepositories({\n topic,\n sort,\n order,\n}: FetchRepositoriesArgs): Promise<string[]> {\n const repos = await helper.searchRepos({\n uid: botUserID,\n archived: false,\n ...(topic && {\n topic: true,\n q: topic,\n }),\n ...(sort && {\n sort,\n }),\n ...(order && {\n order,\n }),\n });\n return repos.filter(usableRepo).map((r) => r.full_name);\n}\n\nconst platform: Platform = {\n async initPlatform({\n endpoint,\n token,\n }: PlatformParams): Promise<PlatformResult> {\n if (!token) {\n throw new Error('Init: You must configure a Gitea personal access token');\n }\n\n if (endpoint) {\n let baseEndpoint = trimTrailingApiPath(endpoint);\n baseEndpoint = ensureTrailingSlash(baseEndpoint);\n defaults.endpoint = baseEndpoint;\n } else {\n logger.debug(`Using default Gitea endpoint: ${defaults.endpoint}`);\n }\n setBaseUrl(defaults.endpoint);\n\n let gitAuthor: string;\n try {\n const user = await helper.getCurrentUser({ token });\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing -- `full_name` can be emtpy string\n gitAuthor = `${user.full_name || user.login} <${user.email}>`;\n botUserID = user.id;\n botUserName = user.login;\n const env = getEnv();\n /* v8 ignore next: experimental feature */\n if (semver.valid(env.RENOVATE_X_PLATFORM_VERSION)) {\n defaults.version = env.RENOVATE_X_PLATFORM_VERSION!;\n } else {\n defaults.version = await helper.getVersion({ token });\n }\n if (defaults.version?.includes('gitea-')) {\n defaults.isForgejo = true;\n logger.info(\n `Detected Forgejo instance, please use 'forgejo' platform instead`,\n );\n }\n logger.debug(\n `${defaults.isForgejo ? 'Forgejo' : 'Gitea'} version: ${defaults.version}`,\n );\n } catch (err) {\n logger.debug(\n { err },\n 'Error authenticating with Gitea. Check your token',\n );\n throw new Error('Init: Authentication failure');\n }\n\n return {\n endpoint: defaults.endpoint,\n gitAuthor,\n };\n },\n\n async getRawFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<string | null> {\n const repo = repoName ?? config.repository;\n const contents = await helper.getRepoContents(repo, fileName, branchOrTag);\n return contents.contentString ?? null;\n },\n\n async getJsonFile(\n fileName: string,\n repoName?: string,\n branchOrTag?: string,\n ): Promise<any> {\n // TODO #22198\n const raw = await platform.getRawFile(fileName, repoName, branchOrTag);\n return parseJson(raw, fileName);\n },\n\n async initRepo({\n repository,\n cloneSubmodules,\n cloneSubmodulesFilter,\n gitUrl,\n }: RepoParams): Promise<RepoResult> {\n let repo: Repo;\n\n config = {} as any;\n config.repository = repository;\n config.cloneSubmodules = !!cloneSubmodules;\n config.cloneSubmodulesFilter = cloneSubmodulesFilter;\n config.ignorePrAuthor = GlobalConfig.get('ignorePrAuthor');\n\n // Try to fetch information about repository\n try {\n repo = await helper.getRepo(repository);\n } catch (err) {\n logger.debug({ err }, 'Unknown Gitea initRepo error');\n throw err;\n }\n\n // Ensure appropriate repository state and permissions\n if (repo.archived) {\n logger.debug('Repository is archived - aborting renovation');\n throw new Error(REPOSITORY_ARCHIVED);\n }\n if (repo.mirror) {\n logger.debug('Repository is a mirror - aborting renovation');\n throw new Error(REPOSITORY_MIRRORED);\n }\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n 'Repository does not permit pull or push - aborting renovation',\n );\n throw new Error(REPOSITORY_ACCESS_FORBIDDEN);\n }\n if (repo.empty) {\n logger.debug('Repository is empty - aborting renovation');\n throw new Error(REPOSITORY_EMPTY);\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug('Repo has disabled pull requests - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n // similar to gitea behaviour- if default merge style is allowed, use this;\n // else fall back to predefined order. Order chosen to minimize commits - see\n // https://github.com/renovatebot/renovate/pull/37768 for discussion.\n const preferredOrder: PRMergeMethod[] = [\n repo.default_merge_style,\n 'fast-forward-only',\n 'squash',\n 'merge',\n 'rebase',\n 'rebase-merge',\n ];\n\n const mergeStyle = preferredOrder.find((style) => isAllowed(style, repo));\n\n if (mergeStyle) {\n config.mergeMethod = mergeStyle;\n } else {\n logger.debug(\n 'Repository has no allowed merge methods - aborting renovation',\n );\n throw new Error(REPOSITORY_BLOCKED);\n }\n\n // Determine author email and branches\n config.defaultBranch = repo.default_branch;\n logger.debug(`${repository} default branch = ${config.defaultBranch}`);\n\n const url = getRepoUrl(repo, gitUrl, defaults.endpoint);\n\n // Initialize Git storage\n await git.initRepo({\n ...config,\n url,\n });\n\n // Reset cached resources\n config.issueList = null;\n config.labelList = null;\n config.hasIssuesEnabled = !repo.external_tracker && repo.has_issues;\n\n return {\n defaultBranch: config.defaultBranch,\n isFork: !!repo.fork,\n repoFingerprint: repoFingerprint(repo.id, defaults.endpoint),\n };\n },\n\n async getRepos(config?: AutodiscoverConfig): Promise<string[]> {\n logger.debug('Auto-discovering Gitea repositories');\n try {\n if (config?.topics) {\n logger.debug({ topics: config.topics }, 'Auto-discovering by topics');\n const fetchRepoArgs: FetchRepositoriesArgs[] = config.topics.map(\n (topic) => {\n return {\n topic,\n sort: config.sort,\n order: config.order,\n };\n },\n );\n const repos = await map(fetchRepoArgs, fetchRepositories);\n return deduplicateArray(repos.flat());\n } else if (config?.namespaces) {\n logger.debug(\n { namespaces: config.namespaces },\n 'Auto-discovering by organization',\n );\n const repos = await map(\n config.namespaces,\n async (organization: string) => {\n const orgRepos = await helper.orgListRepos(organization);\n return orgRepos\n .filter((r) => !r.mirror && !r.archived)\n .map((r) => r.full_name);\n },\n );\n return deduplicateArray(repos.flat());\n } else {\n return await fetchRepositories({\n sort: config?.sort,\n order: config?.order,\n });\n }\n } catch (err) {\n logger.error({ err }, 'Gitea getRepos() error');\n throw err;\n }\n },\n\n async setBranchStatus({\n branchName,\n context,\n description,\n state,\n url: target_url,\n }: BranchStatusConfig): Promise<void> {\n try {\n // Create new status for branch commit\n const branchCommit = git.getBranchCommit(branchName);\n // TODO: check branchCommit\n\n await helper.createCommitStatus(config.repository, branchCommit!, {\n state: helper.renovateToGiteaStatusMapping[state] || 'pending',\n context,\n description,\n ...(target_url && { target_url }),\n });\n\n // Refresh caches by re-fetching commit status for branch\n await helper.getCombinedCommitStatus(config.repository, branchName, {\n memCache: false,\n });\n } catch (err) {\n logger.warn({ err }, 'Failed to set branch status');\n }\n },\n\n async getBranchStatus(\n branchName: string,\n internalChecksAsSuccess: boolean,\n ): Promise<BranchStatus> {\n let ccs: CombinedCommitStatus;\n try {\n ccs = await helper.getCombinedCommitStatus(config.repository, branchName);\n } catch (err) {\n if (err.statusCode === 404) {\n logger.debug(\n 'Received 404 when checking branch status, assuming branch deletion',\n );\n throw new Error(REPOSITORY_CHANGED);\n }\n\n logger.debug('Unknown error when checking branch status');\n throw err;\n }\n\n logger.debug({ ccs }, 'Branch status check result');\n if (\n !internalChecksAsSuccess &&\n ccs.worstStatus === 'success' &&\n ccs.statuses.every((status) => status.context?.startsWith('renovate/'))\n ) {\n logger.debug(\n 'Successful checks are all internal renovate/ checks, so returning \"pending\" branch status',\n );\n return 'yellow';\n }\n\n /* v8 ignore next */\n return helper.giteaToRenovateStatusMapping[ccs.worstStatus] ?? 'yellow';\n },\n\n async getBranchStatusCheck(\n branchName: string,\n context: string,\n ): Promise<BranchStatus | null> {\n const ccs = await helper.getCombinedCommitStatus(\n config.repository,\n branchName,\n );\n const cs = ccs.statuses.find((s) => s.context === context);\n if (!cs) {\n return null;\n } // no status check exists\n const status = helper.giteaToRenovateStatusMapping[cs.status];\n if (status) {\n return status;\n }\n logger.warn(\n { check: cs },\n 'Could not map Gitea status value to Renovate status',\n );\n return 'yellow';\n },\n\n getPrList(): Promise<Pr[]> {\n return GiteaPrCache.getPrs(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n );\n },\n\n async getPr(number: number): Promise<Pr | null> {\n // Search for pull request in cached list or attempt to query directly\n const prList = await platform.getPrList();\n let pr = prList.find((p) => p.number === number) ?? null;\n if (pr) {\n logger.debug('Returning from cached PRs');\n } else {\n logger.debug('PR not found in cached PRs - trying to fetch directly');\n const gpr = await helper.getPR(config.repository, number);\n pr = toRenovatePR(gpr, botUserName);\n\n // Add pull request to cache for further lookups / queries\n if (pr) {\n await GiteaPrCache.setPr(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n }\n\n // Abort and return null if no match was found\n if (!pr) {\n return null;\n }\n\n return pr;\n },\n\n async findPr({\n branchName,\n prTitle: title,\n state = 'all',\n includeOtherAuthors,\n targetBranch,\n }: FindPRConfig): Promise<Pr | null> {\n logger.debug(`findPr(${branchName}, ${title!}, ${state})`);\n if (includeOtherAuthors && isString(targetBranch)) {\n // do not use pr cache as it only fetches prs created by the bot account\n const pr = await helper.getPRByBranch(\n config.repository,\n targetBranch,\n branchName,\n );\n if (!pr) {\n return null;\n }\n\n return toRenovatePR(pr, null);\n }\n const prList = await platform.getPrList();\n const pr = prList.find(\n (p) =>\n p.sourceRepo === config.repository &&\n p.sourceBranch === branchName &&\n matchesState(p.state, state) &&\n (!title || p.title === title),\n );\n\n if (pr) {\n logger.debug(`Found PR #${pr.number}`);\n }\n return pr ?? null;\n },\n\n async createPr({\n sourceBranch,\n targetBranch,\n prTitle,\n prBody: rawBody,\n labels: labelNames,\n platformPrOptions,\n draftPR,\n }: CreatePRConfig): Promise<Pr> {\n let title = prTitle;\n const base = targetBranch;\n const head = sourceBranch;\n const body = sanitize(rawBody);\n if (draftPR) {\n title = DRAFT_PREFIX + title;\n }\n\n logger.debug(`Creating pull request: ${title} (${head} => ${base})`);\n try {\n const labels = Array.isArray(labelNames)\n ? await map(labelNames, lookupLabelByName)\n : [];\n const gpr = await helper.createPR(config.repository, {\n base,\n head,\n title,\n body,\n labels: labels.filter(isNumber),\n });\n\n if (platformPrOptions?.usePlatformAutomerge) {\n // Only Gitea v1.24.0+ and Forgejo v10.0.0+ support delete_branch_after_merge.\n // This is required to not have undesired behavior when renovate finds existing branches on next run.\n if (\n semver.gte(defaults.version, defaults.isForgejo ? '10.0.0' : '1.24.0')\n ) {\n try {\n await helper.mergePR(config.repository, gpr.number, {\n Do:\n getMergeMethod(platformPrOptions?.automergeStrategy) ??\n config.mergeMethod,\n merge_when_checks_succeed: true,\n delete_branch_after_merge: true,\n });\n\n logger.debug(\n { prNumber: gpr.number },\n 'Gitea-native automerge: success',\n );\n } catch (err) {\n logger.warn(\n { err, prNumber: gpr.number },\n 'Gitea-native automerge: fail',\n );\n }\n } else {\n logger.debug(\n { prNumber: gpr.number },\n `Gitea-native automerge: not supported on this version of ${defaults.isForgejo ? 'Forgejo' : 'Gitea'}. Use ${defaults.isForgejo ? '10.0.0' : '1.24.0'} or newer.`,\n );\n }\n }\n\n const pr = toRenovatePR(gpr, botUserName);\n if (!pr) {\n throw new Error('Can not parse newly created Pull Request');\n }\n\n await GiteaPrCache.setPr(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n return pr;\n } catch (err) {\n // When the user manually deletes a branch from Renovate, the PR remains but is no longer linked to any branch. In\n // the most recent versions of Gitea, the PR gets automatically closed when that happens, but older versions do\n // not handle this properly and keep the PR open. As pushing a branch with the same name resurrects the PR, this\n // would cause a HTTP 409 conflict error, which we hereby gracefully handle.\n if (err.statusCode === 409) {\n logger.warn(\n { prTitle: title, sourceBranch },\n 'Attempting to gracefully recover from 409 Conflict response in createPr()',\n );\n\n // Refresh cached PR list and search for pull request with matching information\n GiteaPrCache.forceSync();\n const pr = await platform.findPr({\n branchName: sourceBranch,\n state: 'open',\n });\n\n // If a valid PR was found, return and gracefully recover from the error. Otherwise, abort and throw error.\n // v8 ignore else -- TODO: add test #40625\n if (pr?.bodyStruct) {\n if (pr.title !== title || pr.bodyStruct.hash !== hashBody(body)) {\n logger.debug(\n `Recovered from 409 Conflict, but PR for ${sourceBranch} is outdated. Updating...`,\n );\n await platform.updatePr({\n number: pr.number,\n prTitle: title,\n prBody: body,\n });\n pr.title = title;\n pr.bodyStruct = getPrBodyStruct(body);\n } else {\n logger.debug(\n `Recovered from 409 Conflict and PR for ${sourceBranch} is up-to-date`,\n );\n }\n\n return pr;\n }\n }\n\n throw err;\n }\n },\n\n async updatePr({\n number,\n prTitle,\n prBody: body,\n labels,\n state,\n targetBranch,\n }: UpdatePrConfig): Promise<void> {\n let title = prTitle;\n if ((await getPrList()).find((pr) => pr.number === number)?.isDraft) {\n title = DRAFT_PREFIX + title;\n }\n\n const prUpdateParams: PRUpdateParams = {\n title,\n ...(body && { body }),\n ...(state && { state }),\n };\n if (targetBranch) {\n prUpdateParams.base = targetBranch;\n }\n\n /**\n * Update PR labels.\n * In the Gitea API, labels are replaced on each update if the field is present.\n * If the field is not present (i.e., undefined), labels aren't updated.\n * However, the labels array must contain label IDs instead of names,\n * so a lookup is performed to fetch the details (including the ID) of each label.\n */\n if (Array.isArray(labels)) {\n prUpdateParams.labels = (await map(labels, lookupLabelByName)).filter(\n isNumber,\n );\n if (labels.length !== prUpdateParams.labels.length) {\n logger.warn(\n 'Some labels could not be looked up. Renovate may halt label updates assuming changes by others.',\n );\n }\n }\n\n const gpr = await helper.updatePR(\n config.repository,\n number,\n prUpdateParams,\n );\n const pr = toRenovatePR(gpr, botUserName);\n if (pr) {\n await GiteaPrCache.setPr(\n giteaHttp,\n config.repository,\n config.ignorePrAuthor,\n botUserName,\n pr,\n );\n }\n },\n\n async mergePr({ id, strategy }: MergePRConfig): Promise<boolean> {\n try {\n await helper.mergePR(config.repository, id, {\n Do: getMergeMethod(strategy) ?? config.mergeMethod,\n });\n return true;\n } catch (err) {\n logger.warn({ err, id }, 'Merging of PR failed');\n return false;\n }\n },\n\n getIssueList(): Promise<Issue[]> {\n if (config.hasIssuesEnabled === false) {\n return Promise.resolve([]);\n }\n config.issueList ??= helper\n .searchIssues(config.repository, { state: 'all' }, { memCache: false })\n .then((issues) => {\n const issueList = issues.map(toRenovateIssue);\n logger.debug(`Retrieved ${issueList.length} Issues`);\n return issueList;\n });\n\n return config.issueList;\n },\n\n async getIssue(number: number, memCache = true): Promise<Issue | null> {\n if (config.hasIssuesEnabled === false) {\n return null;\n }\n try {\n const body = (\n await helper.getIssue(config.repository, number, { memCache })\n ).body;\n return {\n number,\n body,\n };\n } catch (err) /* v8 ignore next */ {\n logger.debug({ err, number }, 'Error getting issue');\n return null;\n }\n },\n\n async findIssue(title: string): Promise<Issue | null> {\n const issueList = await platform.getIssueList();\n const issue = issueList.find(\n (i) => i.state === 'open' && i.title === title,\n );\n\n if (!issue) {\n return null;\n }\n // TODO: types (#22198)\n logger.debug(`Found Issue #${issue.number!}`);\n // TODO #22198\n return getIssue!(issue.number!);\n },\n\n async ensureIssue({\n title,\n reuseTitle,\n body: content,\n labels: labelNames,\n shouldReOpen,\n once,\n }: EnsureIssueConfig): Promise<'updated' | 'created' | null> {\n logger.debug(`ensureIssue(${title})`);\n if (config.hasIssuesEnabled === false) {\n logger.info(\n 'Cannot ensure issue because issues are disabled in this repository',\n );\n return null;\n }\n try {\n const body = smartLinks(content);\n\n const issueList = await platform.getIssueList();\n let issues = issueList.filter((i) => i.title === title);\n if (!issues.length) {\n issues = issueList.filter((i) => i.title === reuseTitle);\n }\n\n const labels = Array.isArray(labelNames)\n ? (await Promise.all(labelNames.map(lookupLabelByName))).filter(\n isNumber,\n )\n : undefined;\n\n // Update any matching issues which currently exist\n if (issues.length) {\n let activeIssue = issues.find((i) => i.state === 'open');\n\n // If no active issue was found, decide if it shall be skipped, re-opened or updated without state change\n if (!activeIssue) {\n if (once) {\n logger.debug('Issue already closed - skipping update');\n return null;\n }\n if (shouldReOpen) {\n logger.debug('Reopening previously closed Issue');\n }\n\n // Pick the last issue in the list as the active one\n activeIssue = issues[issues.length - 1];\n }\n\n // Close any duplicate issues\n for (const issue of issues) {\n if (issue.state === 'open' && issue.number !== activeIssue.number) {\n // TODO: types (#22198)\n logger.warn({ issueNo: issue.number! }, 'Closing duplicate issue');\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n\n // Check if issue has already correct state\n if (\n activeIssue.title === title &&\n activeIssue.body === body &&\n activeIssue.state === 'open'\n ) {\n logger.debug(\n // TODO: types (#22198)\n `Issue #${activeIssue.number!} is open and up to date - nothing to do`,\n );\n return null;\n }\n\n if (shouldReOpen || activeIssue.state === 'open') {\n // Update issue body and re-open\n logger.debug(`Updating Issue #${activeIssue.number}`);\n const existingIssue = await helper.updateIssue(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n body,\n title,\n state: 'open',\n },\n );\n\n // Test whether the issues need to be updated\n const existingLabelIds = (existingIssue.labels ?? []).map(\n (label) => label.id,\n );\n if (\n labels &&\n (labels.length !== existingLabelIds.length ||\n labels.filter((labelId) => !existingLabelIds.includes(labelId))\n .length !== 0)\n ) {\n await helper.updateIssueLabels(\n config.repository,\n // TODO #22198\n activeIssue.number!,\n {\n labels,\n },\n );\n }\n\n return 'updated';\n }\n }\n\n // Create new issue and reset cache\n const issue = await helper.createIssue(config.repository, {\n body,\n title,\n labels,\n });\n logger.debug(`Created new Issue #${issue.number}`);\n config.issueList = null;\n\n return 'created';\n } catch (err) {\n logger.warn({ err }, 'Could not ensure issue');\n }\n\n return null;\n },\n\n async ensureIssueClosing(title: string): Promise<void> {\n logger.debug(`ensureIssueClosing(${title})`);\n if (config.hasIssuesEnabled === false) {\n return;\n }\n const issueList = await platform.getIssueList();\n for (const issue of issueList) {\n if (issue.state === 'open' && issue.title === title) {\n logger.debug(`Closing issue...issueNo: ${issue.number!}`);\n // TODO #22198\n await helper.closeIssue(config.repository, issue.number!);\n }\n }\n },\n\n async deleteLabel(issue: number, labelName: string): Promise<void> {\n logger.debug(`Deleting label ${labelName} from Issue #${issue}`);\n const label = await lookupLabelByName(labelName);\n if (label) {\n await helper.unassignLabel(config.repository, issue, label);\n } else {\n logger.warn({ issue, labelName }, 'Failed to lookup label for deletion');\n }\n },\n\n async ensureComment({\n number: issue,\n topic,\n content,\n }: EnsureCommentConfig): Promise<boolean> {\n try {\n let body = sanitize(content);\n const commentList = await helper.getComments(config.repository, issue);\n\n // Search comment by either topic or exact body\n let comment: Comment | null = null;\n if (topic) {\n comment = findCommentByTopic(commentList, topic);\n body = `### ${topic}\\n\\n${body}`;\n } else {\n comment = findCommentByContent(commentList, body);\n }\n\n // Create a new comment if no match has been found, otherwise update if necessary\n if (!comment) {\n comment = await helper.createComment(config.repository, issue, body);\n logger.info(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment added',\n );\n } else if (comment.body === body) {\n logger.debug(`Comment #${comment.id} is already up-to-date`);\n } else {\n await helper.updateComment(config.repository, comment.id, body);\n logger.debug(\n { repository: config.repository, issue, comment: comment.id },\n 'Comment updated',\n );\n }\n\n return true;\n } catch (err) {\n logger.warn({ err, issue, subject: topic }, 'Error ensuring comment');\n return false;\n }\n },\n\n async ensureCommentRemoval(\n deleteConfig: EnsureCommentRemovalConfig,\n ): Promise<void> {\n const { number: issue } = deleteConfig;\n const key =\n deleteConfig.type === 'by-topic'\n ? deleteConfig.topic\n : deleteConfig.content;\n logger.debug(`Ensuring comment \"${key}\" in #${issue} is removed`);\n const commentList = await helper.getComments(config.repository, issue);\n\n let comment: Comment | null = null;\n // v8 ignore else -- TODO: add test #40625\n if (deleteConfig.type === 'by-topic') {\n comment = findCommentByTopic(commentList, deleteConfig.topic);\n } else if (deleteConfig.type === 'by-content') {\n const body = sanitize(deleteConfig.content);\n comment = findCommentByContent(commentList, body);\n }\n\n // Abort and do nothing if no matching comment was found\n if (!comment) {\n return;\n }\n\n // Try to delete comment\n try {\n await helper.deleteComment(config.repository, comment.id);\n } catch (err) {\n logger.warn(\n { err, issue, config: deleteConfig },\n 'Error deleting comment',\n );\n }\n },\n\n async getBranchPr(branchName: string): Promise<Pr | null> {\n logger.debug(`getBranchPr(${branchName})`);\n const pr = await platform.findPr({ branchName, state: 'open' });\n return pr ? platform.getPr(pr.number) : null;\n },\n\n async addAssignees(number: number, assignees: string[]): Promise<void> {\n logger.debug(\n `Updating assignees '${assignees?.join(', ')}' on Issue #${number}`,\n );\n await helper.updateIssue(config.repository, number, {\n assignees,\n });\n },\n\n async addReviewers(number: number, reviewers: string[]): Promise<void> {\n logger.debug(`Adding reviewers '${reviewers?.join(', ')}' to #${number}`);\n if (semver.lt(defaults.version, '1.14.0')) {\n logger.debug(\n { version: defaults.version },\n 'Adding reviewer not yet supported.',\n );\n return;\n }\n try {\n await helper.requestPrReviewers(config.repository, number, { reviewers });\n } catch (err) {\n logger.warn({ err, number, reviewers }, 'Failed to assign reviewer');\n }\n },\n\n massageMarkdown(prBody: string): string {\n return smartTruncate(smartLinks(prBody), maxBodyLength());\n },\n\n maxBodyLength,\n};\n\nexport function maxBodyLength(): number {\n return 1000000;\n}\n\n/* oxlint-disable typescript/unbound-method */\nexport const {\n addAssignees,\n addReviewers,\n createPr,\n deleteLabel,\n ensureComment,\n ensureCommentRemoval,\n ensureIssue,\n ensureIssueClosing,\n findIssue,\n findPr,\n getBranchPr,\n getBranchStatus,\n getBranchStatusCheck,\n getIssue,\n getRawFile,\n getJsonFile,\n getIssueList,\n getPr,\n massageMarkdown,\n getPrList,\n getRepos,\n initPlatform,\n initRepo,\n mergePr,\n setBranchStatus,\n updatePr,\n} = platform;\n"],"mappings":"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"}
@@ -55,7 +55,7 @@ function toRenovatePR(data, author) {
55
55
  logger.trace(`Skipping Pull Request #${data.number} due to missing base and/or head branch`);
56
56
  return null;
57
57
  }
58
- const createdBy = data.user?.username;
58
+ const createdBy = data.user?.login;
59
59
  if (createdBy && author && !reconfigurePrRegex.test(data.head.label) && createdBy !== author) return null;
60
60
  let title = data.title;
61
61
  let isDraft = false;
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","names":["hostRules.find"],"sources":["../../../../lib/modules/platform/gitea/utils.ts"],"sourcesContent":["import { isNonEmptyArray } from '@sindresorhus/is';\nimport type { MergeStrategy } from '../../../config/types.ts';\nimport {\n CONFIG_GIT_URL_UNAVAILABLE,\n REPOSITORY_BLOCKED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport * as hostRules from '../../../util/host-rules.ts';\nimport { regEx } from '../../../util/regex.ts';\nimport { parseUrl } from '../../../util/url.ts';\nimport { getPrBodyStruct } from '../pr-body.ts';\nimport type { GitUrlOption, Pr } from '../types.ts';\nimport type { PR, PRMergeMethod, Repo } from './types.ts';\n\nexport function smartLinks(body: string): string {\n return body\n ?.replace(regEx(/\\]\\(\\.\\.\\/issues\\//g), '](issues/')\n .replace(regEx(/\\]\\(\\.\\.\\/pull\\//g), '](pulls/');\n}\n\nexport function trimTrailingApiPath(url: string): string {\n return url?.replace(regEx(/api\\/v1\\/?$/g), '');\n}\n\nexport function getRepoUrl(\n repo: Repo,\n gitUrl: GitUrlOption | undefined,\n endpoint: string,\n): string {\n if (gitUrl === 'ssh') {\n if (!repo.ssh_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n logger.debug(`Using SSH URL: ${repo.ssh_url}`);\n return repo.ssh_url;\n }\n\n // Find options for current host and determine Git endpoint\n const opts = hostRules.find({\n hostType: 'gitea',\n url: endpoint,\n });\n\n if (gitUrl === 'endpoint') {\n const url = parseUrl(endpoint);\n if (!url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n url.username = opts.token ?? '';\n url.pathname = `${url.pathname}${repo.full_name}.git`;\n logger.debug(\n { url: url.toString() },\n 'using URL based on configured endpoint',\n );\n return url.toString();\n }\n\n if (!repo.clone_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n\n logger.debug(`Using HTTP URL: ${repo.clone_url}`);\n const repoUrl = parseUrl(repo.clone_url);\n if (!repoUrl) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n repoUrl.username = opts.token ?? '';\n return repoUrl.toString();\n}\n\nexport function getMergeMethod(\n strategy: MergeStrategy | undefined,\n): PRMergeMethod | null {\n switch (strategy) {\n case 'fast-forward':\n return 'rebase';\n case 'merge-commit':\n return 'merge';\n case 'rebase':\n return 'rebase-merge';\n case 'squash':\n return strategy;\n case 'auto':\n default:\n return null;\n }\n}\n\nexport const API_PATH = '/api/v1';\n\nexport const DRAFT_PREFIX = 'WIP: ';\nconst reconfigurePrRegex = regEx(/reconfigure$/g);\n\nexport function toRenovatePR(data: PR, author: string | null): Pr | null {\n if (!data) {\n return null;\n }\n\n if (\n !data.base?.ref ||\n !data.head?.label ||\n !data.head?.sha ||\n !data.head?.repo?.full_name\n ) {\n logger.trace(\n `Skipping Pull Request #${data.number} due to missing base and/or head branch`,\n );\n return null;\n }\n\n const createdBy = data.user?.username;\n if (\n createdBy &&\n author &&\n !reconfigurePrRegex.test(data.head.label) &&\n createdBy !== author\n ) {\n return null;\n }\n\n let title = data.title;\n let isDraft = false;\n if (title.startsWith(DRAFT_PREFIX)) {\n title = title.substring(DRAFT_PREFIX.length);\n isDraft = true;\n }\n const labels = (data?.labels ?? []).map((l) => l.name);\n\n return {\n labels,\n number: data.number,\n state: data.merged ? 'merged' : data.state,\n title,\n isDraft,\n bodyStruct: getPrBodyStruct(data.body),\n sha: data.head.sha,\n sourceBranch: data.head.label,\n targetBranch: data.base.ref,\n sourceRepo: data.head.repo.full_name,\n createdAt: data.created_at,\n cannotMergeReason: data.mergeable\n ? undefined\n : `pr.mergeable=\"${data.mergeable}\"`,\n hasAssignees: !!(data.assignee?.login ?? isNonEmptyArray(data.assignees)),\n };\n}\n\n/**\n * Check if a repository is usable.\n * A repo isn't usable if one of the following conditions is met:\n * - The repo is a `mirror`\n * - We don't have pull or push permissions\n * - Pull requests are disabled\n * @param repo Repo to check\n * @returns `true` if the repository is usable, `false` otherwise\n */\nexport function usableRepo(repo: Repo): boolean {\n if (repo.mirror === true) {\n return false;\n }\n\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because of missing pull or push permissions`,\n );\n return false;\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because pull requests are disabled`,\n );\n return false;\n }\n return true;\n}\n\nexport function isAllowed(style: PRMergeMethod, repo: Repo): boolean {\n switch (style) {\n case 'merge':\n return repo.allow_merge_commits;\n case 'rebase':\n return repo.allow_rebase;\n case 'rebase-merge':\n return repo.allow_rebase_explicit;\n case 'squash':\n return repo.allow_squash_merge;\n case 'fast-forward-only':\n return repo.allow_fast_forward_only_merge;\n }\n logger.debug('Repo has unknown merge style - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"utils.js","names":["hostRules.find"],"sources":["../../../../lib/modules/platform/gitea/utils.ts"],"sourcesContent":["import { isNonEmptyArray } from '@sindresorhus/is';\nimport type { MergeStrategy } from '../../../config/types.ts';\nimport {\n CONFIG_GIT_URL_UNAVAILABLE,\n REPOSITORY_BLOCKED,\n} from '../../../constants/error-messages.ts';\nimport { logger } from '../../../logger/index.ts';\nimport * as hostRules from '../../../util/host-rules.ts';\nimport { regEx } from '../../../util/regex.ts';\nimport { parseUrl } from '../../../util/url.ts';\nimport { getPrBodyStruct } from '../pr-body.ts';\nimport type { GitUrlOption, Pr } from '../types.ts';\nimport type { PR, PRMergeMethod, Repo } from './types.ts';\n\nexport function smartLinks(body: string): string {\n return body\n ?.replace(regEx(/\\]\\(\\.\\.\\/issues\\//g), '](issues/')\n .replace(regEx(/\\]\\(\\.\\.\\/pull\\//g), '](pulls/');\n}\n\nexport function trimTrailingApiPath(url: string): string {\n return url?.replace(regEx(/api\\/v1\\/?$/g), '');\n}\n\nexport function getRepoUrl(\n repo: Repo,\n gitUrl: GitUrlOption | undefined,\n endpoint: string,\n): string {\n if (gitUrl === 'ssh') {\n if (!repo.ssh_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n logger.debug(`Using SSH URL: ${repo.ssh_url}`);\n return repo.ssh_url;\n }\n\n // Find options for current host and determine Git endpoint\n const opts = hostRules.find({\n hostType: 'gitea',\n url: endpoint,\n });\n\n if (gitUrl === 'endpoint') {\n const url = parseUrl(endpoint);\n if (!url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n url.username = opts.token ?? '';\n url.pathname = `${url.pathname}${repo.full_name}.git`;\n logger.debug(\n { url: url.toString() },\n 'using URL based on configured endpoint',\n );\n return url.toString();\n }\n\n if (!repo.clone_url) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n\n logger.debug(`Using HTTP URL: ${repo.clone_url}`);\n const repoUrl = parseUrl(repo.clone_url);\n if (!repoUrl) {\n throw new Error(CONFIG_GIT_URL_UNAVAILABLE);\n }\n repoUrl.username = opts.token ?? '';\n return repoUrl.toString();\n}\n\nexport function getMergeMethod(\n strategy: MergeStrategy | undefined,\n): PRMergeMethod | null {\n switch (strategy) {\n case 'fast-forward':\n return 'rebase';\n case 'merge-commit':\n return 'merge';\n case 'rebase':\n return 'rebase-merge';\n case 'squash':\n return strategy;\n case 'auto':\n default:\n return null;\n }\n}\n\nexport const API_PATH = '/api/v1';\n\nexport const DRAFT_PREFIX = 'WIP: ';\nconst reconfigurePrRegex = regEx(/reconfigure$/g);\n\nexport function toRenovatePR(data: PR, author: string | null): Pr | null {\n if (!data) {\n return null;\n }\n\n if (\n !data.base?.ref ||\n !data.head?.label ||\n !data.head?.sha ||\n !data.head?.repo?.full_name\n ) {\n logger.trace(\n `Skipping Pull Request #${data.number} due to missing base and/or head branch`,\n );\n return null;\n }\n\n const createdBy = data.user?.login;\n if (\n createdBy &&\n author &&\n !reconfigurePrRegex.test(data.head.label) &&\n createdBy !== author\n ) {\n return null;\n }\n\n let title = data.title;\n let isDraft = false;\n if (title.startsWith(DRAFT_PREFIX)) {\n title = title.substring(DRAFT_PREFIX.length);\n isDraft = true;\n }\n const labels = (data?.labels ?? []).map((l) => l.name);\n\n return {\n labels,\n number: data.number,\n state: data.merged ? 'merged' : data.state,\n title,\n isDraft,\n bodyStruct: getPrBodyStruct(data.body),\n sha: data.head.sha,\n sourceBranch: data.head.label,\n targetBranch: data.base.ref,\n sourceRepo: data.head.repo.full_name,\n createdAt: data.created_at,\n cannotMergeReason: data.mergeable\n ? undefined\n : `pr.mergeable=\"${data.mergeable}\"`,\n hasAssignees: !!(data.assignee?.login ?? isNonEmptyArray(data.assignees)),\n };\n}\n\n/**\n * Check if a repository is usable.\n * A repo isn't usable if one of the following conditions is met:\n * - The repo is a `mirror`\n * - We don't have pull or push permissions\n * - Pull requests are disabled\n * @param repo Repo to check\n * @returns `true` if the repository is usable, `false` otherwise\n */\nexport function usableRepo(repo: Repo): boolean {\n if (repo.mirror === true) {\n return false;\n }\n\n if (repo.permissions.pull === false || repo.permissions.push === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because of missing pull or push permissions`,\n );\n return false;\n }\n\n if (repo.has_pull_requests === false) {\n logger.debug(\n `Skipping repository ${repo.full_name} because pull requests are disabled`,\n );\n return false;\n }\n return true;\n}\n\nexport function isAllowed(style: PRMergeMethod, repo: Repo): boolean {\n switch (style) {\n case 'merge':\n return repo.allow_merge_commits;\n case 'rebase':\n return repo.allow_rebase;\n case 'rebase-merge':\n return repo.allow_rebase_explicit;\n case 'squash':\n return repo.allow_squash_merge;\n case 'fast-forward-only':\n return repo.allow_fast_forward_only_merge;\n }\n logger.debug('Repo has unknown merge style - aborting renovation');\n throw new Error(REPOSITORY_BLOCKED);\n}\n"],"mappings":"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"}
@@ -27,7 +27,7 @@ declare const GithubVulnerabilityAlerts: z.ZodPipe<z.ZodType<{
27
27
  };
28
28
  security_vulnerability: {
29
29
  package: {
30
- ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "nuget" | "actions" | "pip";
30
+ ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "actions" | "nuget" | "pip";
31
31
  name: string;
32
32
  };
33
33
  severity: "low" | "medium" | "high" | "critical";
@@ -66,7 +66,7 @@ declare const GithubVulnerabilityAlerts: z.ZodPipe<z.ZodType<{
66
66
  };
67
67
  security_vulnerability: {
68
68
  package: {
69
- ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "nuget" | "actions" | "pip";
69
+ ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "actions" | "nuget" | "pip";
70
70
  name: string;
71
71
  };
72
72
  severity: "low" | "medium" | "high" | "critical";
@@ -105,7 +105,7 @@ declare const GithubVulnerabilityAlerts: z.ZodPipe<z.ZodType<{
105
105
  };
106
106
  security_vulnerability: {
107
107
  package: {
108
- ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "nuget" | "actions" | "pip";
108
+ ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "actions" | "nuget" | "pip";
109
109
  name: string;
110
110
  };
111
111
  severity: "low" | "medium" | "high" | "critical";
@@ -144,7 +144,7 @@ declare const GithubVulnerabilityAlerts: z.ZodPipe<z.ZodType<{
144
144
  };
145
145
  security_vulnerability: {
146
146
  package: {
147
- ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "nuget" | "actions" | "pip";
147
+ ecosystem: "composer" | "maven" | "npm" | "rust" | "go" | "rubygems" | "actions" | "nuget" | "pip";
148
148
  name: string;
149
149
  };
150
150
  severity: "low" | "medium" | "high" | "critical";
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "renovate",
3
3
  "description": "Automated dependency updates. Flexible so you don't need to be.",
4
- "version": "43.217.1",
4
+ "version": "43.218.0",
5
5
  "type": "module",
6
6
  "bin": {
7
7
  "renovate": "dist/renovate.js",