@gitkraken/provider-apis 0.47.0 → 0.48.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.
- package/CHANGELOG.md +10 -0
- package/dist/index.js +12 -12
- package/dist/index.providers.js +9 -9
- package/dist/providers/github/github.d.ts +23 -0
- package/package.json +5 -2
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
"use strict";var $t=Object.defineProperty;var Bs=Object.getOwnPropertyDescriptor;var Qs=Object.getOwnPropertyNames;var Fs=Object.prototype.hasOwnProperty;var z=(s,r)=>{for(var e in r)$t(s,e,{get:r[e],enumerable:!0})},Ms=(s,r,e,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of Qs(r))!Fs.call(s,n)&&n!==e&&$t(s,n,{get:()=>r[n],enumerable:!(t=Bs(r,n))||t.enumerable});return s};var zs=s=>Ms($t({},"__esModule",{value:!0}),s);var Ho={};z(Ho,{AzureDevOps:()=>me,AzureDevopsUtils:()=>lt,Bitbucket:()=>ge,BitbucketServer:()=>he,BitbucketServerUtils:()=>_e,BitbucketUtils:()=>pt,EntityIdentifierProviderType:()=>x,EntityIdentifierUtils:()=>wt,EntityType:()=>N,EntityVersion:()=>_,GitBuildStatusStage:()=>Lr,GitBuildStatusState:()=>ve,GitDiffLineType:()=>At,GitHub:()=>fe,GitHubIssueCloseReason:()=>xs,GitHubUtils:()=>vt,GitIssueState:()=>Ne,GitLab:()=>Ie,GitLabUtils:()=>Et,GitMergeStrategy:()=>ce,GitProviderUtils:()=>qt,GitPullRequestMergeableState:()=>X,GitPullRequestReviewState:()=>W,GitPullRequestState:()=>ae,GraphQLErrors:()=>R,Jira:()=>be,JiraServer:()=>ye,JiraUtils:()=>St,Linear:()=>Pe,PullRequestAsyncStatus:()=>Os,Trello:()=>we,TrelloUtils:()=>Ct,Utils:()=>Wo,default:()=>zo,isFetch:()=>Ge});module.exports=zs(Ho);var jr=require("diff");var Lr=(n=>(n.Build="build",n.Production="production",n.Staging="staging",n.Test="test",n))(Lr||{}),ve=(p=>(p.ActionRequired="ACTION_REQUIRED",p.Cancelled="CANCELLED",p.Error="ERROR",p.Failed="FAILED",p.Pending="PENDING",p.Running="RUNNING",p.Skipped="SKIPPED",p.Success="SUCCESS",p.Warning="WARNING",p.OptionalActionRequired="OPTIONAL_ACTION_REQUIRED",p))(ve||{}),ce=(o=>(o.MergeCommit="MERGE_COMMIT",o.Rebase="REBASE",o.RebaseThenMergeCommit="REBASE_THEN_MERGE_COMMIT",o.FastForward="FAST_FORWARD",o.Squash="SQUASH",o))(ce||{}),ae=(t=>(t.Open="OPEN",t.Closed="CLOSED",t.Merged="MERGED",t))(ae||{}),W=(n=>(n.Approved="APPROVED",n.ChangesRequested="CHANGES_REQUESTED",n.Commented="COMMENTED",n.ReviewRequested="REVIEW_REQUESTED",n))(W||{}),X=(u=>(u.Behind="BEHIND",u.Blocked="BLOCKED",u.Conflicts="CONFLICTS",u.FailingChecks="FAILING_CHECKS",u.Mergeable="MERGEABLE",u.Unknown="UNKNOWN",u.UnknownAndBlocked="UNKNOWN_AND_BLOCKED",u.Unstable="UNSTABLE",u))(X||{}),At=(t=>(t.ADDED="ADDED",t.DELETED="DELETED",t.UNMODIFIED="UNMODIFIED",t))(At||{});var Ur={APPROVED:0,COMMENTED:1,REVIEW_REQUESTED:2,CHANGES_REQUESTED:3},H=s=>!s||s.length===0?null:s.reduce((r,e)=>Ur[e.state]>Ur[r]?e.state:r,"APPROVED"),Te=(s,r)=>s.name||s.username||s.email||r,ue=s=>{let r=Object.values(s).map(e=>e.name).sort((e,t)=>e.localeCompare(t));return Object.values(s).forEach(e=>{e.priority!==-1&&(e.priority=r.indexOf(e.name))}),s};var Lt=(a=>(a[a.Unknown=0]="Unknown",a[a.Active=1]="Active",a[a.Fixed=2]="Fixed",a[a.WontFix=3]="WontFix",a[a.Closed=4]="Closed",a[a.ByDesign=5]="ByDesign",a[a.Pending=6]="Pending",a))(Lt||{});var $=100;var Tr=globalThis.fetch;var Ws=async s=>{let r=s.headers.get("content-type")||"",e=null;if(r.startsWith("application/json")){let o=await s.text();e=o.trim().length>0?JSON.parse(o):null}else if(r.startsWith("text/")||r==="")e=await s.text();else if(r.startsWith("application/vnd.github.raw+json")||r.startsWith("application/octet-stream"))e=await s.arrayBuffer();else throw new Error(`Unsupported content-type: ${r}`);let t={};s.headers.forEach((o,i)=>{t[i]=o});let n={body:e,headers:t,status:s.status,statusText:s.statusText};if(!s.ok){let o=new Error(s.statusText);throw Object.assign(o,{response:n}),o}return n},Ut=s=>async({url:r,...e})=>{let t=await s(r,e);return Ws(t)};var Ge=(s,r=!1)=>s.name==="fetch"||r;var F=class{constructor(r){let e=r?.request||Tr;this.config={...r,request:Ge(e,r?.forceIsFetch)?Ut(e):e}}updateConfig(r){this.config={...this.config,...r,request:r.request&&Ge(r.request,r?.forceIsFetch??this.config.forceIsFetch)?Ut(r.request):this.config.request}}},j=class extends F{};var f=(s,r)=>{let e={};return s&&(e.Authorization=`${r?"Basic":"Bearer"} ${s}`),e},Gr=s=>s?s.reduce((r,e)=>(r[e]=!0,r),{}):void 0,se=(s,r,e)=>!s||r.some(t=>s[t])?e:"",Or=async s=>{let r=[],e=!0,t;for(;e;){let n=await s(t);r=r.concat(n.data),e=!!n?.pageInfo?.hasNextPage,t=n?.pageInfo?.endCursor||n?.pageInfo?.nextPage}return r};async function Tt(s){return(await Promise.allSettled(s)).map(e=>Hs(e)).filter(e=>e!=null)}function Hs(s,r=void 0){return s?.status==="fulfilled"?s.value:r}var Js="https://app.vssps.visualstudio.com/_apis",Vs="https://vssps.dev.azure.com/",Ks="https://dev.azure.com",w=(s,r={})=>f(r.token||s.token,r.isPAT||s.isPAT),xr=s=>s.url.replace("/_apis/git/repositories/","/_git/").replace(`/${s.repository.project.id}/`,`/${encodeURIComponent(s.repository.project.name)}/`).replace(`/${s.repository.id}/`,`/${encodeURIComponent(s.repository.name)}/`).replace("/pullRequests/","/pullrequest/"),Gt=(s,r)=>{let e=r.baseUrl||s.baseUrl||Js;return e=e.replace(/\/$/,""),e},C=(s,r)=>{let e=r.baseUrl||s.baseUrl||Ks;return e=e.replace(/\/$/,""),e},Ot=(s,r)=>{let e=r.baseUrl||s.baseUrl||Vs;return e=e.replace(/\/$/,""),e};var Xs={active:"OPEN",completed:"MERGED",abandoned:"CLOSED"},Ys=s=>{if(typeof s!="string")return s;let r=s.charAt(0).toUpperCase()+s.slice(1);return Lt[r]??0},Zs=new Set([2,3,4,5]),en={10:"APPROVED",5:"APPROVED",0:"REVIEW_REQUESTED",[-5]:"CHANGES_REQUESTED",[-10]:"CHANGES_REQUESTED"},le=s=>({id:s.id,name:s.displayName??null,username:(s.uniqueName||s.displayName)??null,email:null,avatarUrl:s.imageUrl??null,url:null}),Oe=s=>s.startsWith("refs/heads/")?s.replace("refs/heads/",""):s,tn=s=>{switch(s){case"conflicts":return"CONFLICTS";case"failure":return"FAILING_CHECKS";case"rejectedByPolicy":return"BLOCKED";case"succeeded":return"MERGEABLE";case"notSet":case"queued":default:return"UNKNOWN"}},xt=(s,r,e,t,n,o)=>`${s}|${r}|${e}|${t}|${n}|${o}`,kr=s=>{let r=s.split("|");if(r.length!==6)throw new Error("Invalid Azure comment ID format");return{namespace:r[0],project:r[1],repoName:r[2],prId:r[3],threadId:r[4],commentId:r[5]}},_r=(s,r,e,t,n)=>`${s}|${r}|${e}|${t}|${n}`,kt=s=>{let r=s.split("|");if(r.length!==5)throw new Error("Invalid Azure thread ID format");return{namespace:r[0],project:r[1],repoName:r[2],prId:r[3],threadId:r[4]}},Ee=(s,r)=>{let e=[],t=[];return r.reviewers.forEach(n=>{let o={reviewer:le(n),state:en[n.vote??0]||"REVIEW_REQUESTED"};n.isRequired&&e.push(o),t.push(o)}),{id:r.pullRequestId.toString(),title:r.title,description:r.description??null,number:r.codeReviewId,state:Xs[r.status],isDraft:r.isDraft,commentCount:null,upvoteCount:null,author:le(r.createdBy),createdDate:new Date(r.creationDate),updatedDate:new Date(r.closedDate||r.creationDate),closedDate:r.closedDate?new Date(r.closedDate):null,mergedDate:r.closedDate&&r.status==="completed"?new Date(r.closedDate):null,repository:{id:r.repository.id,name:r.repository.name,project:r.repository.project.name,owner:{login:s},remoteInfo:null},headCommit:{buildStatuses:null},baseRef:{name:Oe(r.targetRefName),oid:r.lastMergeTargetCommit.commitId},headRef:{name:Oe(r.sourceRefName),oid:r.lastMergeSourceCommit.commitId},url:xr(r),assignees:r.reviewers.map(le),reviews:t,reviewDecision:H(e),additions:null,deletions:null,fileCount:null,commitCount:null,headRepository:r.forkSource?{id:r.forkSource.repository.id,name:r.forkSource.repository.name,project:void 0,owner:{login:s},remoteInfo:null}:{id:r.repository.id,name:r.repository.name,project:r.repository.project.name,owner:{login:s},remoteInfo:null},mergeableState:tn(r.mergeStatus),labels:r.labels?.map(n=>({color:null,description:null,id:n.id,name:n.name}))??[],permissions:null}},Nr=(s,r)=>({id:r.id,name:r.name,namespace:s,project:r.project.name,projectId:r.project.id,webUrl:r.webUrl,httpsUrl:r.remoteUrl,sshUrl:r.sshUrl,defaultBranch:r.defaultBranch?{name:Oe(r.defaultBranch)}:null,permissions:null}),rn=(s,r,e,t)=>{let n=e.fields,o=n["System.AssignedTo"],i=n["System.State"],a=n["System.WorkItemType"],u;return i&&a&&(u=t[a]?.[i]),{id:e.id.toString(),number:e.id.toString(),title:n["System.Title"],commentCount:n["System.CommentCount"],author:{avatarUrl:n["System.CreatedBy"]._links?.avatar?.href??null,email:null,id:n["System.CreatedBy"].id,name:n["System.CreatedBy"].uniqueName??null,username:n["System.CreatedBy"].displayName??null,url:null},closedDate:n["Microsoft.VSTS.Common.ClosedDate"]?new Date(n["Microsoft.VSTS.Common.ClosedDate"]):null,createdDate:new Date(n["System.CreatedDate"]),updatedDate:new Date(n["System.ChangedDate"]),url:e._links.html.href,assignees:o?[{avatarUrl:o._links?.avatar?.href??null,email:null,id:o.id,name:o.uniqueName??null,username:o.displayName??null,url:null}]:[],description:n["System.Description"]??null,state:{name:u?.title||i,color:null},type:n["System.WorkItemType"],repository:null,project:{namespace:s,name:r,resourceId:null,key:null,id:null},upvoteCount:0,labels:e.fields["System.Tags"]?.split(";").map(l=>({color:null,description:null,id:null,name:l.trim()}))??[]}},me=class extends j{constructor(){super(...arguments);this.cachedUserIds=new Map;this.inflightUserIds=new Map}getCurrentUserId(e,t){let n=JSON.stringify([e,t.token??null,t.isPAT??this.config.isPAT??!1,t.baseUrl??null]),o=this.cachedUserIds.get(n);if(o)return Promise.resolve(o);let i=this.inflightUserIds.get(n);if(i)return i;let a=this.fetchCurrentUserId(e,t,n);return this.inflightUserIds.set(n,a),a}async fetchCurrentUserId(e,t,n){try{let o=await this.getCurrentUserForInstance({namespace:e},t);return this.cachedUserIds.set(n,o.data.id),o.data.id}finally{this.inflightUserIds.delete(n)}}getRepoApiUrl(e,t,n,o){return`${C(this.config,o)}/${encodeURIComponent(e)}/${encodeURIComponent(t)}/_apis/git/repositories/${encodeURIComponent(n)}`}async getCurrentUser(e={},t={}){if(t.isPAT||this.config.isPAT)throw new Error("Azure DevOps does not support PATs for this function.");let n=`${Gt(this.config,t)}/profile/profiles/me`,o=await this.config.request({url:n,headers:w(this.config,t)});return{data:{id:o.body.id,name:o.body.displayName,username:o.body.displayName,email:o.body.emailAddress,avatarUrl:null,url:null}}}async getCurrentUserForInstance(e,t={}){let o=(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/_apis/ConnectionData`,headers:w(this.config,t)})).body.authorizedUser;if(o.providerDisplayName==="Anonymous")throw new Error("Current user not found.");return{data:{id:o.id,name:o.providerDisplayName,username:o.providerDisplayName,email:o.properties.Account.$value,avatarUrl:null,url:null}}}async getUserForCommit(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let o=(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.repo.namespace)}/${encodeURIComponent(e.repo.project)}/_apis/git/repositories/${encodeURIComponent(e.repo.name)}/commits/${e.oid}`,headers:w(this.config,t)})).body.author;return{data:{name:o.name,email:o.email,avatarUrl:o.imageUrl}}}async getOrgsForUser(e,t={}){let n=`${Gt(this.config,t)}/accounts?memberId=${e.userId}&api-version=6.0`;return{data:(await this.config.request({url:n,headers:w(this.config,t)})).body.value.map(i=>({id:i.accountId,name:i.accountName}))}}async getCollectionsForUser(e,t={}){let n=`${C(this.config,t)}/_apis/projectCollections`;return{data:(await this.config.request({url:n,headers:w(this.config,t)})).body.value.map(i=>({id:i.id,name:i.name}))}}async getAzureProjects(e,t={}){let n=new URL(`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/_apis/projects`);n.searchParams.set("$top",$.toString()),e.cursor&&n.searchParams.set("$skip",e.cursor);let o=await this.config.request({url:n.toString(),headers:w(this.config,t)}),i=o.headers["x-ms-continuationtoken"];return{pageInfo:{hasNextPage:!!i,endCursor:i||null},data:o.body.value.map(a=>({id:a.id,name:a.name,namespace:e.namespace}))}}async getAzureProjectScopeDescriptor(e,t={}){let{namespace:n,projectId:o}=e;return{data:{scope:(await this.config.request({url:`${Ot(this.config,t)}/${encodeURIComponent(n)}/_apis/graph/descriptors/${o}?api-version=6.0`,headers:w(this.config,t)})).body.value}}}async getAzureGraphAccountsForAzureProject(e,t={}){let{namespace:n,projectScopeDescriptor:o,cursor:i}=e,a=new URL(`${Ot(this.config,t)}/${encodeURIComponent(n)}/_apis/graph/users`);o&&a.searchParams.set("scopeDescriptor",o),i&&a.searchParams.set("continuationToken",i);let u=await this.config.request({url:a.toString(),headers:w(this.config,t)}),l=u.headers["x-ms-continuationtoken"];return{pageInfo:{endCursor:l||null,hasNextPage:!!l},data:u.body.value.map(p=>({avatarUrl:p._links?.avatar?.href??null,descriptor:p.descriptor??null,email:p.mailAddress??null,name:p.displayName??null,storageKeyURL:p._links?.storageKey?.href??null,username:p.displayName??null}))}}async getAccountFromAzureGraphAccount(e,t={}){let{azureGraphAccount:n}=e;if(!n.storageKeyURL)throw new Error("Expected 'storageKeyURL' to not be null for 'azureGraphAccount'");let o=await this.config.request({url:n.storageKeyURL,headers:w(this.config,t)});return{data:{avatarUrl:n.avatarUrl,email:n.email,id:o.body.value,name:n.name,username:n.username,url:null}}}async getAccountsFromAzureGraphAccounts(e,t={}){let n=[];for(let o of e.azureGraphAccounts){let i=await this.getAccountFromAzureGraphAccount({azureGraphAccount:o},t);n.push(i.data)}return{data:n}}async getRepo(e,t={}){if(!e.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/git/repositories/${encodeURIComponent(e.name)}`,headers:w(this.config,t)});return{data:Nr(e.namespace,n.body)}}async getRepos(e,t={}){let n=[],o=[];return await Promise.all(e.map(async i=>{try{let a=await this.getRepo(i,t);n.push(a.data)}catch(a){o.push({input:i,error:a})}})),{data:n,errors:o}}async getReposForAzureProject(e,t={}){if(!e.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');return{data:(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/git/repositories`,headers:w(this.config,t)})).body.value.map(o=>Nr(e.namespace,o))}}async getRefs(e,t,n={}){if(!t.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let o=new URL(`${C(this.config,n)}/${encodeURIComponent(t.repo.namespace)}/${encodeURIComponent(t.repo.project)}/_apis/git/repositories/${encodeURIComponent(t.repo.name)}/refs`);o.searchParams.set("filter",e),o.searchParams.set("$top",$.toString()),t.cursor&&o.searchParams.set("continuationToken",t.cursor);let i=await this.config.request({url:o.toString(),headers:w(this.config,n)}),a=i.headers["x-ms-continuationtoken"];return{pageInfo:{hasNextPage:!!a,endCursor:a||null},data:i.body.value.map(u=>({name:Oe(u.name),commit:{oid:u.objectId,authoredDate:null,committedDate:null}}))}}async getBranches(e,t={}){return this.getRefs("heads",e,t)}async getTags(e,t={}){return this.getRefs("tags",e,t)}async getPullRequestsForRepoBase(e,t={},n=100){let{page:o,repo:i,assigneeLogins:a,authorLogin:u}=e||{},l=o||1;if(!i.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let p="searchCriteria.status=1";return a&&a.length&&(p+=`&searchCriteria.reviewerId=${a[0]}`),u&&(p+=`&searchCriteria.creatorId=${u}`),await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(i.namespace)}/${encodeURIComponent(i.project||"")}/_apis/git/repositories/${encodeURIComponent(i.name)}/pullRequests?${p}&%24top=${n}&%24skip=${(l-1)*n}`,headers:w(this.config,t)})}async getPullRequestsForRepo(e,t={}){let o=e.page||1,i=await this.getPullRequestsForRepoBase(e,t,100);return{pageInfo:{hasNextPage:i.body.value.length===100,nextPage:o+1},data:i.body.value.map(a=>Ee(e.repo.namespace,a))}}async getPullRequestsForRepos(e,t={}){if(!e.repos.every(i=>i.project))throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{repos:n}=e||{},o=[];return await Promise.all(n.map(async i=>{try{(await this.getPullRequestsForRepoBase({repo:i,...e},t)).body.value.forEach(u=>{o.push(Ee(i.namespace,u))})}catch(a){if(a.statusCode!==404&&a.statusCode!==401)throw a}})),{data:o}}async getPullRequestsForProjectBase(e,t={},n=100){let{namespace:o,project:i,page:a,assigneeLogins:u,authorLogin:l,repo:p}=e;if(p?.project&&p.project!==i)throw new Error("Could not fetch pull requests, project mismatch");let c=a||1,d=new URL(`${C(this.config,t)}/${encodeURIComponent(o)}/${encodeURIComponent(i)}/_apis/git/pullRequests`);return d.searchParams.set("searchCriteria.status","1"),d.searchParams.set("$top",n.toString()),d.searchParams.set("$skip",((c-1)*n).toString()),p?.id&&p?.project===i&&d.searchParams.set("searchCriteria.repositoryId",p.id),u&&u.length&&d.searchParams.set("searchCriteria.reviewerId",u[0]),l&&d.searchParams.set("searchCriteria.creatorId",l),await this.config.request({url:d.toString(),headers:w(this.config,t)})}async getPullRequestsForProject(e,t={}){let o=e.page||1,i=await this.getPullRequestsForProjectBase(e,t,100);return{pageInfo:{hasNextPage:i?.body.value.length===100,nextPage:o+1},data:i?.body.value.map(a=>Ee(e.namespace,a))||[]}}async getPullRequestsForProjects(e,t={}){let{projects:n}=e||{},o=[];return await Promise.all(n.map(async i=>{try{(!e.repo||e.repo.project&&e.repo.project===i.project)&&(await this.getPullRequestsForProjectBase({...i,...e},t))?.body.value.forEach(u=>{o.push(Ee(i.namespace,u))})}catch(a){if(a.statusCode!==404&&a.statusCode!==401)throw a}})),{data:o}}async getAzurePullRequestLastMergeStatus(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{repo:{namespace:n,project:o,name:i},pullRequestId:a}=e,u=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(n)}/${encodeURIComponent(o||"")}/_apis/git/repositories/${i}/pullrequests/${a}?includeCommits=true?api-version=6.0`,headers:{...w(this.config,t)}});if(!u.body.mergeStatus)throw new Error("Could not fetch pull request");return{data:u.body.mergeStatus}}async updatePullRequest(e,t,n){return await this.config.request({method:"PATCH",url:`${C(this.config,n)}/${encodeURIComponent(e.repository.owner.login)}/${encodeURIComponent(e.repository.project)}/_apis/git/repositories/${e.repository.name}/pullrequests/${e.id}?api-version=6.0`,body:t,headers:{...w(this.config,n),"Content-Type":"application/json"}})}async closePullRequest(e,t={}){let{pullRequest:n}=e,o={status:"abandoned"};if(!(await this.updatePullRequest(n,JSON.stringify(o),t)).body.status)throw new Error("Could not close pull request")}async mergePullRequest(e,t={}){let{pullRequest:n,mergeStrategy:o}=e,i;switch(o){case"MERGE_COMMIT":{i="noFastForward";break}case"REBASE":{i="rebase";break}case"REBASE_THEN_MERGE_COMMIT":{i="rebaseMerge";break}case"SQUASH":{i="squash";break}}let a={completionOptions:{mergeStrategy:i},lastMergeSourceCommit:{commitId:n.headRef?.oid},status:"completed"};if(!(await this.updatePullRequest(n,JSON.stringify(a),t)).body.status)throw new Error("Could not merge pull request")}async addPullRequestLabel(e,t={}){let{pullRequest:n,label:o}=e;if(!n.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let i={name:o.name};if(!(await this.config.request({method:"POST",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/labels?api-version=6.0`,body:JSON.stringify(i),headers:{...w(this.config,t),"Content-Type":"application/json"}})).body.id)throw new Error("Could not add pull request label")}async removePullRequestLabel(e,t={}){let{pullRequest:n,label:o}=e;if(!n.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');await this.config.request({method:"DELETE",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/labels/${encodeURIComponent(o.name)}?api-version=6.0`,headers:{...w(this.config,t)}})}async setPullRequestLabels(e,t={}){let{pullRequest:n,labels:o}=e;if(!n.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let i=n.labels;if(!i)throw new Error('Azure DevOps requires "labels" for this function.');for(let a of o)i.find(u=>u.id===a.id)||await this.addPullRequestLabel({pullRequest:n,label:a},t);for(let a of i)o.find(u=>a.id===u.id)||await this.removePullRequestLabel({pullRequest:n,label:a},t)}async setPullRequestAsDraft(e,t={}){let{pullRequest:n,isDraft:o}=e,i={isDraft:o};if(!(await this.updatePullRequest(n,JSON.stringify(i),t)).body.status)throw new Error("Could not set the pull request as draft")}async addPullRequestReviewer(e,t={}){let{pullRequest:n,reviewer:o,isRequired:i}=e,a={id:o.id,isRequired:i};if(!(await this.config.request({method:"PUT",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/reviewers/${o.id}?api-version=6.0`,body:JSON.stringify(a),headers:{...w(this.config,t),"Content-Type":"application/json"}})).body.id)throw new Error("Could not add pull request reviewer")}async removePullRequestReviewer(e,t={}){let{pullRequest:n,reviewer:o}=e;await this.config.request({method:"DELETE",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/reviewers/${o.id}?api-version=6.0`,headers:{...w(this.config,t),Accept:"application/json"}})}async setPullRequestReviewers(e,t={}){let{pullRequest:n,reviewers:o}=e;for(let i of o)n.assignees.find(a=>a.id===i.id)||await this.addPullRequestReviewer({pullRequest:n,reviewer:i,isRequired:!0},t);for(let i of n.assignees)o.find(a=>i.id===a.id)||await this.removePullRequestReviewer({pullRequest:n,reviewer:i},t)}async getIssuesForAzureProject(e,t={}){let{page:n,assigneeLogins:o,authorLogin:i,mentionLogin:a,labelNames:u,statusByWorkItemIdByStatusId:l}=e||{},p=n||1,c=200,d=["[Microsoft.VSTS.Common.ClosedDate] = ''","[System.TeamProject] = @project","[Microsoft.VSTS.Common.ResolvedDate] = ''"];i&&d.push(`[System.CreatedBy] = '${i.replace("'","''")}'`),o&&o[0]&&d.push(`[System.AssignedTo] = '${o[0].replace("'","''")}'`),a&&d.push("[System.Id] IN (@recentMentions)"),u&&u.forEach(h=>d.push(`[System.Tags] Contains '${h}'`));let g=`Select [Microsoft.VSTS.Common.ClosedDate], [Microsoft.VSTS.Common.ResolvedDate] From WorkItems Where ${d.join(" AND ")} order by [System.CreatedDate] desc`,m=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/wit/wiql?api-version=6.0`,body:JSON.stringify({query:g}),method:"POST",headers:{...w(this.config,t),"Content-Type":"application/json"}}),I=m.body.workItems.slice((p-1)*c,c*p).map(h=>h.id);if(I.length==0)return{pageInfo:{hasNextPage:!1,nextPage:null},data:[]};let y=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/wit/workitemsbatch?api-version=6.0`,body:JSON.stringify({ids:I,$expand:"Links"}),method:"POST",headers:{...w(this.config,t),"Content-Type":"application/json"}});return{pageInfo:{hasNextPage:m.body.workItems.length>c*p,nextPage:p+1},data:y.body.value.map(h=>rn(e.namespace,e.project,h,l||{}))}}async getPermissionsForRepos(e,t={}){let{namespace:n,repos:o}=e,i={4:["canPush","canCreateWebhook"],1024:["isAdmin"],2048:["isAdmin"],4096:["isAdmin"],8192:["isAdmin"]},a=c=>{let d="2e9eb7ed-3c0a-47d4-87c1-0ffdd275fd87",g=`repoV2/${c.projectId}/${c.id}`;return Object.keys(i).map(m=>({securityNamespaceId:d,token:g,permissions:m}))},u={alwaysAllowAdministrators:!1,evaluations:o.flatMap(a)};return{data:(await this.config.request({method:"POST",url:`${C(this.config,t)}/${encodeURIComponent(n)}/_apis/security/permissionevaluationbatch?api-version=7.0`,body:JSON.stringify(u),headers:{...w(this.config,t),"Content-Type":"application/json"}})).body.evaluations.reduce((c,d)=>{let[,g,m]=d.token.split("/"),I=`${g}/${m}`,y=i[d.permissions];for(let h of y)c[I]===void 0&&(c[I]={canCreateWebhook:!0,canPush:!0,isAdmin:!0}),d.value===!1&&(c[I][h]=!1);return c},{})}}async decorateReposWithPermissions(e,t={}){let{namespace:n,repos:o}=e,i=await this.getPermissionsForRepos({namespace:n,repos:o},t);return{data:o.map(a=>({...a,permissions:i.data[`${a.projectId}/${a.id}`]}))}}async updateIssue(e,t,n={}){return await this.config.request({method:"PATCH",url:`${C(this.config,n)}/${encodeURIComponent(e.project.namespace)}/${encodeURIComponent(e.project.name)}/_apis/wit/workitems/${e.id}?api-version=6.0`,body:JSON.stringify(t),headers:{...w(this.config,n),"Content-Type":"application/json-patch+json"}})}async setIssueStatus(e,t={}){let{issue:n,status:o}=e,i=[{op:"add",path:"/fields/System.State",value:o.name}];if(!(await this.updateIssue(n,i,t)).body.fields?.["System.State"])throw new Error("Could not set issue status")}async setIssueAssignee(e,t={}){let{issue:n,assignee:o}=e,i=[{op:"add",path:"/fields/System.AssignedTo",value:o?.name??""}];if(!(await this.updateIssue(n,i,t)).body.fields?.["System.State"])throw new Error("Could not set issue assignee")}async setIssueLabels(e,t={}){let{issue:n,labels:o}=e,a=[{op:"replace",path:"/fields/System.Tags",value:o.map(l=>l.name).join(";")}];if(!(await this.updateIssue(n,a,t)).body.fields?.["System.Tags"])throw new Error("Could not set issue tags")}async getIssueTypesForAzureProject(e,t={}){if(!e.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{namespace:n,project:o}=e;return{data:(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(n)}/${encodeURIComponent(o||"")}/_apis/wit/workitemtypes?api-version=6.0`,headers:{...w(this.config,t)}})).body.value}}async getLabelsForProject(e,t={}){let{namespace:n,project:o}=e;return{data:(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(n)}/${encodeURIComponent(o||"")}/_apis/wit/tags?api-version=6.0`,headers:{...w(this.config,t)}})).body.value.map(a=>({color:null,description:null,id:a.id,name:a.name,url:a.url}))}}async getPullRequestForRepo(e,t={}){let{repo:n,number:o}=e;if(!n.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let i=await this.config.request({url:`${this.getRepoApiUrl(n.namespace,n.project,n.name,t)}/pullrequests/${o}?api-version=7.1`,headers:w(this.config,t)});return{data:Ee(n.namespace,i.body)}}async getPullRequestDescription(e,t={}){let{repo:n,number:o}=e;if(!n.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');try{return{data:{description:(await this.config.request({url:`${this.getRepoApiUrl(n.namespace,n.project,n.name,t)}/pullrequests/${o}?api-version=7.1`,headers:w(this.config,t)})).body?.description??""}}}catch{return{data:{description:null}}}}async setPullRequestDescription(e,t={}){let{repo:n,number:o,description:i}=e;if(!n.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');return{data:{description:(await this.config.request({method:"PATCH",url:`${this.getRepoApiUrl(n.namespace,n.project,n.name,t)}/pullrequests/${o}?api-version=7.1`,headers:{...w(this.config,t),"Content-Type":"application/json"},body:JSON.stringify({description:i})})).body?.description??i}}}async getMergeBase(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=await this.config.request({url:`${this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t)}/commits/${encodeURIComponent(e.base)}/mergebases?otherCommitId=${encodeURIComponent(e.head)}&api-version=7.1`,headers:w(this.config,t)});if(!n.body.value?.length)throw new Error("No merge base found between the specified commits.");return{data:n.body.value[0].commitId}}async getFileContents(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=await this.config.request({url:`${this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t)}/items?path=${encodeURIComponent(e.path)}&versionDescriptor[version]=${encodeURIComponent(e.ref)}&versionDescriptor[versionType]=commit&api-version=7.1`,headers:{...w(this.config,t),Accept:"application/octet-stream"}});return{data:new Blob([n.body])}}async getPullRequestDiff(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t),o=w(this.config,t),i={...o,Accept:"application/octet-stream"},[a,u]=await Promise.all([this.config.request({url:`${n}/pullrequests/${e.pullRequestId}?api-version=7.1`,headers:o}),this.config.request({url:`${n}/pullrequests/${e.pullRequestId}/iterations?api-version=7.1`,headers:o})]),l=a.body.lastMergeTargetCommit.commitId,p=a.body.lastMergeSourceCommit.commitId,c=u.body.value;if(c.length===0)return"";let d=c[c.length-1],g=1e3,m=[],I=0;for(;;){let E=(await this.config.request({url:`${n}/pullrequests/${e.pullRequestId}/iterations/${d.id}/changes?api-version=7.1&$top=${g}&$skip=${I}`,headers:o})).body.changeEntries??[];if(E.length===0||(m.push(...E),E.length<g))break;I+=E.length}if(m.length===0)return"";let y=5,h=[],v=new TextDecoder,D=P=>P instanceof ArrayBuffer?v.decode(P):typeof P=="string"?P:"",k=async(P,E)=>{try{let oe=await this.config.request({url:`${n}/items?path=${encodeURIComponent(P)}&versionDescriptor[version]=${encodeURIComponent(E)}&versionDescriptor[versionType]=commit&includeContent=true&api-version=7.1`,headers:i});return D(oe.body)}catch{return""}},S=P=>{if(typeof P=="number")return{add:(P&1)!==0,rename:(P&8)!==0,delete:(P&16)!==0};let E=P.toLowerCase().split(",").map(oe=>oe.trim());return{add:E.includes("add"),rename:E.includes("rename"),delete:E.includes("delete")}};for(let P=0;P<m.length;P+=y){let E=m.slice(P,P+y),oe=await Promise.all(E.map(async pe=>{let{add:de,rename:Dt,delete:ie}=S(pe.changeType),qe=pe.originalPath??pe.item.originalPath,U=pe.item.path,Ue=ie?U??qe??"":U??"",Ar=Dt||ie?qe??Ue:Ue,[ks,_s]=await Promise.all([de?Promise.resolve(""):k(Ar,l),ie?Promise.resolve(""):k(Ue,p)]),Ns=de?"/dev/null":`a${Ar}`,js=ie?"/dev/null":`b${Ue}`;return(0,jr.createTwoFilesPatch)(Ns,js,ks,_s)}));h.push(...oe)}return h.join(`
|
|
2
|
-
`)}getPullRequestWriteHeaders(e){return{...w(this.config,e),"Content-Type":"application/json"}}setReviewerVote(e,t,n,o,i){return this.config.request({method:"PUT",url:`${e}/pullRequests/${t}/reviewers/${encodeURIComponent(n)}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(i),body:JSON.stringify({vote:o})})}postPullRequestThread(e,t,n,o){return this.config.request({method:"POST",url:`${e}/pullRequests/${t}/threads?api-version=7.1`,headers:this.getPullRequestWriteHeaders(o),body:JSON.stringify({comments:[{parentCommentId:0,content:n,commentType:1}],status:1})})}async getCommentsForPullRequest(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t),o=w(this.config,t),i=await this.config.request({url:`${n}/pullRequests/${e.pullRequestNumber}/threads?api-version=7.1`,headers:o}),a=[];for(let u of i.body.value)if(!(u.isDeleted||u.threadContext))for(let l of u.comments)l.commentType==="system"||l.isDeleted||a.push({id:xt(e.repo.namespace,e.repo.project,e.repo.name,e.pullRequestNumber,u.id,l.id),author:l.author?le(l.author):null,body:l.content||"",createdAt:l.publishedDate?new Date(l.publishedDate):null,url:""});return{data:a,pageInfo:{hasNextPage:!1,endCursor:null}}}async addCommentToPullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,t);await this.postPullRequestThread(n,e.pullRequest.id,e.comment,t)}async addInlineCommentToPullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,t),o=this.getPullRequestWriteHeaders(t);if(e.threadId){let p=kt(e.threadId),c=e.pullRequest.repository.owner.login,d=e.pullRequest.repository.project,g=e.pullRequest.repository.name,m=String(e.pullRequest.id);if(p.namespace!==c||p.project!==d||p.repoName!==g||p.prId!==m)throw new Error(`Azure thread ID context mismatch: threadId targets ${p.namespace}/${p.project}/${p.repoName} pull request ${p.prId}, but input.pullRequest targets ${c}/${d}/${g} pull request ${m}.`);let y=(await this.config.request({url:`${n}/pullRequests/${e.pullRequest.id}/threads/${p.threadId}?api-version=7.1`,headers:w(this.config,t)})).body.comments?.find(v=>v.parentCommentId===0);if(!y)throw new Error(`Could not determine root comment for Azure DevOps thread ${p.threadId}.`);let h=await this.config.request({method:"POST",url:`${n}/pullRequests/${e.pullRequest.id}/threads/${p.threadId}/comments?api-version=7.1`,headers:o,body:JSON.stringify({content:e.comment,parentCommentId:y.id,commentType:1})});return xt(c,d,g,Number(m),Number(p.threadId),h.body.id)}let i=e.path.startsWith("/")?e.path:`/${e.path}`,a={line:e.line,offset:1},u={filePath:i};e.side==="LEFT"?(u.leftFileStart=a,u.leftFileEnd=a):(u.rightFileStart=a,u.rightFileEnd=a);let l=await this.config.request({method:"POST",url:`${n}/pullRequests/${e.pullRequest.id}/threads?api-version=7.1`,headers:o,body:JSON.stringify({comments:[{parentCommentId:0,content:e.comment,commentType:1}],status:1,threadContext:u})});return _r(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,Number(e.pullRequest.id),l.body.id)}async editComment(e,t={}){let n=kr(e.commentId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"PATCH",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}/comments/${n.commentId}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(t),body:JSON.stringify({content:e.body})})}async editInlineComment(e,t={}){return this.editComment(e,t)}async deleteComment(e,t={}){let n=kr(e.commentId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"DELETE",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}/comments/${n.commentId}?api-version=7.1`,headers:w(this.config,t)})}async deleteInlineComment(e,t={}){return this.deleteComment(e,t)}async resolveReviewThread(e,t={}){let n=kt(e.threadId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"PATCH",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(t),body:JSON.stringify({status:2})})}async unresolveReviewThread(e,t={}){let n=kt(e.threadId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"PATCH",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(t),body:JSON.stringify({status:1})})}async approvePullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=e.pullRequest.repository.owner.login,o=this.getRepoApiUrl(n,e.pullRequest.repository.project,e.pullRequest.repository.name,t),i=await this.getCurrentUserId(n,t);await Promise.all([this.setReviewerVote(o,e.pullRequest.id,i,10,t),e.comment?this.postPullRequestThread(o,e.pullRequest.id,e.comment,t):null])}async requestPullRequestChanges(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=e.pullRequest.repository.owner.login,o=this.getRepoApiUrl(n,e.pullRequest.repository.project,e.pullRequest.repository.name,t),i=await this.getCurrentUserId(n,t);await this.postPullRequestThread(o,e.pullRequest.id,e.comment,t),await this.setReviewerVote(o,e.pullRequest.id,i,-5,t)}async commentOnPullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,t);await this.postPullRequestThread(n,e.pullRequest.id,e.comment,t)}async getReviewsForPullRequest(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{namespace:n,project:o,name:i}=e.repo,{pullRequestId:a}=e,u=this.getRepoApiUrl(n,o,i,t),l=w(this.config,t),[p,c]=await Promise.all([this.config.request({url:`${u}/pullRequests/${a}/reviewers?api-version=7.1`,headers:l}),this.config.request({url:`${u}/pullRequests/${a}/threads?api-version=7.1`,headers:l})]),d=(h,v)=>xt(n,o,i,a,h,v),g=h=>_r(n,o,i,a,h),m=new Map;for(let h of c.body.value){if(h.isDeleted)continue;let v=h.comments.filter(U=>!U.isDeleted&&U.commentType!=="system"),D=v.find(U=>U.parentCommentId===0)??v[0];if(!D)continue;let k=D.author?.id;if(!k)continue;let S=v.filter(U=>U.id!==D.id),P=h.threadContext,E=P?.rightFileStart?{side:"RIGHT",start:P.rightFileStart,end:P.rightFileEnd}:P?.leftFileStart?{side:"LEFT",start:P.leftFileStart,end:P.leftFileEnd}:null,oe=E?.end?.line??E?.start.line??null,pe=E?.start&&E.end&&E.start.line!==E.end.line?E.start.line:null,de=P?.filePath??"",Dt=de.startsWith("/")?de.slice(1):de,ie={id:d(h.id,D.id),author:D.author?le(D.author):null,body:D.content??"",createdAt:D.publishedDate?new Date(D.publishedDate):null,url:"",diffLines:[],filename:Dt,replies:S.map(U=>({id:d(h.id,U.id),author:U.author?le(U.author):null,body:U.content??"",createdAt:U.publishedDate?new Date(U.publishedDate):null,url:""})),isOutdated:!1,isResolved:Zs.has(Ys(h.status)),line:oe,startLine:pe,side:E?.side??null,threadId:g(h.id)},qe=m.get(k);qe?qe.push(ie):m.set(k,[ie])}let I=[],y=new Set;for(let h of p.body.value){if(h.hasDeclined)continue;let v=h.vote??0,D=m.get(h.id);v===0&&!D?.length||(I.push({id:h.id,author:le(h),body:"",createdAt:null,url:"",reviewComments:D??[]}),y.add(h.id))}for(let[h,v]of m){if(y.has(h)||!v.length)continue;let D=v[0].author;D&&I.push({id:h,author:D,body:"",createdAt:null,url:"",reviewComments:v})}return{data:I}}};var L=(s,r={})=>f(r.token||s.token,r.isPAT||s.isPAT);var T="https://api.bitbucket.org/2.0",sn={OPEN:"OPEN",MERGED:"MERGED",DECLINED:"CLOSED"},xe={owner:4,admin:3,contributor:2,member:1},ke=s=>({id:s.uuid,name:s.display_name||s.nickname,username:s.nickname||s.display_name,email:null,avatarUrl:s.links.avatar.href,url:s.links.html.href}),Br=s=>{let r=s.links.clone,e=r?.find(n=>n.name==="ssh"),t=r?.find(n=>n.name==="https");return e&&t?{cloneUrlHTTPS:t.href,cloneUrlSSH:e.href}:null},_t=s=>({id:s.uuid,namespace:s.workspace.slug,name:s.slug,webUrl:s.links.html.href,httpsUrl:s.links.clone.find(r=>r.name==="https")?.href??null,sshUrl:s.links.clone.find(r=>r.name==="ssh")?.href??null,defaultBranch:{name:s.mainbranch.name},permissions:null}),Nt=s=>{let r=s.id,e=s.participants?.map(t=>{let n="REVIEW_REQUESTED";return t.approved?n="APPROVED":t.state==="changes_requested"?n="CHANGES_REQUESTED":t.participated_on!==null&&(n="COMMENTED"),{reviewer:ke(t.user),state:n}})??[];return{id:r.toString(),title:s.title,description:s.description,number:r,state:sn[s.state],isDraft:!1,commentCount:s.comment_count,upvoteCount:null,author:ke(s.author),createdDate:new Date(s.created_on),updatedDate:new Date(s.updated_on),closedDate:null,mergedDate:null,repository:{id:s.destination.repository.uuid,name:s.destination.repository.name,owner:{login:s.destination.repository.full_name.split("/")[0]},remoteInfo:Br(s.destination.repository)},headCommit:{buildStatuses:null},baseRef:{name:s.destination.branch.name,oid:s.destination.commit.hash},headRef:{name:s.source.branch.name,oid:s.source.commit.hash},url:s.links.html.href,assignees:null,reviews:e,reviewDecision:H(e),additions:null,deletions:null,fileCount:null,commitCount:null,headRepository:{id:s.source.repository.uuid,name:s.source.repository.name,owner:{login:s.source.repository.full_name.split("/")[0]},remoteInfo:Br(s.source.repository)},mergeableState:"MERGEABLE",permissions:null}},nn=s=>{switch(s){case"owner":case"admin":return{canCreateWebhook:!0,canPush:!0,isAdmin:!0};case"write":return{canCreateWebhook:!1,canPush:!0,isAdmin:!1};case"read":case"none":return{canCreateWebhook:!1,canPush:!1,isAdmin:!1}}},on=s=>{switch(s){case"owner":case"admin":return{canCreateWebhook:!0,canPush:!0,isAdmin:!0};case"contributor":return{canCreateWebhook:!1,canPush:!0,isAdmin:!1};default:return{canCreateWebhook:!1,canPush:!1,isAdmin:!1}}},ge=class extends F{async refreshToken(r){return{data:(await this.config.request({url:"https://bitbucket.org/site/oauth2/access_token",method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Authorization:`Basic ${r.base64ClientIDColonClientSecret}`},body:`grant_type=refresh_token&refresh_token=${r.refreshToken}`})).body}}async getCurrentUser(r={},e={}){let t=await this.config.request({url:`${T}/user`,headers:L(this.config,e)});return{data:ke(t.body)}}async getUserForCommit(r,e={}){let n=(await this.config.request({url:`${T}/repositories/${r.repo.namespace}/${r.repo.name}/commit/${r.oid}`,headers:L(this.config,e)})).body.author,o=n.raw.match(/([^<]+)<(.+)>/);return{data:{name:o?o[1].trim():null,email:o?o[2]:null,avatarUrl:n.user?.links.avatar.href||null}}}async getRepo(r,e={}){let t=await this.config.request({url:`${T}/repositories/${r.namespace}/${r.name}`,headers:L(this.config,e)});return{data:_t(t.body)}}async getRepos(r,e={}){let t=[],n=[];return await Promise.all(r.map(async o=>{try{let i=await this.getRepo(o,e);t.push(i.data)}catch(i){n.push({input:o,error:i})}})),{data:t,errors:n}}async getReposForWorkspace(r,e={}){let t=new URL(`${T}/repositories/${encodeURIComponent(r.workspace)}`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen",$.toString()),r.minimumRole&&t.searchParams.set("role",r.minimumRole);let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(_t)}}async getAllReposForWorkspace(r,e={}){let t=[],n=1;for(;n!==null;){let o=await this.getReposForWorkspace({workspace:r.workspace,minimumRole:r.minimumRole,page:n},e);t.push(...o.data),n=o.pageInfo.hasNextPage?o.pageInfo.nextPage:null}return t}async getAllReposForWorkspaceWithPermissions(r,e={}){let t=new Map,n=[],o=xe[r.minimumRole||"member"];o<=xe.admin&&n.push("admin"),o<=xe.contributor&&n.push("contributor"),o<=xe.member&&n.push("member");let i=[];for(let a of n){i=await this.getAllReposForWorkspace({workspace:r.workspace,minimumRole:a},e);for(let u of i)t.has(u.id)||t.set(u.id,a)}return{data:i.map(a=>{let u=t.get(a.id)||"member";return{...a,permissions:on(u)}})}}async getReposForCurrentUser(r,e={}){let t=new URL(`${T}/repositories`);t.searchParams.set("role","member"),t.searchParams.set("pagelen",$.toString()),r.cursor&&t.searchParams.set("after",r.cursor);let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next,i=null;return n.body.next&&(i=new URL(n.body.next).searchParams.get("after")),{pageInfo:{hasNextPage:o,endCursor:i},data:n.body.values.map(_t)}}async getBranches(r,e={}){let t=new URL(`${T}/repositories/${r.repo.namespace}/${r.repo.name}/refs/branches`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen",$.toString());let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>{let a=new Date(i.target.date);return{name:i.name,commit:{oid:i.target.hash,authoredDate:a,committedDate:a}}})}}async getTags(r,e={}){let t=new URL(`${T}/repositories/${r.repo.namespace}/${r.repo.name}/refs/tags`);t.searchParams.set("pagelen",$.toString()),r.cursor&&t.searchParams.set("page",r.cursor);let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next,i=null;return n.body.next&&(i=new URL(n.body.next).searchParams.get("page")),{pageInfo:{hasNextPage:o,endCursor:i},data:n.body.values.map(a=>{let u=new Date(a.target.date);return{name:a.name,commit:{oid:a.target.hash,authoredDate:u,committedDate:u}}})}}async getWorkspacesForCurrentUser(r={},e={}){let t=new URL(`${T}/user/workspaces`);t.searchParams.set("page",r?.page?.toString()||"1"),t.searchParams.set("pagelen","50"),r?.administrator!==void 0&&t.searchParams.set("administrator",r.administrator.toString());let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>({id:i.workspace.uuid,slug:i.workspace.slug}))}}async getWorkspacesForUser(r,e={}){let t=new URL(`${T}/user/permissions/workspaces`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","50");let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>({id:i.workspace.uuid,slug:i.workspace.slug,name:i.workspace.name}))}}async getPullRequestsForUserAndWorkspace(r,e={}){let t=new URL(`${T}/workspaces/${r.workspaceSlug}/pullrequests/${r.userId}`);if(t.searchParams.set("fields","+values.participants,+values.destination.repository.links.clone.*,+values.source.repository.links.clone.*"),t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","50"),r.repos&&r.repos.length>0){let i=`state = "open" AND (${r.repos.map(a=>`source.repository.full_name = "${a.namespace}/${a.name}"`).join(" OR ")})`;t.searchParams.set("q",i)}let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(Nt)}}async getPullRequestsForRepoBase(r,e={}){let t=new URL(`${T}/repositories/${encodeURI(r.repo.namespace)}/${encodeURI(r.repo.name)}/pullrequests?state=OPEN`),n=[];r.reviewerId&&n.push(`reviewers.uuid="${r.reviewerId}"`),r.authorLogin&&n.push(`author.uuid="${r.authorLogin}"`);let o='state="OPEN"';return n.length&&(o+=` AND (${n.join(r.useOrFilter?" OR ":" AND ")})`),t.searchParams.set("fields","+values.participants,+values.destination.repository.links.clone.*,+values.source.repository.links.clone.*"),t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","50"),t.searchParams.set("q",o),await this.config.request({url:t.toString(),headers:L(this.config,e)})}async getPullRequestsForRepo(r,e={}){let t=[],n=await this.getPullRequestsForRepoBase(r,e);n.body.values.forEach(i=>{t.push(Nt(i))});let o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:t}}async getPullRequestsForRepos(r,e={}){let t=[];return await Promise.all(r.repos.map(async n=>{try{(await this.getPullRequestsForRepoBase({repo:n,...r},e)).body.values.forEach(i=>{t.push(Nt(i))})}catch(o){if(o.statusCode!==404&&o.statusCode!==401)throw o}})),{data:t}}async getAccountsForWorkspace(r,e={}){let t=new URL(`${T}/workspaces/${encodeURI(r.workspace)}/members`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","100");let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>ke(i.user))}}async getReposPermissionsForCurrentUser(r,e={}){let t=new URL(`${T}/user/permissions/repositories`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","100");let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.reduce((i,a)=>({...i,[a.repository.uuid]:nn(a.permission)}),{})}}async decorateReposWithPermissions(r,e={}){let t={},n=1;do{let o=await this.getReposPermissionsForCurrentUser({page:n},e);t={...o.data,...t},n=o.pageInfo.hasNextPage?o.pageInfo.nextPage:null}while(n!==null);return{data:r.repos.map(o=>({...o,permissions:t[o.id]??{canCreateWebhook:!1,canPush:!1,isAdmin:!1}}))}}async closePullRequest(r,e={}){let{pullRequest:t}=r;if(!(await this.config.request({method:"POST",url:`${T}/repositories/${t.repository.owner.login}/${t.repository.name}/pullrequests/${t.id}/decline`,headers:L(this.config,e)})).body.title)throw new Error("Could not close pull request")}async mergePullRequest(r,e={}){let{pullRequest:t,mergeStrategy:n}=r,o;switch(n){case"MERGE_COMMIT":{o="merge_commit";break}case"FAST_FORWARD":{o="fast_forward";break}case"SQUASH":{o="squash";break}}let i={merge_strategy:o,type:"pullrequest"};if(!(await this.config.request({method:"POST",url:`${T}/repositories/${t.repository.owner.login}/${t.repository.name}/pullrequests/${t.id}/merge`,body:JSON.stringify(i),headers:{...L(this.config,e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not merge pull request")}async setPullRequestReviewers(r,e={}){let{pullRequest:t,reviewers:n}=r,o={reviewers:n.map(a=>{if(a.username)throw new Error('Bitbucket reviewer requires "username" for this function.');return{username:a.username}})};if(!(await this.config.request({method:"PUT",url:`${T}/repositories/${t.repository.owner.login}/${t.repository.name}/pullrequests/${t.id}`,body:JSON.stringify(o),headers:{...L(this.config,e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not set pull request reviewers")}};var _e={};z(_e,{normalizePermissions:()=>jt,restApiPullRequestToCommonPullRequest:()=>an});var an=s=>Se(s),jt=s=>s?s.find(r=>r.permission==="USER_ADMIN"||r.permission==="PROJECT_ADMIN"||r.permission==="ADMIN"||r.permission==="SYS_ADMIN"||r.permission==="REPO_ADMIN")?{canCreateWebhook:!0,canPush:!0,isAdmin:!0}:s.find(r=>r.permission==="REPO_WRITE"||r.permission==="REPO_CREATE"||r.permission==="PROJECT_CREATE"||r.permission==="PROJECT_WRITE")?{canCreateWebhook:!1,canPush:!0,isAdmin:!1}:{canCreateWebhook:!1,canPush:!1,isAdmin:!1}:{canCreateWebhook:!1,canPush:!1,isAdmin:!1};var Ce=s=>{let r=s.links.self[0].href;return{name:s.displayName,email:s.emailAddress,avatarUrl:s.avatarUrl??(r&&`${r}/avatar.png`),id:s.id.toString(),username:s.name,url:r}},Se=s=>{let r={OPEN:"OPEN",MERGED:"MERGED",DECLINED:"CLOSED"},e={UNAPPROVED:"REVIEW_REQUESTED",NEEDS_WORK:"CHANGES_REQUESTED",APPROVED:"APPROVED"},t=s.reviewers.map(u=>({reviewer:Ce(u.user),state:e[u.status]})),n=s.toRef.repository.links.clone.find(u=>u.name==="ssh")?.href??null,o=s.toRef.repository.links.clone.find(u=>u.name==="https")?.href??null;o||(o=s.toRef.repository.links.clone.find(u=>u.name==="http")?.href??null);let i=s.fromRef.repository.links.clone.find(u=>u.name==="ssh")?.href??null,a=s.fromRef.repository.links.clone.find(u=>u.name==="https")?.href??null;return a||(a=s.fromRef.repository.links.clone.find(u=>u.name==="http")?.href??null),{id:s.id.toString(),number:s.id,title:s.title,description:s.description,url:s.links.self[0].href,state:r[s.state],isDraft:!1,createdDate:new Date(s.createdDate),updatedDate:new Date(s.updatedDate),closedDate:s.closedDate?new Date(s.closedDate):null,mergedDate:s.state=="MERGED"&&s.closedDate?new Date(s.closedDate):null,baseRef:{name:s.toRef.displayId,oid:s.toRef.latestCommit},headRef:{name:s.fromRef.displayId,oid:s.fromRef.latestCommit},commentCount:s.properties.commentCount,upvoteCount:null,commitCount:null,fileCount:null,additions:null,deletions:null,author:Ce(s.author.user),assignees:null,reviews:t,reviewDecision:H(t),repository:{id:s.toRef.repository.id.toString(),name:s.toRef.repository.name,owner:{login:s.toRef.repository.project.key},remoteInfo:o&&n?{cloneUrlHTTPS:o,cloneUrlSSH:n}:null},headRepository:{id:s.fromRef.repository.id.toString(),name:s.fromRef.repository.name,owner:{login:s.fromRef.repository.project.key},remoteInfo:a&&i?{cloneUrlHTTPS:a,cloneUrlSSH:i}:null},headCommit:null,mergeableState:"MERGEABLE",permissions:null,version:s.version}},Qr=s=>({id:s.id.toString(),namespace:s.project.key,name:s.slug,webUrl:s.links.self[0]?.href??null,httpsUrl:s.links.clone.find(r=>r.name==="https"||r.name==="http")?.href??null,sshUrl:s.links.clone.find(r=>r.name==="ssh")?.href??null,defaultBranch:null,permissions:null}),he=class extends j{getBaseUrl(r){let e=r.baseUrl||this.config.baseUrl;if(!e)throw new Error('Bitbucket Server requires "baseUrl"');return e}getRequestHeaders(r){return f(r.token||this.config.token)}async getCurrentUser(r={},e={}){let t=await this.config.request({url:`${this.getBaseUrl(e)}/users?limit=2`,headers:this.getRequestHeaders(e)}),{headers:{"x-auserid":n,"x-ausername":o}}=t,i=n?parseInt(n,10):null,a=decodeURIComponent(o),l=(await this.config.request({url:`${this.getBaseUrl(e)}/users?filter=${o}&avatarSize=64`,headers:this.getRequestHeaders(e)})).body.values.find(({emailAddress:p,id:c,name:d,slug:g})=>i?i===c:a===d||a===p||a===g);if(!l)throw new Error("Could not find current Bitbucket Server user");return{data:Ce(l)}}async getUserForCommit(r,e){let{repo:t,oid:n}=r,o=await this.config.request({url:`${this.getBaseUrl(e)}/projects/${t.namespace}/repos/${t.name}/commits/${n}`,headers:this.getRequestHeaders(e)});if(!o.body.author)throw new Error("Could not find user for commit");return{data:Ce(o.body.author)}}async getRepo(r,e={}){let t=await this.config.request({url:`${this.getBaseUrl(e)}/projects/${r.namespace}/repos/${r.name}`,headers:this.getRequestHeaders(e)});return{data:Qr(t.body)}}async getRepos(r,e={}){let t=[],n=[];return await Promise.all(r.map(async o=>{try{let i=await this.getRepo(o,e);t.push(i.data)}catch(i){n.push({input:o,error:i})}})),{data:t,errors:n}}async getReposForCurrentUser(r,e={}){let t=r.page??0,n=await this.config.request({url:`${this.getBaseUrl(e)}/repos?start=${t}`,headers:this.getRequestHeaders(e)});return{pageInfo:{hasNextPage:!n.body.isLastPage,nextPage:n.body.nextPageStart},data:n.body.values.map(Qr)}}async getRepoPermissionsForUsername(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/projects/${r.repo.namespace}/repos/${r.repo.name}/permissions/search?filterText=${r.username}`);try{let n=await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)});return{data:jt(n.body.values)}}catch(n){if(n.response?.status===401)return{data:{canCreateWebhook:!1,canPush:!1,isAdmin:!1}};throw n}}async decorateReposWithPermissions(r,e={}){return await Promise.all(r.repos.map(async n=>{let o=await this.getRepoPermissionsForUsername({repo:n,username:r.username},e);return{...n,permissions:o.data}}))}async getPullRequestsForRepoBase(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/projects/${encodeURI(r.repo.namespace)}/repos/${encodeURI(r.repo.name)}/pull-requests?state=OPEN`);return t.searchParams.set("start",r.page?.toString()||"0"),t.searchParams.set("limit","50"),await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)})}async getPullRequestsForRepo(r,e={}){let t=[],n=await this.getPullRequestsForRepoBase(r,e);n.body.values.forEach(i=>{if(r.authorLogin&&i.author.user.name!==r.authorLogin)return null;t.push(Se(i))});let o=n.body.values.length!==0;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.start+n.body.values.length:null},data:t}}async getPullRequestsForRepos(r,e={}){let t=[];return await Promise.all(r.repos.map(async n=>{try{(await this.getPullRequestsForRepoBase({repo:n,...r},e)).body.values.forEach(i=>{if(r.authorLogin&&i.author.user.name!==r.authorLogin)return null;t.push(Se(i))})}catch(o){if(o.statusCode!==404&&o.statusCode!==401)throw o}})),{data:t}}async getPullRequestsForCurrentUser(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/dashboard/pull-requests`);t.searchParams.set("state","OPEN"),t.searchParams.set("start",r.page?.toString()||"0"),t.searchParams.set("limit","50");let n=await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)}),o=n.body.values.length!==0;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.start+n.body.values.length:null},data:n.body.values.map(Se)}}async closePullRequest(r,e={}){let{pullRequest:t}=r;if(t.version===void 0)throw new Error('Bitbucket Server requires "version" for this function.');if(!(await this.config.request({method:"POST",url:`${this.getBaseUrl(e)}/projects/${t.repository.owner.login}/repos/${t.repository.name}/pull-requests/${t.id}/decline`,body:JSON.stringify({version:t.version}),headers:{...this.getRequestHeaders(e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not close pull request")}async mergePullRequest(r,e={}){let{pullRequest:t,mergeStrategyId:n}=r;if(r.mergeStrategy)throw new Error('Bitbucket Server uses "mergeStrategyId" instead of "mergeStrategy".');if(t.version===void 0)throw new Error('Bitbucket Server requires "version" for this function.');if(!(await this.config.request({method:"POST",url:`${this.getBaseUrl(e)}/projects/${t.repository.owner.login}/repos/${t.repository.name}/pull-requests/${t.id}/merge`,body:JSON.stringify({strategyId:n,version:t.version}),headers:{...this.getRequestHeaders(e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not merge pull request")}async getMergeStrategies(r={}){let e=await this.config.request({url:`${this.getBaseUrl(r)}/admin/pull-requests/git`,headers:{...this.getRequestHeaders(r),"Content-Type":"application/json"}});return{data:{defaultStrategy:e.body.mergeConfig.defaultStrategy,strategies:e.body.mergeConfig.strategies}}}async setPullRequestReviewers(r,e={}){let{pullRequest:t,reviewers:n}=r;if(t.version===void 0)throw new Error('Bitbucket Server requires "version" for this function.');let o={reviewers:n.map(a=>{if(a.username)throw new Error('Bitbucket Server reviewer requires "username" for this function.');return{user:{name:a.username}}}),version:t.version};if(!(await this.config.request({method:"PUT",url:`${this.getBaseUrl(e)}/projects/${t.repository.owner.login}/repos/${t.repository.name}/pull-requests/${t.id}`,body:JSON.stringify(o),headers:{...this.getRequestHeaders(e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not set pull request reviewers")}async getAccountsForProject(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/projects/${encodeURI(r.project)}/permissions/users`);t.searchParams.set("start",r.page?.toString()||"0"),t.searchParams.set("limit","50");let n=await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)}),o=n.body.values.length!==0;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.start+n.body.values.length:null},data:n.body.values.map(i=>Ce(i.user))}}};var ss=require("js-base64");var Ne=(e=>(e.Open="OPEN",e.Closed="CLOSED",e))(Ne||{});var R=class extends Error{constructor(e,t){let n=t?.map(i=>`'${i.message}'`).join(", "),o=n?`${e}: ${n}`:e;super(o);this.graphQLErrors=t??[]}};var un={AS_CODE_OWNER:[3,0,0],CHECK_RUN:[3,0,0],LATEST_REVIEWS:[3,0,0],VIEWER_CAN_MERGE_AS_ADMIN:[3,5,0],ISSUE_FULL_DATABASE_ID:[3,12,0],PR_FULL_DATABASE_ID:[3,13,0],PR_REVIEW_FULL_DATABASE_ID:[3,13,0],PR_REVIEW_COMMENT_FULL_DATABASE_ID:[3,13,0]},Fr=15,Mr=100,De={__typename:"User",id:"U_kgDNJ5k",databaseId:10137,name:"Deleted user",login:"ghost",email:"",avatarUrl:"https://avatars.githubusercontent.com/u/10137?v=4",url:"https://github.com/ghost"},O=s=>!!s,J=(s,r)=>{let e=un[r];for(let t=0;t<3;t++){if(s[t]>e[t])return!0;if(s[t]<e[t])return!1}return!0},Be="https://api.github.com",ln=`${Be}/graphql`,Qe=`
|
|
1
|
+
"use strict";var $t=Object.defineProperty;var Bs=Object.getOwnPropertyDescriptor;var Qs=Object.getOwnPropertyNames;var Fs=Object.prototype.hasOwnProperty;var z=(s,r)=>{for(var e in r)$t(s,e,{get:r[e],enumerable:!0})},Ms=(s,r,e,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of Qs(r))!Fs.call(s,n)&&n!==e&&$t(s,n,{get:()=>r[n],enumerable:!(t=Bs(r,n))||t.enumerable});return s};var zs=s=>Ms($t({},"__esModule",{value:!0}),s);var Ho={};z(Ho,{AzureDevOps:()=>me,AzureDevopsUtils:()=>lt,Bitbucket:()=>ge,BitbucketServer:()=>he,BitbucketServerUtils:()=>_e,BitbucketUtils:()=>pt,EntityIdentifierProviderType:()=>k,EntityIdentifierUtils:()=>wt,EntityType:()=>N,EntityVersion:()=>_,GitBuildStatusStage:()=>Lr,GitBuildStatusState:()=>ve,GitDiffLineType:()=>At,GitHub:()=>fe,GitHubIssueCloseReason:()=>ks,GitHubUtils:()=>vt,GitIssueState:()=>Ne,GitLab:()=>Ie,GitLabUtils:()=>Et,GitMergeStrategy:()=>ce,GitProviderUtils:()=>qt,GitPullRequestMergeableState:()=>Y,GitPullRequestReviewState:()=>W,GitPullRequestState:()=>ae,GraphQLErrors:()=>R,Jira:()=>be,JiraServer:()=>ye,JiraUtils:()=>St,Linear:()=>Pe,PullRequestAsyncStatus:()=>Os,Trello:()=>we,TrelloUtils:()=>Ct,Utils:()=>Wo,default:()=>zo,isFetch:()=>Ge});module.exports=zs(Ho);var jr=require("diff");var Lr=(n=>(n.Build="build",n.Production="production",n.Staging="staging",n.Test="test",n))(Lr||{}),ve=(p=>(p.ActionRequired="ACTION_REQUIRED",p.Cancelled="CANCELLED",p.Error="ERROR",p.Failed="FAILED",p.Pending="PENDING",p.Running="RUNNING",p.Skipped="SKIPPED",p.Success="SUCCESS",p.Warning="WARNING",p.OptionalActionRequired="OPTIONAL_ACTION_REQUIRED",p))(ve||{}),ce=(o=>(o.MergeCommit="MERGE_COMMIT",o.Rebase="REBASE",o.RebaseThenMergeCommit="REBASE_THEN_MERGE_COMMIT",o.FastForward="FAST_FORWARD",o.Squash="SQUASH",o))(ce||{}),ae=(t=>(t.Open="OPEN",t.Closed="CLOSED",t.Merged="MERGED",t))(ae||{}),W=(n=>(n.Approved="APPROVED",n.ChangesRequested="CHANGES_REQUESTED",n.Commented="COMMENTED",n.ReviewRequested="REVIEW_REQUESTED",n))(W||{}),Y=(u=>(u.Behind="BEHIND",u.Blocked="BLOCKED",u.Conflicts="CONFLICTS",u.FailingChecks="FAILING_CHECKS",u.Mergeable="MERGEABLE",u.Unknown="UNKNOWN",u.UnknownAndBlocked="UNKNOWN_AND_BLOCKED",u.Unstable="UNSTABLE",u))(Y||{}),At=(t=>(t.ADDED="ADDED",t.DELETED="DELETED",t.UNMODIFIED="UNMODIFIED",t))(At||{});var Ur={APPROVED:0,COMMENTED:1,REVIEW_REQUESTED:2,CHANGES_REQUESTED:3},H=s=>!s||s.length===0?null:s.reduce((r,e)=>Ur[e.state]>Ur[r]?e.state:r,"APPROVED"),Te=(s,r)=>s.name||s.username||s.email||r,ue=s=>{let r=Object.values(s).map(e=>e.name).sort((e,t)=>e.localeCompare(t));return Object.values(s).forEach(e=>{e.priority!==-1&&(e.priority=r.indexOf(e.name))}),s};var Lt=(a=>(a[a.Unknown=0]="Unknown",a[a.Active=1]="Active",a[a.Fixed=2]="Fixed",a[a.WontFix=3]="WontFix",a[a.Closed=4]="Closed",a[a.ByDesign=5]="ByDesign",a[a.Pending=6]="Pending",a))(Lt||{});var $=100;var Tr=globalThis.fetch;var Ws=async s=>{let r=s.headers.get("content-type")||"",e=null;if(r.startsWith("application/json")){let o=await s.text();e=o.trim().length>0?JSON.parse(o):null}else if(r.startsWith("text/")||r===""||r.startsWith("application/vnd.github.diff")||r.startsWith("application/vnd.github.patch"))e=await s.text();else if(r.startsWith("application/vnd.github.raw+json")||r.startsWith("application/octet-stream"))e=await s.arrayBuffer();else throw new Error(`Unsupported content-type: ${r}`);let t={};s.headers.forEach((o,i)=>{t[i]=o});let n={body:e,headers:t,status:s.status,statusText:s.statusText};if(!s.ok){let o=new Error(s.statusText);throw Object.assign(o,{response:n}),o}return n},Ut=s=>async({url:r,...e})=>{let t=await s(r,e);return Ws(t)};var Ge=(s,r=!1)=>s.name==="fetch"||r;var F=class{constructor(r){let e=r?.request||Tr;this.config={...r,request:Ge(e,r?.forceIsFetch)?Ut(e):e}}updateConfig(r){this.config={...this.config,...r,request:r.request&&Ge(r.request,r?.forceIsFetch??this.config.forceIsFetch)?Ut(r.request):this.config.request}}},j=class extends F{};var f=(s,r)=>{let e={};return s&&(e.Authorization=`${r?"Basic":"Bearer"} ${s}`),e},Gr=s=>s?s.reduce((r,e)=>(r[e]=!0,r),{}):void 0,se=(s,r,e)=>!s||r.some(t=>s[t])?e:"",Or=async s=>{let r=[],e=!0,t;for(;e;){let n=await s(t);r=r.concat(n.data),e=!!n?.pageInfo?.hasNextPage,t=n?.pageInfo?.endCursor||n?.pageInfo?.nextPage}return r};async function Tt(s){return(await Promise.allSettled(s)).map(e=>Hs(e)).filter(e=>e!=null)}function Hs(s,r=void 0){return s?.status==="fulfilled"?s.value:r}var Js="https://app.vssps.visualstudio.com/_apis",Vs="https://vssps.dev.azure.com/",Ks="https://dev.azure.com",w=(s,r={})=>f(r.token||s.token,r.isPAT||s.isPAT),kr=s=>s.url.replace("/_apis/git/repositories/","/_git/").replace(`/${s.repository.project.id}/`,`/${encodeURIComponent(s.repository.project.name)}/`).replace(`/${s.repository.id}/`,`/${encodeURIComponent(s.repository.name)}/`).replace("/pullRequests/","/pullrequest/"),Gt=(s,r)=>{let e=r.baseUrl||s.baseUrl||Js;return e=e.replace(/\/$/,""),e},C=(s,r)=>{let e=r.baseUrl||s.baseUrl||Ks;return e=e.replace(/\/$/,""),e},Ot=(s,r)=>{let e=r.baseUrl||s.baseUrl||Vs;return e=e.replace(/\/$/,""),e};var Xs={active:"OPEN",completed:"MERGED",abandoned:"CLOSED"},Ys=s=>{if(typeof s!="string")return s;let r=s.charAt(0).toUpperCase()+s.slice(1);return Lt[r]??0},Zs=new Set([2,3,4,5]),en={10:"APPROVED",5:"APPROVED",0:"REVIEW_REQUESTED",[-5]:"CHANGES_REQUESTED",[-10]:"CHANGES_REQUESTED"},le=s=>({id:s.id,name:s.displayName??null,username:(s.uniqueName||s.displayName)??null,email:null,avatarUrl:s.imageUrl??null,url:null}),Oe=s=>s.startsWith("refs/heads/")?s.replace("refs/heads/",""):s,tn=s=>{switch(s){case"conflicts":return"CONFLICTS";case"failure":return"FAILING_CHECKS";case"rejectedByPolicy":return"BLOCKED";case"succeeded":return"MERGEABLE";case"notSet":case"queued":default:return"UNKNOWN"}},kt=(s,r,e,t,n,o)=>`${s}|${r}|${e}|${t}|${n}|${o}`,xr=s=>{let r=s.split("|");if(r.length!==6)throw new Error("Invalid Azure comment ID format");return{namespace:r[0],project:r[1],repoName:r[2],prId:r[3],threadId:r[4],commentId:r[5]}},_r=(s,r,e,t,n)=>`${s}|${r}|${e}|${t}|${n}`,xt=s=>{let r=s.split("|");if(r.length!==5)throw new Error("Invalid Azure thread ID format");return{namespace:r[0],project:r[1],repoName:r[2],prId:r[3],threadId:r[4]}},Ee=(s,r)=>{let e=[],t=[];return r.reviewers.forEach(n=>{let o={reviewer:le(n),state:en[n.vote??0]||"REVIEW_REQUESTED"};n.isRequired&&e.push(o),t.push(o)}),{id:r.pullRequestId.toString(),title:r.title,description:r.description??null,number:r.codeReviewId,state:Xs[r.status],isDraft:r.isDraft,commentCount:null,upvoteCount:null,author:le(r.createdBy),createdDate:new Date(r.creationDate),updatedDate:new Date(r.closedDate||r.creationDate),closedDate:r.closedDate?new Date(r.closedDate):null,mergedDate:r.closedDate&&r.status==="completed"?new Date(r.closedDate):null,repository:{id:r.repository.id,name:r.repository.name,project:r.repository.project.name,owner:{login:s},remoteInfo:null},headCommit:{buildStatuses:null},baseRef:{name:Oe(r.targetRefName),oid:r.lastMergeTargetCommit.commitId},headRef:{name:Oe(r.sourceRefName),oid:r.lastMergeSourceCommit.commitId},url:kr(r),assignees:r.reviewers.map(le),reviews:t,reviewDecision:H(e),additions:null,deletions:null,fileCount:null,commitCount:null,headRepository:r.forkSource?{id:r.forkSource.repository.id,name:r.forkSource.repository.name,project:void 0,owner:{login:s},remoteInfo:null}:{id:r.repository.id,name:r.repository.name,project:r.repository.project.name,owner:{login:s},remoteInfo:null},mergeableState:tn(r.mergeStatus),labels:r.labels?.map(n=>({color:null,description:null,id:n.id,name:n.name}))??[],permissions:null}},Nr=(s,r)=>({id:r.id,name:r.name,namespace:s,project:r.project.name,projectId:r.project.id,webUrl:r.webUrl,httpsUrl:r.remoteUrl,sshUrl:r.sshUrl,defaultBranch:r.defaultBranch?{name:Oe(r.defaultBranch)}:null,permissions:null}),rn=(s,r,e,t)=>{let n=e.fields,o=n["System.AssignedTo"],i=n["System.State"],a=n["System.WorkItemType"],u;return i&&a&&(u=t[a]?.[i]),{id:e.id.toString(),number:e.id.toString(),title:n["System.Title"],commentCount:n["System.CommentCount"],author:{avatarUrl:n["System.CreatedBy"]._links?.avatar?.href??null,email:null,id:n["System.CreatedBy"].id,name:n["System.CreatedBy"].uniqueName??null,username:n["System.CreatedBy"].displayName??null,url:null},closedDate:n["Microsoft.VSTS.Common.ClosedDate"]?new Date(n["Microsoft.VSTS.Common.ClosedDate"]):null,createdDate:new Date(n["System.CreatedDate"]),updatedDate:new Date(n["System.ChangedDate"]),url:e._links.html.href,assignees:o?[{avatarUrl:o._links?.avatar?.href??null,email:null,id:o.id,name:o.uniqueName??null,username:o.displayName??null,url:null}]:[],description:n["System.Description"]??null,state:{name:u?.title||i,color:null},type:n["System.WorkItemType"],repository:null,project:{namespace:s,name:r,resourceId:null,key:null,id:null},upvoteCount:0,labels:e.fields["System.Tags"]?.split(";").map(l=>({color:null,description:null,id:null,name:l.trim()}))??[]}},me=class extends j{constructor(){super(...arguments);this.cachedUserIds=new Map;this.inflightUserIds=new Map}getCurrentUserId(e,t){let n=JSON.stringify([e,t.token??null,t.isPAT??this.config.isPAT??!1,t.baseUrl??null]),o=this.cachedUserIds.get(n);if(o)return Promise.resolve(o);let i=this.inflightUserIds.get(n);if(i)return i;let a=this.fetchCurrentUserId(e,t,n);return this.inflightUserIds.set(n,a),a}async fetchCurrentUserId(e,t,n){try{let o=await this.getCurrentUserForInstance({namespace:e},t);return this.cachedUserIds.set(n,o.data.id),o.data.id}finally{this.inflightUserIds.delete(n)}}getRepoApiUrl(e,t,n,o){return`${C(this.config,o)}/${encodeURIComponent(e)}/${encodeURIComponent(t)}/_apis/git/repositories/${encodeURIComponent(n)}`}async getCurrentUser(e={},t={}){if(t.isPAT||this.config.isPAT)throw new Error("Azure DevOps does not support PATs for this function.");let n=`${Gt(this.config,t)}/profile/profiles/me`,o=await this.config.request({url:n,headers:w(this.config,t)});return{data:{id:o.body.id,name:o.body.displayName,username:o.body.displayName,email:o.body.emailAddress,avatarUrl:null,url:null}}}async getCurrentUserForInstance(e,t={}){let o=(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/_apis/ConnectionData`,headers:w(this.config,t)})).body.authorizedUser;if(o.providerDisplayName==="Anonymous")throw new Error("Current user not found.");return{data:{id:o.id,name:o.providerDisplayName,username:o.providerDisplayName,email:o.properties.Account.$value,avatarUrl:null,url:null}}}async getUserForCommit(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let o=(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.repo.namespace)}/${encodeURIComponent(e.repo.project)}/_apis/git/repositories/${encodeURIComponent(e.repo.name)}/commits/${e.oid}`,headers:w(this.config,t)})).body.author;return{data:{name:o.name,email:o.email,avatarUrl:o.imageUrl}}}async getOrgsForUser(e,t={}){let n=`${Gt(this.config,t)}/accounts?memberId=${e.userId}&api-version=6.0`;return{data:(await this.config.request({url:n,headers:w(this.config,t)})).body.value.map(i=>({id:i.accountId,name:i.accountName}))}}async getCollectionsForUser(e,t={}){let n=`${C(this.config,t)}/_apis/projectCollections`;return{data:(await this.config.request({url:n,headers:w(this.config,t)})).body.value.map(i=>({id:i.id,name:i.name}))}}async getAzureProjects(e,t={}){let n=new URL(`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/_apis/projects`);n.searchParams.set("$top",$.toString()),e.cursor&&n.searchParams.set("$skip",e.cursor);let o=await this.config.request({url:n.toString(),headers:w(this.config,t)}),i=o.headers["x-ms-continuationtoken"];return{pageInfo:{hasNextPage:!!i,endCursor:i||null},data:o.body.value.map(a=>({id:a.id,name:a.name,namespace:e.namespace}))}}async getAzureProjectScopeDescriptor(e,t={}){let{namespace:n,projectId:o}=e;return{data:{scope:(await this.config.request({url:`${Ot(this.config,t)}/${encodeURIComponent(n)}/_apis/graph/descriptors/${o}?api-version=6.0`,headers:w(this.config,t)})).body.value}}}async getAzureGraphAccountsForAzureProject(e,t={}){let{namespace:n,projectScopeDescriptor:o,cursor:i}=e,a=new URL(`${Ot(this.config,t)}/${encodeURIComponent(n)}/_apis/graph/users`);o&&a.searchParams.set("scopeDescriptor",o),i&&a.searchParams.set("continuationToken",i);let u=await this.config.request({url:a.toString(),headers:w(this.config,t)}),l=u.headers["x-ms-continuationtoken"];return{pageInfo:{endCursor:l||null,hasNextPage:!!l},data:u.body.value.map(p=>({avatarUrl:p._links?.avatar?.href??null,descriptor:p.descriptor??null,email:p.mailAddress??null,name:p.displayName??null,storageKeyURL:p._links?.storageKey?.href??null,username:p.displayName??null}))}}async getAccountFromAzureGraphAccount(e,t={}){let{azureGraphAccount:n}=e;if(!n.storageKeyURL)throw new Error("Expected 'storageKeyURL' to not be null for 'azureGraphAccount'");let o=await this.config.request({url:n.storageKeyURL,headers:w(this.config,t)});return{data:{avatarUrl:n.avatarUrl,email:n.email,id:o.body.value,name:n.name,username:n.username,url:null}}}async getAccountsFromAzureGraphAccounts(e,t={}){let n=[];for(let o of e.azureGraphAccounts){let i=await this.getAccountFromAzureGraphAccount({azureGraphAccount:o},t);n.push(i.data)}return{data:n}}async getRepo(e,t={}){if(!e.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/git/repositories/${encodeURIComponent(e.name)}`,headers:w(this.config,t)});return{data:Nr(e.namespace,n.body)}}async getRepos(e,t={}){let n=[],o=[];return await Promise.all(e.map(async i=>{try{let a=await this.getRepo(i,t);n.push(a.data)}catch(a){o.push({input:i,error:a})}})),{data:n,errors:o}}async getReposForAzureProject(e,t={}){if(!e.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');return{data:(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/git/repositories`,headers:w(this.config,t)})).body.value.map(o=>Nr(e.namespace,o))}}async getRefs(e,t,n={}){if(!t.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let o=new URL(`${C(this.config,n)}/${encodeURIComponent(t.repo.namespace)}/${encodeURIComponent(t.repo.project)}/_apis/git/repositories/${encodeURIComponent(t.repo.name)}/refs`);o.searchParams.set("filter",e),o.searchParams.set("$top",$.toString()),t.cursor&&o.searchParams.set("continuationToken",t.cursor);let i=await this.config.request({url:o.toString(),headers:w(this.config,n)}),a=i.headers["x-ms-continuationtoken"];return{pageInfo:{hasNextPage:!!a,endCursor:a||null},data:i.body.value.map(u=>({name:Oe(u.name),commit:{oid:u.objectId,authoredDate:null,committedDate:null}}))}}async getBranches(e,t={}){return this.getRefs("heads",e,t)}async getTags(e,t={}){return this.getRefs("tags",e,t)}async getPullRequestsForRepoBase(e,t={},n=100){let{page:o,repo:i,assigneeLogins:a,authorLogin:u}=e||{},l=o||1;if(!i.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let p="searchCriteria.status=1";return a&&a.length&&(p+=`&searchCriteria.reviewerId=${a[0]}`),u&&(p+=`&searchCriteria.creatorId=${u}`),await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(i.namespace)}/${encodeURIComponent(i.project||"")}/_apis/git/repositories/${encodeURIComponent(i.name)}/pullRequests?${p}&%24top=${n}&%24skip=${(l-1)*n}`,headers:w(this.config,t)})}async getPullRequestsForRepo(e,t={}){let o=e.page||1,i=await this.getPullRequestsForRepoBase(e,t,100);return{pageInfo:{hasNextPage:i.body.value.length===100,nextPage:o+1},data:i.body.value.map(a=>Ee(e.repo.namespace,a))}}async getPullRequestsForRepos(e,t={}){if(!e.repos.every(i=>i.project))throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{repos:n}=e||{},o=[];return await Promise.all(n.map(async i=>{try{(await this.getPullRequestsForRepoBase({repo:i,...e},t)).body.value.forEach(u=>{o.push(Ee(i.namespace,u))})}catch(a){if(a.statusCode!==404&&a.statusCode!==401)throw a}})),{data:o}}async getPullRequestsForProjectBase(e,t={},n=100){let{namespace:o,project:i,page:a,assigneeLogins:u,authorLogin:l,repo:p}=e;if(p?.project&&p.project!==i)throw new Error("Could not fetch pull requests, project mismatch");let c=a||1,d=new URL(`${C(this.config,t)}/${encodeURIComponent(o)}/${encodeURIComponent(i)}/_apis/git/pullRequests`);return d.searchParams.set("searchCriteria.status","1"),d.searchParams.set("$top",n.toString()),d.searchParams.set("$skip",((c-1)*n).toString()),p?.id&&p?.project===i&&d.searchParams.set("searchCriteria.repositoryId",p.id),u&&u.length&&d.searchParams.set("searchCriteria.reviewerId",u[0]),l&&d.searchParams.set("searchCriteria.creatorId",l),await this.config.request({url:d.toString(),headers:w(this.config,t)})}async getPullRequestsForProject(e,t={}){let o=e.page||1,i=await this.getPullRequestsForProjectBase(e,t,100);return{pageInfo:{hasNextPage:i?.body.value.length===100,nextPage:o+1},data:i?.body.value.map(a=>Ee(e.namespace,a))||[]}}async getPullRequestsForProjects(e,t={}){let{projects:n}=e||{},o=[];return await Promise.all(n.map(async i=>{try{(!e.repo||e.repo.project&&e.repo.project===i.project)&&(await this.getPullRequestsForProjectBase({...i,...e},t))?.body.value.forEach(u=>{o.push(Ee(i.namespace,u))})}catch(a){if(a.statusCode!==404&&a.statusCode!==401)throw a}})),{data:o}}async getAzurePullRequestLastMergeStatus(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{repo:{namespace:n,project:o,name:i},pullRequestId:a}=e,u=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(n)}/${encodeURIComponent(o||"")}/_apis/git/repositories/${i}/pullrequests/${a}?includeCommits=true?api-version=6.0`,headers:{...w(this.config,t)}});if(!u.body.mergeStatus)throw new Error("Could not fetch pull request");return{data:u.body.mergeStatus}}async updatePullRequest(e,t,n){return await this.config.request({method:"PATCH",url:`${C(this.config,n)}/${encodeURIComponent(e.repository.owner.login)}/${encodeURIComponent(e.repository.project)}/_apis/git/repositories/${e.repository.name}/pullrequests/${e.id}?api-version=6.0`,body:t,headers:{...w(this.config,n),"Content-Type":"application/json"}})}async closePullRequest(e,t={}){let{pullRequest:n}=e,o={status:"abandoned"};if(!(await this.updatePullRequest(n,JSON.stringify(o),t)).body.status)throw new Error("Could not close pull request")}async mergePullRequest(e,t={}){let{pullRequest:n,mergeStrategy:o}=e,i;switch(o){case"MERGE_COMMIT":{i="noFastForward";break}case"REBASE":{i="rebase";break}case"REBASE_THEN_MERGE_COMMIT":{i="rebaseMerge";break}case"SQUASH":{i="squash";break}}let a={completionOptions:{mergeStrategy:i},lastMergeSourceCommit:{commitId:n.headRef?.oid},status:"completed"};if(!(await this.updatePullRequest(n,JSON.stringify(a),t)).body.status)throw new Error("Could not merge pull request")}async addPullRequestLabel(e,t={}){let{pullRequest:n,label:o}=e;if(!n.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let i={name:o.name};if(!(await this.config.request({method:"POST",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/labels?api-version=6.0`,body:JSON.stringify(i),headers:{...w(this.config,t),"Content-Type":"application/json"}})).body.id)throw new Error("Could not add pull request label")}async removePullRequestLabel(e,t={}){let{pullRequest:n,label:o}=e;if(!n.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');await this.config.request({method:"DELETE",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/labels/${encodeURIComponent(o.name)}?api-version=6.0`,headers:{...w(this.config,t)}})}async setPullRequestLabels(e,t={}){let{pullRequest:n,labels:o}=e;if(!n.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let i=n.labels;if(!i)throw new Error('Azure DevOps requires "labels" for this function.');for(let a of o)i.find(u=>u.id===a.id)||await this.addPullRequestLabel({pullRequest:n,label:a},t);for(let a of i)o.find(u=>a.id===u.id)||await this.removePullRequestLabel({pullRequest:n,label:a},t)}async setPullRequestAsDraft(e,t={}){let{pullRequest:n,isDraft:o}=e,i={isDraft:o};if(!(await this.updatePullRequest(n,JSON.stringify(i),t)).body.status)throw new Error("Could not set the pull request as draft")}async addPullRequestReviewer(e,t={}){let{pullRequest:n,reviewer:o,isRequired:i}=e,a={id:o.id,isRequired:i};if(!(await this.config.request({method:"PUT",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/reviewers/${o.id}?api-version=6.0`,body:JSON.stringify(a),headers:{...w(this.config,t),"Content-Type":"application/json"}})).body.id)throw new Error("Could not add pull request reviewer")}async removePullRequestReviewer(e,t={}){let{pullRequest:n,reviewer:o}=e;await this.config.request({method:"DELETE",url:`${C(this.config,t)}/${encodeURIComponent(n.repository.owner.login)}/${encodeURIComponent(n.repository.project)}/_apis/git/repositories/${n.repository.name}/pullrequests/${n.id}/reviewers/${o.id}?api-version=6.0`,headers:{...w(this.config,t),Accept:"application/json"}})}async setPullRequestReviewers(e,t={}){let{pullRequest:n,reviewers:o}=e;for(let i of o)n.assignees.find(a=>a.id===i.id)||await this.addPullRequestReviewer({pullRequest:n,reviewer:i,isRequired:!0},t);for(let i of n.assignees)o.find(a=>i.id===a.id)||await this.removePullRequestReviewer({pullRequest:n,reviewer:i},t)}async getIssuesForAzureProject(e,t={}){let{page:n,assigneeLogins:o,authorLogin:i,mentionLogin:a,labelNames:u,statusByWorkItemIdByStatusId:l}=e||{},p=n||1,c=200,d=["[Microsoft.VSTS.Common.ClosedDate] = ''","[System.TeamProject] = @project","[Microsoft.VSTS.Common.ResolvedDate] = ''"];i&&d.push(`[System.CreatedBy] = '${i.replace("'","''")}'`),o&&o[0]&&d.push(`[System.AssignedTo] = '${o[0].replace("'","''")}'`),a&&d.push("[System.Id] IN (@recentMentions)"),u&&u.forEach(h=>d.push(`[System.Tags] Contains '${h}'`));let g=`Select [Microsoft.VSTS.Common.ClosedDate], [Microsoft.VSTS.Common.ResolvedDate] From WorkItems Where ${d.join(" AND ")} order by [System.CreatedDate] desc`,m=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/wit/wiql?api-version=6.0`,body:JSON.stringify({query:g}),method:"POST",headers:{...w(this.config,t),"Content-Type":"application/json"}}),I=m.body.workItems.slice((p-1)*c,c*p).map(h=>h.id);if(I.length==0)return{pageInfo:{hasNextPage:!1,nextPage:null},data:[]};let y=await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(e.namespace)}/${encodeURIComponent(e.project)}/_apis/wit/workitemsbatch?api-version=6.0`,body:JSON.stringify({ids:I,$expand:"Links"}),method:"POST",headers:{...w(this.config,t),"Content-Type":"application/json"}});return{pageInfo:{hasNextPage:m.body.workItems.length>c*p,nextPage:p+1},data:y.body.value.map(h=>rn(e.namespace,e.project,h,l||{}))}}async getPermissionsForRepos(e,t={}){let{namespace:n,repos:o}=e,i={4:["canPush","canCreateWebhook"],1024:["isAdmin"],2048:["isAdmin"],4096:["isAdmin"],8192:["isAdmin"]},a=c=>{let d="2e9eb7ed-3c0a-47d4-87c1-0ffdd275fd87",g=`repoV2/${c.projectId}/${c.id}`;return Object.keys(i).map(m=>({securityNamespaceId:d,token:g,permissions:m}))},u={alwaysAllowAdministrators:!1,evaluations:o.flatMap(a)};return{data:(await this.config.request({method:"POST",url:`${C(this.config,t)}/${encodeURIComponent(n)}/_apis/security/permissionevaluationbatch?api-version=7.0`,body:JSON.stringify(u),headers:{...w(this.config,t),"Content-Type":"application/json"}})).body.evaluations.reduce((c,d)=>{let[,g,m]=d.token.split("/"),I=`${g}/${m}`,y=i[d.permissions];for(let h of y)c[I]===void 0&&(c[I]={canCreateWebhook:!0,canPush:!0,isAdmin:!0}),d.value===!1&&(c[I][h]=!1);return c},{})}}async decorateReposWithPermissions(e,t={}){let{namespace:n,repos:o}=e,i=await this.getPermissionsForRepos({namespace:n,repos:o},t);return{data:o.map(a=>({...a,permissions:i.data[`${a.projectId}/${a.id}`]}))}}async updateIssue(e,t,n={}){return await this.config.request({method:"PATCH",url:`${C(this.config,n)}/${encodeURIComponent(e.project.namespace)}/${encodeURIComponent(e.project.name)}/_apis/wit/workitems/${e.id}?api-version=6.0`,body:JSON.stringify(t),headers:{...w(this.config,n),"Content-Type":"application/json-patch+json"}})}async setIssueStatus(e,t={}){let{issue:n,status:o}=e,i=[{op:"add",path:"/fields/System.State",value:o.name}];if(!(await this.updateIssue(n,i,t)).body.fields?.["System.State"])throw new Error("Could not set issue status")}async setIssueAssignee(e,t={}){let{issue:n,assignee:o}=e,i=[{op:"add",path:"/fields/System.AssignedTo",value:o?.name??""}];if(!(await this.updateIssue(n,i,t)).body.fields?.["System.State"])throw new Error("Could not set issue assignee")}async setIssueLabels(e,t={}){let{issue:n,labels:o}=e,a=[{op:"replace",path:"/fields/System.Tags",value:o.map(l=>l.name).join(";")}];if(!(await this.updateIssue(n,a,t)).body.fields?.["System.Tags"])throw new Error("Could not set issue tags")}async getIssueTypesForAzureProject(e,t={}){if(!e.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{namespace:n,project:o}=e;return{data:(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(n)}/${encodeURIComponent(o||"")}/_apis/wit/workitemtypes?api-version=6.0`,headers:{...w(this.config,t)}})).body.value}}async getLabelsForProject(e,t={}){let{namespace:n,project:o}=e;return{data:(await this.config.request({url:`${C(this.config,t)}/${encodeURIComponent(n)}/${encodeURIComponent(o||"")}/_apis/wit/tags?api-version=6.0`,headers:{...w(this.config,t)}})).body.value.map(a=>({color:null,description:null,id:a.id,name:a.name,url:a.url}))}}async getPullRequestForRepo(e,t={}){let{repo:n,number:o}=e;if(!n.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let i=await this.config.request({url:`${this.getRepoApiUrl(n.namespace,n.project,n.name,t)}/pullrequests/${o}?api-version=7.1`,headers:w(this.config,t)});return{data:Ee(n.namespace,i.body)}}async getPullRequestDescription(e,t={}){let{repo:n,number:o}=e;if(!n.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');try{return{data:{description:(await this.config.request({url:`${this.getRepoApiUrl(n.namespace,n.project,n.name,t)}/pullrequests/${o}?api-version=7.1`,headers:w(this.config,t)})).body?.description??""}}}catch{return{data:{description:null}}}}async setPullRequestDescription(e,t={}){let{repo:n,number:o,description:i}=e;if(!n.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');return{data:{description:(await this.config.request({method:"PATCH",url:`${this.getRepoApiUrl(n.namespace,n.project,n.name,t)}/pullrequests/${o}?api-version=7.1`,headers:{...w(this.config,t),"Content-Type":"application/json"},body:JSON.stringify({description:i})})).body?.description??i}}}async getMergeBase(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=await this.config.request({url:`${this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t)}/commits/${encodeURIComponent(e.base)}/mergebases?otherCommitId=${encodeURIComponent(e.head)}&api-version=7.1`,headers:w(this.config,t)});if(!n.body.value?.length)throw new Error("No merge base found between the specified commits.");return{data:n.body.value[0].commitId}}async getFileContents(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=await this.config.request({url:`${this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t)}/items?path=${encodeURIComponent(e.path)}&versionDescriptor[version]=${encodeURIComponent(e.ref)}&versionDescriptor[versionType]=commit&api-version=7.1`,headers:{...w(this.config,t),Accept:"application/octet-stream"}});return{data:new Blob([n.body])}}async getPullRequestDiff(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t),o=w(this.config,t),i={...o,Accept:"application/octet-stream"},[a,u]=await Promise.all([this.config.request({url:`${n}/pullrequests/${e.pullRequestId}?api-version=7.1`,headers:o}),this.config.request({url:`${n}/pullrequests/${e.pullRequestId}/iterations?api-version=7.1`,headers:o})]),l=a.body.lastMergeTargetCommit.commitId,p=a.body.lastMergeSourceCommit.commitId,c=u.body.value;if(c.length===0)return"";let d=c[c.length-1],g=1e3,m=[],I=0;for(;;){let E=(await this.config.request({url:`${n}/pullrequests/${e.pullRequestId}/iterations/${d.id}/changes?api-version=7.1&$top=${g}&$skip=${I}`,headers:o})).body.changeEntries??[];if(E.length===0||(m.push(...E),E.length<g))break;I+=E.length}if(m.length===0)return"";let y=5,h=[],v=new TextDecoder,D=P=>P instanceof ArrayBuffer?v.decode(P):typeof P=="string"?P:"",x=async(P,E)=>{try{let oe=await this.config.request({url:`${n}/items?path=${encodeURIComponent(P)}&versionDescriptor[version]=${encodeURIComponent(E)}&versionDescriptor[versionType]=commit&includeContent=true&api-version=7.1`,headers:i});return D(oe.body)}catch{return""}},S=P=>{if(typeof P=="number")return{add:(P&1)!==0,rename:(P&8)!==0,delete:(P&16)!==0};let E=P.toLowerCase().split(",").map(oe=>oe.trim());return{add:E.includes("add"),rename:E.includes("rename"),delete:E.includes("delete")}};for(let P=0;P<m.length;P+=y){let E=m.slice(P,P+y),oe=await Promise.all(E.map(async pe=>{let{add:de,rename:Dt,delete:ie}=S(pe.changeType),qe=pe.originalPath??pe.item.originalPath,U=pe.item.path,Ue=ie?U??qe??"":U??"",Ar=Dt||ie?qe??Ue:Ue,[xs,_s]=await Promise.all([de?Promise.resolve(""):x(Ar,l),ie?Promise.resolve(""):x(Ue,p)]),Ns=de?"/dev/null":`a${Ar}`,js=ie?"/dev/null":`b${Ue}`;return(0,jr.createTwoFilesPatch)(Ns,js,xs,_s)}));h.push(...oe)}return h.join(`
|
|
2
|
+
`)}getPullRequestWriteHeaders(e){return{...w(this.config,e),"Content-Type":"application/json"}}setReviewerVote(e,t,n,o,i){return this.config.request({method:"PUT",url:`${e}/pullRequests/${t}/reviewers/${encodeURIComponent(n)}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(i),body:JSON.stringify({vote:o})})}postPullRequestThread(e,t,n,o){return this.config.request({method:"POST",url:`${e}/pullRequests/${t}/threads?api-version=7.1`,headers:this.getPullRequestWriteHeaders(o),body:JSON.stringify({comments:[{parentCommentId:0,content:n,commentType:1}],status:1})})}async getCommentsForPullRequest(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.repo.namespace,e.repo.project,e.repo.name,t),o=w(this.config,t),i=await this.config.request({url:`${n}/pullRequests/${e.pullRequestNumber}/threads?api-version=7.1`,headers:o}),a=[];for(let u of i.body.value)if(!(u.isDeleted||u.threadContext))for(let l of u.comments)l.commentType==="system"||l.isDeleted||a.push({id:kt(e.repo.namespace,e.repo.project,e.repo.name,e.pullRequestNumber,u.id,l.id),author:l.author?le(l.author):null,body:l.content||"",createdAt:l.publishedDate?new Date(l.publishedDate):null,url:""});return{data:a,pageInfo:{hasNextPage:!1,endCursor:null}}}async addCommentToPullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,t);await this.postPullRequestThread(n,e.pullRequest.id,e.comment,t)}async addInlineCommentToPullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,t),o=this.getPullRequestWriteHeaders(t);if(e.threadId){let p=xt(e.threadId),c=e.pullRequest.repository.owner.login,d=e.pullRequest.repository.project,g=e.pullRequest.repository.name,m=String(e.pullRequest.id);if(p.namespace!==c||p.project!==d||p.repoName!==g||p.prId!==m)throw new Error(`Azure thread ID context mismatch: threadId targets ${p.namespace}/${p.project}/${p.repoName} pull request ${p.prId}, but input.pullRequest targets ${c}/${d}/${g} pull request ${m}.`);let y=(await this.config.request({url:`${n}/pullRequests/${e.pullRequest.id}/threads/${p.threadId}?api-version=7.1`,headers:w(this.config,t)})).body.comments?.find(v=>v.parentCommentId===0);if(!y)throw new Error(`Could not determine root comment for Azure DevOps thread ${p.threadId}.`);let h=await this.config.request({method:"POST",url:`${n}/pullRequests/${e.pullRequest.id}/threads/${p.threadId}/comments?api-version=7.1`,headers:o,body:JSON.stringify({content:e.comment,parentCommentId:y.id,commentType:1})});return kt(c,d,g,Number(m),Number(p.threadId),h.body.id)}let i=e.path.startsWith("/")?e.path:`/${e.path}`,a={line:e.line,offset:1},u={filePath:i};e.side==="LEFT"?(u.leftFileStart=a,u.leftFileEnd=a):(u.rightFileStart=a,u.rightFileEnd=a);let l=await this.config.request({method:"POST",url:`${n}/pullRequests/${e.pullRequest.id}/threads?api-version=7.1`,headers:o,body:JSON.stringify({comments:[{parentCommentId:0,content:e.comment,commentType:1}],status:1,threadContext:u})});return _r(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,Number(e.pullRequest.id),l.body.id)}async editComment(e,t={}){let n=xr(e.commentId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"PATCH",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}/comments/${n.commentId}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(t),body:JSON.stringify({content:e.body})})}async editInlineComment(e,t={}){return this.editComment(e,t)}async deleteComment(e,t={}){let n=xr(e.commentId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"DELETE",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}/comments/${n.commentId}?api-version=7.1`,headers:w(this.config,t)})}async deleteInlineComment(e,t={}){return this.deleteComment(e,t)}async resolveReviewThread(e,t={}){let n=xt(e.threadId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"PATCH",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(t),body:JSON.stringify({status:2})})}async unresolveReviewThread(e,t={}){let n=xt(e.threadId),o=this.getRepoApiUrl(n.namespace,n.project,n.repoName,t);await this.config.request({method:"PATCH",url:`${o}/pullRequests/${n.prId}/threads/${n.threadId}?api-version=7.1`,headers:this.getPullRequestWriteHeaders(t),body:JSON.stringify({status:1})})}async approvePullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=e.pullRequest.repository.owner.login,o=this.getRepoApiUrl(n,e.pullRequest.repository.project,e.pullRequest.repository.name,t),i=await this.getCurrentUserId(n,t);await Promise.all([this.setReviewerVote(o,e.pullRequest.id,i,10,t),e.comment?this.postPullRequestThread(o,e.pullRequest.id,e.comment,t):null])}async requestPullRequestChanges(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=e.pullRequest.repository.owner.login,o=this.getRepoApiUrl(n,e.pullRequest.repository.project,e.pullRequest.repository.name,t),i=await this.getCurrentUserId(n,t);await this.postPullRequestThread(o,e.pullRequest.id,e.comment,t),await this.setReviewerVote(o,e.pullRequest.id,i,-5,t)}async commentOnPullRequest(e,t={}){if(!e.pullRequest.repository.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let n=this.getRepoApiUrl(e.pullRequest.repository.owner.login,e.pullRequest.repository.project,e.pullRequest.repository.name,t);await this.postPullRequestThread(n,e.pullRequest.id,e.comment,t)}async getReviewsForPullRequest(e,t={}){if(!e.repo.project)throw new Error('Azure DevOps requires a "project" (name or ID) for this function.');let{namespace:n,project:o,name:i}=e.repo,{pullRequestId:a}=e,u=this.getRepoApiUrl(n,o,i,t),l=w(this.config,t),[p,c]=await Promise.all([this.config.request({url:`${u}/pullRequests/${a}/reviewers?api-version=7.1`,headers:l}),this.config.request({url:`${u}/pullRequests/${a}/threads?api-version=7.1`,headers:l})]),d=(h,v)=>kt(n,o,i,a,h,v),g=h=>_r(n,o,i,a,h),m=new Map;for(let h of c.body.value){if(h.isDeleted)continue;let v=h.comments.filter(U=>!U.isDeleted&&U.commentType!=="system"),D=v.find(U=>U.parentCommentId===0)??v[0];if(!D)continue;let x=D.author?.id;if(!x)continue;let S=v.filter(U=>U.id!==D.id),P=h.threadContext,E=P?.rightFileStart?{side:"RIGHT",start:P.rightFileStart,end:P.rightFileEnd}:P?.leftFileStart?{side:"LEFT",start:P.leftFileStart,end:P.leftFileEnd}:null,oe=E?.end?.line??E?.start.line??null,pe=E?.start&&E.end&&E.start.line!==E.end.line?E.start.line:null,de=P?.filePath??"",Dt=de.startsWith("/")?de.slice(1):de,ie={id:d(h.id,D.id),author:D.author?le(D.author):null,body:D.content??"",createdAt:D.publishedDate?new Date(D.publishedDate):null,url:"",diffLines:[],filename:Dt,replies:S.map(U=>({id:d(h.id,U.id),author:U.author?le(U.author):null,body:U.content??"",createdAt:U.publishedDate?new Date(U.publishedDate):null,url:""})),isOutdated:!1,isResolved:Zs.has(Ys(h.status)),line:oe,startLine:pe,side:E?.side??null,threadId:g(h.id)},qe=m.get(x);qe?qe.push(ie):m.set(x,[ie])}let I=[],y=new Set;for(let h of p.body.value){if(h.hasDeclined)continue;let v=h.vote??0,D=m.get(h.id);v===0&&!D?.length||(I.push({id:h.id,author:le(h),body:"",createdAt:null,url:"",reviewComments:D??[]}),y.add(h.id))}for(let[h,v]of m){if(y.has(h)||!v.length)continue;let D=v[0].author;D&&I.push({id:h,author:D,body:"",createdAt:null,url:"",reviewComments:v})}return{data:I}}};var L=(s,r={})=>f(r.token||s.token,r.isPAT||s.isPAT);var T="https://api.bitbucket.org/2.0",sn={OPEN:"OPEN",MERGED:"MERGED",DECLINED:"CLOSED"},ke={owner:4,admin:3,contributor:2,member:1},xe=s=>({id:s.uuid,name:s.display_name||s.nickname,username:s.nickname||s.display_name,email:null,avatarUrl:s.links.avatar.href,url:s.links.html.href}),Br=s=>{let r=s.links.clone,e=r?.find(n=>n.name==="ssh"),t=r?.find(n=>n.name==="https");return e&&t?{cloneUrlHTTPS:t.href,cloneUrlSSH:e.href}:null},_t=s=>({id:s.uuid,namespace:s.workspace.slug,name:s.slug,webUrl:s.links.html.href,httpsUrl:s.links.clone.find(r=>r.name==="https")?.href??null,sshUrl:s.links.clone.find(r=>r.name==="ssh")?.href??null,defaultBranch:{name:s.mainbranch.name},permissions:null}),Nt=s=>{let r=s.id,e=s.participants?.map(t=>{let n="REVIEW_REQUESTED";return t.approved?n="APPROVED":t.state==="changes_requested"?n="CHANGES_REQUESTED":t.participated_on!==null&&(n="COMMENTED"),{reviewer:xe(t.user),state:n}})??[];return{id:r.toString(),title:s.title,description:s.description,number:r,state:sn[s.state],isDraft:!1,commentCount:s.comment_count,upvoteCount:null,author:xe(s.author),createdDate:new Date(s.created_on),updatedDate:new Date(s.updated_on),closedDate:null,mergedDate:null,repository:{id:s.destination.repository.uuid,name:s.destination.repository.name,owner:{login:s.destination.repository.full_name.split("/")[0]},remoteInfo:Br(s.destination.repository)},headCommit:{buildStatuses:null},baseRef:{name:s.destination.branch.name,oid:s.destination.commit.hash},headRef:{name:s.source.branch.name,oid:s.source.commit.hash},url:s.links.html.href,assignees:null,reviews:e,reviewDecision:H(e),additions:null,deletions:null,fileCount:null,commitCount:null,headRepository:{id:s.source.repository.uuid,name:s.source.repository.name,owner:{login:s.source.repository.full_name.split("/")[0]},remoteInfo:Br(s.source.repository)},mergeableState:"MERGEABLE",permissions:null}},nn=s=>{switch(s){case"owner":case"admin":return{canCreateWebhook:!0,canPush:!0,isAdmin:!0};case"write":return{canCreateWebhook:!1,canPush:!0,isAdmin:!1};case"read":case"none":return{canCreateWebhook:!1,canPush:!1,isAdmin:!1}}},on=s=>{switch(s){case"owner":case"admin":return{canCreateWebhook:!0,canPush:!0,isAdmin:!0};case"contributor":return{canCreateWebhook:!1,canPush:!0,isAdmin:!1};default:return{canCreateWebhook:!1,canPush:!1,isAdmin:!1}}},ge=class extends F{async refreshToken(r){return{data:(await this.config.request({url:"https://bitbucket.org/site/oauth2/access_token",method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Authorization:`Basic ${r.base64ClientIDColonClientSecret}`},body:`grant_type=refresh_token&refresh_token=${r.refreshToken}`})).body}}async getCurrentUser(r={},e={}){let t=await this.config.request({url:`${T}/user`,headers:L(this.config,e)});return{data:xe(t.body)}}async getUserForCommit(r,e={}){let n=(await this.config.request({url:`${T}/repositories/${r.repo.namespace}/${r.repo.name}/commit/${r.oid}`,headers:L(this.config,e)})).body.author,o=n.raw.match(/([^<]+)<(.+)>/);return{data:{name:o?o[1].trim():null,email:o?o[2]:null,avatarUrl:n.user?.links.avatar.href||null}}}async getRepo(r,e={}){let t=await this.config.request({url:`${T}/repositories/${r.namespace}/${r.name}`,headers:L(this.config,e)});return{data:_t(t.body)}}async getRepos(r,e={}){let t=[],n=[];return await Promise.all(r.map(async o=>{try{let i=await this.getRepo(o,e);t.push(i.data)}catch(i){n.push({input:o,error:i})}})),{data:t,errors:n}}async getReposForWorkspace(r,e={}){let t=new URL(`${T}/repositories/${encodeURIComponent(r.workspace)}`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen",$.toString()),r.minimumRole&&t.searchParams.set("role",r.minimumRole);let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(_t)}}async getAllReposForWorkspace(r,e={}){let t=[],n=1;for(;n!==null;){let o=await this.getReposForWorkspace({workspace:r.workspace,minimumRole:r.minimumRole,page:n},e);t.push(...o.data),n=o.pageInfo.hasNextPage?o.pageInfo.nextPage:null}return t}async getAllReposForWorkspaceWithPermissions(r,e={}){let t=new Map,n=[],o=ke[r.minimumRole||"member"];o<=ke.admin&&n.push("admin"),o<=ke.contributor&&n.push("contributor"),o<=ke.member&&n.push("member");let i=[];for(let a of n){i=await this.getAllReposForWorkspace({workspace:r.workspace,minimumRole:a},e);for(let u of i)t.has(u.id)||t.set(u.id,a)}return{data:i.map(a=>{let u=t.get(a.id)||"member";return{...a,permissions:on(u)}})}}async getReposForCurrentUser(r,e={}){let t=new URL(`${T}/repositories`);t.searchParams.set("role","member"),t.searchParams.set("pagelen",$.toString()),r.cursor&&t.searchParams.set("after",r.cursor);let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next,i=null;return n.body.next&&(i=new URL(n.body.next).searchParams.get("after")),{pageInfo:{hasNextPage:o,endCursor:i},data:n.body.values.map(_t)}}async getBranches(r,e={}){let t=new URL(`${T}/repositories/${r.repo.namespace}/${r.repo.name}/refs/branches`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen",$.toString());let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>{let a=new Date(i.target.date);return{name:i.name,commit:{oid:i.target.hash,authoredDate:a,committedDate:a}}})}}async getTags(r,e={}){let t=new URL(`${T}/repositories/${r.repo.namespace}/${r.repo.name}/refs/tags`);t.searchParams.set("pagelen",$.toString()),r.cursor&&t.searchParams.set("page",r.cursor);let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next,i=null;return n.body.next&&(i=new URL(n.body.next).searchParams.get("page")),{pageInfo:{hasNextPage:o,endCursor:i},data:n.body.values.map(a=>{let u=new Date(a.target.date);return{name:a.name,commit:{oid:a.target.hash,authoredDate:u,committedDate:u}}})}}async getWorkspacesForCurrentUser(r={},e={}){let t=new URL(`${T}/user/workspaces`);t.searchParams.set("page",r?.page?.toString()||"1"),t.searchParams.set("pagelen","50"),r?.administrator!==void 0&&t.searchParams.set("administrator",r.administrator.toString());let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>({id:i.workspace.uuid,slug:i.workspace.slug}))}}async getWorkspacesForUser(r,e={}){let t=new URL(`${T}/user/permissions/workspaces`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","50");let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>({id:i.workspace.uuid,slug:i.workspace.slug,name:i.workspace.name}))}}async getPullRequestsForUserAndWorkspace(r,e={}){let t=new URL(`${T}/workspaces/${r.workspaceSlug}/pullrequests/${r.userId}`);if(t.searchParams.set("fields","+values.participants,+values.destination.repository.links.clone.*,+values.source.repository.links.clone.*"),t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","50"),r.repos&&r.repos.length>0){let i=`state = "open" AND (${r.repos.map(a=>`source.repository.full_name = "${a.namespace}/${a.name}"`).join(" OR ")})`;t.searchParams.set("q",i)}let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(Nt)}}async getPullRequestsForRepoBase(r,e={}){let t=new URL(`${T}/repositories/${encodeURI(r.repo.namespace)}/${encodeURI(r.repo.name)}/pullrequests?state=OPEN`),n=[];r.reviewerId&&n.push(`reviewers.uuid="${r.reviewerId}"`),r.authorLogin&&n.push(`author.uuid="${r.authorLogin}"`);let o='state="OPEN"';return n.length&&(o+=` AND (${n.join(r.useOrFilter?" OR ":" AND ")})`),t.searchParams.set("fields","+values.participants,+values.destination.repository.links.clone.*,+values.source.repository.links.clone.*"),t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","50"),t.searchParams.set("q",o),await this.config.request({url:t.toString(),headers:L(this.config,e)})}async getPullRequestsForRepo(r,e={}){let t=[],n=await this.getPullRequestsForRepoBase(r,e);n.body.values.forEach(i=>{t.push(Nt(i))});let o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:t}}async getPullRequestsForRepos(r,e={}){let t=[];return await Promise.all(r.repos.map(async n=>{try{(await this.getPullRequestsForRepoBase({repo:n,...r},e)).body.values.forEach(i=>{t.push(Nt(i))})}catch(o){if(o.statusCode!==404&&o.statusCode!==401)throw o}})),{data:t}}async getAccountsForWorkspace(r,e={}){let t=new URL(`${T}/workspaces/${encodeURI(r.workspace)}/members`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","100");let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.map(i=>xe(i.user))}}async getReposPermissionsForCurrentUser(r,e={}){let t=new URL(`${T}/user/permissions/repositories`);t.searchParams.set("page",r.page?.toString()||"1"),t.searchParams.set("pagelen","100");let n=await this.config.request({url:t.toString(),headers:L(this.config,e)}),o=!!n.body.next;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.page+1:null},data:n.body.values.reduce((i,a)=>({...i,[a.repository.uuid]:nn(a.permission)}),{})}}async decorateReposWithPermissions(r,e={}){let t={},n=1;do{let o=await this.getReposPermissionsForCurrentUser({page:n},e);t={...o.data,...t},n=o.pageInfo.hasNextPage?o.pageInfo.nextPage:null}while(n!==null);return{data:r.repos.map(o=>({...o,permissions:t[o.id]??{canCreateWebhook:!1,canPush:!1,isAdmin:!1}}))}}async closePullRequest(r,e={}){let{pullRequest:t}=r;if(!(await this.config.request({method:"POST",url:`${T}/repositories/${t.repository.owner.login}/${t.repository.name}/pullrequests/${t.id}/decline`,headers:L(this.config,e)})).body.title)throw new Error("Could not close pull request")}async mergePullRequest(r,e={}){let{pullRequest:t,mergeStrategy:n}=r,o;switch(n){case"MERGE_COMMIT":{o="merge_commit";break}case"FAST_FORWARD":{o="fast_forward";break}case"SQUASH":{o="squash";break}}let i={merge_strategy:o,type:"pullrequest"};if(!(await this.config.request({method:"POST",url:`${T}/repositories/${t.repository.owner.login}/${t.repository.name}/pullrequests/${t.id}/merge`,body:JSON.stringify(i),headers:{...L(this.config,e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not merge pull request")}async setPullRequestReviewers(r,e={}){let{pullRequest:t,reviewers:n}=r,o={reviewers:n.map(a=>{if(a.username)throw new Error('Bitbucket reviewer requires "username" for this function.');return{username:a.username}})};if(!(await this.config.request({method:"PUT",url:`${T}/repositories/${t.repository.owner.login}/${t.repository.name}/pullrequests/${t.id}`,body:JSON.stringify(o),headers:{...L(this.config,e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not set pull request reviewers")}};var _e={};z(_e,{normalizePermissions:()=>jt,restApiPullRequestToCommonPullRequest:()=>an});var an=s=>Se(s),jt=s=>s?s.find(r=>r.permission==="USER_ADMIN"||r.permission==="PROJECT_ADMIN"||r.permission==="ADMIN"||r.permission==="SYS_ADMIN"||r.permission==="REPO_ADMIN")?{canCreateWebhook:!0,canPush:!0,isAdmin:!0}:s.find(r=>r.permission==="REPO_WRITE"||r.permission==="REPO_CREATE"||r.permission==="PROJECT_CREATE"||r.permission==="PROJECT_WRITE")?{canCreateWebhook:!1,canPush:!0,isAdmin:!1}:{canCreateWebhook:!1,canPush:!1,isAdmin:!1}:{canCreateWebhook:!1,canPush:!1,isAdmin:!1};var Ce=s=>{let r=s.links.self[0].href;return{name:s.displayName,email:s.emailAddress,avatarUrl:s.avatarUrl??(r&&`${r}/avatar.png`),id:s.id.toString(),username:s.name,url:r}},Se=s=>{let r={OPEN:"OPEN",MERGED:"MERGED",DECLINED:"CLOSED"},e={UNAPPROVED:"REVIEW_REQUESTED",NEEDS_WORK:"CHANGES_REQUESTED",APPROVED:"APPROVED"},t=s.reviewers.map(u=>({reviewer:Ce(u.user),state:e[u.status]})),n=s.toRef.repository.links.clone.find(u=>u.name==="ssh")?.href??null,o=s.toRef.repository.links.clone.find(u=>u.name==="https")?.href??null;o||(o=s.toRef.repository.links.clone.find(u=>u.name==="http")?.href??null);let i=s.fromRef.repository.links.clone.find(u=>u.name==="ssh")?.href??null,a=s.fromRef.repository.links.clone.find(u=>u.name==="https")?.href??null;return a||(a=s.fromRef.repository.links.clone.find(u=>u.name==="http")?.href??null),{id:s.id.toString(),number:s.id,title:s.title,description:s.description,url:s.links.self[0].href,state:r[s.state],isDraft:!1,createdDate:new Date(s.createdDate),updatedDate:new Date(s.updatedDate),closedDate:s.closedDate?new Date(s.closedDate):null,mergedDate:s.state=="MERGED"&&s.closedDate?new Date(s.closedDate):null,baseRef:{name:s.toRef.displayId,oid:s.toRef.latestCommit},headRef:{name:s.fromRef.displayId,oid:s.fromRef.latestCommit},commentCount:s.properties.commentCount,upvoteCount:null,commitCount:null,fileCount:null,additions:null,deletions:null,author:Ce(s.author.user),assignees:null,reviews:t,reviewDecision:H(t),repository:{id:s.toRef.repository.id.toString(),name:s.toRef.repository.name,owner:{login:s.toRef.repository.project.key},remoteInfo:o&&n?{cloneUrlHTTPS:o,cloneUrlSSH:n}:null},headRepository:{id:s.fromRef.repository.id.toString(),name:s.fromRef.repository.name,owner:{login:s.fromRef.repository.project.key},remoteInfo:a&&i?{cloneUrlHTTPS:a,cloneUrlSSH:i}:null},headCommit:null,mergeableState:"MERGEABLE",permissions:null,version:s.version}},Qr=s=>({id:s.id.toString(),namespace:s.project.key,name:s.slug,webUrl:s.links.self[0]?.href??null,httpsUrl:s.links.clone.find(r=>r.name==="https"||r.name==="http")?.href??null,sshUrl:s.links.clone.find(r=>r.name==="ssh")?.href??null,defaultBranch:null,permissions:null}),he=class extends j{getBaseUrl(r){let e=r.baseUrl||this.config.baseUrl;if(!e)throw new Error('Bitbucket Server requires "baseUrl"');return e}getRequestHeaders(r){return f(r.token||this.config.token)}async getCurrentUser(r={},e={}){let t=await this.config.request({url:`${this.getBaseUrl(e)}/users?limit=2`,headers:this.getRequestHeaders(e)}),{headers:{"x-auserid":n,"x-ausername":o}}=t,i=n?parseInt(n,10):null,a=decodeURIComponent(o),l=(await this.config.request({url:`${this.getBaseUrl(e)}/users?filter=${o}&avatarSize=64`,headers:this.getRequestHeaders(e)})).body.values.find(({emailAddress:p,id:c,name:d,slug:g})=>i?i===c:a===d||a===p||a===g);if(!l)throw new Error("Could not find current Bitbucket Server user");return{data:Ce(l)}}async getUserForCommit(r,e){let{repo:t,oid:n}=r,o=await this.config.request({url:`${this.getBaseUrl(e)}/projects/${t.namespace}/repos/${t.name}/commits/${n}`,headers:this.getRequestHeaders(e)});if(!o.body.author)throw new Error("Could not find user for commit");return{data:Ce(o.body.author)}}async getRepo(r,e={}){let t=await this.config.request({url:`${this.getBaseUrl(e)}/projects/${r.namespace}/repos/${r.name}`,headers:this.getRequestHeaders(e)});return{data:Qr(t.body)}}async getRepos(r,e={}){let t=[],n=[];return await Promise.all(r.map(async o=>{try{let i=await this.getRepo(o,e);t.push(i.data)}catch(i){n.push({input:o,error:i})}})),{data:t,errors:n}}async getReposForCurrentUser(r,e={}){let t=r.page??0,n=await this.config.request({url:`${this.getBaseUrl(e)}/repos?start=${t}`,headers:this.getRequestHeaders(e)});return{pageInfo:{hasNextPage:!n.body.isLastPage,nextPage:n.body.nextPageStart},data:n.body.values.map(Qr)}}async getRepoPermissionsForUsername(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/projects/${r.repo.namespace}/repos/${r.repo.name}/permissions/search?filterText=${r.username}`);try{let n=await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)});return{data:jt(n.body.values)}}catch(n){if(n.response?.status===401)return{data:{canCreateWebhook:!1,canPush:!1,isAdmin:!1}};throw n}}async decorateReposWithPermissions(r,e={}){return await Promise.all(r.repos.map(async n=>{let o=await this.getRepoPermissionsForUsername({repo:n,username:r.username},e);return{...n,permissions:o.data}}))}async getPullRequestsForRepoBase(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/projects/${encodeURI(r.repo.namespace)}/repos/${encodeURI(r.repo.name)}/pull-requests?state=OPEN`);return t.searchParams.set("start",r.page?.toString()||"0"),t.searchParams.set("limit","50"),await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)})}async getPullRequestsForRepo(r,e={}){let t=[],n=await this.getPullRequestsForRepoBase(r,e);n.body.values.forEach(i=>{if(r.authorLogin&&i.author.user.name!==r.authorLogin)return null;t.push(Se(i))});let o=n.body.values.length!==0;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.start+n.body.values.length:null},data:t}}async getPullRequestsForRepos(r,e={}){let t=[];return await Promise.all(r.repos.map(async n=>{try{(await this.getPullRequestsForRepoBase({repo:n,...r},e)).body.values.forEach(i=>{if(r.authorLogin&&i.author.user.name!==r.authorLogin)return null;t.push(Se(i))})}catch(o){if(o.statusCode!==404&&o.statusCode!==401)throw o}})),{data:t}}async getPullRequestsForCurrentUser(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/dashboard/pull-requests`);t.searchParams.set("state","OPEN"),t.searchParams.set("start",r.page?.toString()||"0"),t.searchParams.set("limit","50");let n=await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)}),o=n.body.values.length!==0;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.start+n.body.values.length:null},data:n.body.values.map(Se)}}async closePullRequest(r,e={}){let{pullRequest:t}=r;if(t.version===void 0)throw new Error('Bitbucket Server requires "version" for this function.');if(!(await this.config.request({method:"POST",url:`${this.getBaseUrl(e)}/projects/${t.repository.owner.login}/repos/${t.repository.name}/pull-requests/${t.id}/decline`,body:JSON.stringify({version:t.version}),headers:{...this.getRequestHeaders(e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not close pull request")}async mergePullRequest(r,e={}){let{pullRequest:t,mergeStrategyId:n}=r;if(r.mergeStrategy)throw new Error('Bitbucket Server uses "mergeStrategyId" instead of "mergeStrategy".');if(t.version===void 0)throw new Error('Bitbucket Server requires "version" for this function.');if(!(await this.config.request({method:"POST",url:`${this.getBaseUrl(e)}/projects/${t.repository.owner.login}/repos/${t.repository.name}/pull-requests/${t.id}/merge`,body:JSON.stringify({strategyId:n,version:t.version}),headers:{...this.getRequestHeaders(e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not merge pull request")}async getMergeStrategies(r={}){let e=await this.config.request({url:`${this.getBaseUrl(r)}/admin/pull-requests/git`,headers:{...this.getRequestHeaders(r),"Content-Type":"application/json"}});return{data:{defaultStrategy:e.body.mergeConfig.defaultStrategy,strategies:e.body.mergeConfig.strategies}}}async setPullRequestReviewers(r,e={}){let{pullRequest:t,reviewers:n}=r;if(t.version===void 0)throw new Error('Bitbucket Server requires "version" for this function.');let o={reviewers:n.map(a=>{if(a.username)throw new Error('Bitbucket Server reviewer requires "username" for this function.');return{user:{name:a.username}}}),version:t.version};if(!(await this.config.request({method:"PUT",url:`${this.getBaseUrl(e)}/projects/${t.repository.owner.login}/repos/${t.repository.name}/pull-requests/${t.id}`,body:JSON.stringify(o),headers:{...this.getRequestHeaders(e),"Content-Type":"application/json"}})).body.title)throw new Error("Could not set pull request reviewers")}async getAccountsForProject(r,e={}){let t=new URL(`${this.getBaseUrl(e)}/projects/${encodeURI(r.project)}/permissions/users`);t.searchParams.set("start",r.page?.toString()||"0"),t.searchParams.set("limit","50");let n=await this.config.request({url:t.toString(),headers:this.getRequestHeaders(e)}),o=n.body.values.length!==0;return{pageInfo:{hasNextPage:o,nextPage:o?n.body.start+n.body.values.length:null},data:n.body.values.map(i=>Ce(i.user))}}};var ss=require("js-base64");var Ne=(e=>(e.Open="OPEN",e.Closed="CLOSED",e))(Ne||{});var R=class extends Error{constructor(e,t){let n=t?.map(i=>`'${i.message}'`).join(", "),o=n?`${e}: ${n}`:e;super(o);this.graphQLErrors=t??[]}};var un={AS_CODE_OWNER:[3,0,0],CHECK_RUN:[3,0,0],LATEST_REVIEWS:[3,0,0],VIEWER_CAN_MERGE_AS_ADMIN:[3,5,0],ISSUE_FULL_DATABASE_ID:[3,12,0],PR_FULL_DATABASE_ID:[3,13,0],PR_REVIEW_FULL_DATABASE_ID:[3,13,0],PR_REVIEW_COMMENT_FULL_DATABASE_ID:[3,13,0]},Fr=15,Mr=100,De={__typename:"User",id:"U_kgDNJ5k",databaseId:10137,name:"Deleted user",login:"ghost",email:"",avatarUrl:"https://avatars.githubusercontent.com/u/10137?v=4",url:"https://github.com/ghost"},O=s=>!!s,J=(s,r)=>{let e=un[r];for(let t=0;t<3;t++){if(s[t]>e[t])return!0;if(s[t]<e[t])return!1}return!0},Be="https://api.github.com",ln=`${Be}/graphql`,Qe=`
|
|
3
3
|
description
|
|
4
4
|
dueOn
|
|
5
5
|
id
|
|
@@ -21,7 +21,7 @@ color
|
|
|
21
21
|
description
|
|
22
22
|
id
|
|
23
23
|
name
|
|
24
|
-
`,zr=s=>{if(s.endsWith("/api/graphql"))throw new Error("The graphql endpoint is being used as the baseUrl. This package uses both GraphQL and REST APIs, and the REST version cannot be assumed. Use the REST endpoint as the baseUrl instead.")},dn=(s,r)=>{let e=r.baseUrl||s.baseUrl;return e?(e=e.replace(/\/$/,""),zr(e),je.test(e)&&(e=e.replace(je,"")),`${e}/api/graphql`):ln},
|
|
24
|
+
`,zr=s=>{if(s.endsWith("/api/graphql"))throw new Error("The graphql endpoint is being used as the baseUrl. This package uses both GraphQL and REST APIs, and the REST version cannot be assumed. Use the REST endpoint as the baseUrl instead.")},dn=(s,r)=>{let e=r.baseUrl||s.baseUrl;return e?(e=e.replace(/\/$/,""),zr(e),je.test(e)&&(e=e.replace(je,"")),`${e}/api/graphql`):ln},V=(s,r)=>{let e=r.baseUrl||s.baseUrl;return e?(e=e.replace(/\/$/,""),zr(e),je.test(e)&&(e=e.replace(je,"")),`${e}/api/v3`):Be},b=(s,r,e)=>{let t=f(e.token||s.token);return t["X-Github-Next-Global-ID"]="1",t["Content-Type"]="application/json",t.Accept="application/vnd.github.merge-info-preview+json",s.request({url:dn(s,e),method:"POST",headers:t,body:JSON.stringify(r)})},cn={user:!0,"user:email":!0,"read:user":!0},Z=s=>s.some(r=>cn[r]),B=(s=!1,r=!1,e)=>`
|
|
25
25
|
__typename
|
|
26
26
|
${se(e,["graphQLId"],"id")}
|
|
27
27
|
${se(e,["id"],"databaseId")}
|
|
@@ -368,7 +368,7 @@ defaultBranchRef {
|
|
|
368
368
|
name
|
|
369
369
|
}
|
|
370
370
|
viewerPermission
|
|
371
|
-
`,yn={APPROVED:"APPROVED",CHANGES_REQUESTED:"CHANGES_REQUESTED",COMMENTED:"COMMENTED",REVIEW_REQUESTED:"REVIEW_REQUESTED"},Pn={MERGEABLE:"MERGEABLE",CONFLICTING:"CONFLICTS",UNKNOWN:"UNKNOWN"},wn={BEHIND:"BEHIND",BLOCKED:"BLOCKED",UNKNOWN:"UNKNOWN_AND_BLOCKED",UNSTABLE:"UNSTABLE",CLEAN:null,DIRTY:null,DRAFT:null,HAS_HOOKS:null},qn={OPEN:"OPEN",CLOSED:"CLOSED"},vn=["ADMIN","MAINTAIN","TRIAGE","WRITE"],Ht=s=>({color:`#${s.color}`,description:s.description,graphQLId:s.id,id:null,name:s.name}),En=s=>({canCreateWebhook:s==="ADMIN",canPush:s==="ADMIN"||s==="MAINTAIN"||s==="WRITE",isAdmin:s==="ADMIN"}),zt=s=>({id:s.databaseId.toString(),graphQLId:s.id,namespace:s.owner.login,name:s.name,webUrl:s.url,httpsUrl:s.url.endsWith(".git")?s.url:`${s.url}.git`,sshUrl:s.sshUrl,defaultBranch:s.defaultBranchRef,permissions:En(s.viewerPermission)}),Sn=s=>({canCreateWebhook:s.admin,canPush:s.admin||s.maintain||s.push,isAdmin:s.admin}),rs=s=>({id:s.id.toString(),graphQLId:s.node_id,namespace:s.owner.login,name:s.name,webUrl:s.html_url,httpsUrl:s.clone_url,sshUrl:s.ssh_url,defaultBranch:{name:s.default_branch},permissions:Sn(s.permissions)}),Cn=s=>({path:s.path,isDirectory:s.type==="tree"}),Dn={OPEN:"OPEN",CLOSED:"CLOSED",MERGED:"MERGED"},$n={id:!0,graphQLId:!0,name:!0,username:!0,email:!0,avatarUrl:!0,url:!0},M=(s,r=$n)=>{let e={};return r.id&&(e.id="databaseId"in s?s.databaseId.toString():s.id),r.graphQLId&&(e.graphQLId=s.id),r.name&&(e.name=s.name??s.login),r.username&&(e.username=s.login),r.email&&(e.email=s.email??null),r.avatarUrl&&(e.avatarUrl=s.avatarUrl),r.url&&(e.url=s.url),e},An=(s,r)=>{let e={IN_PROGRESS:"RUNNING",PENDING:"PENDING",QUEUED:"PENDING",REQUESTED:"PENDING",WAITING:"PENDING"};return s!=="COMPLETED"?e[s]:{ACTION_REQUIRED:"ACTION_REQUIRED",CANCELLED:"CANCELLED",FAILURE:"FAILED",NEUTRAL:null,SKIPPED:"SKIPPED",STALE:"FAILED",STARTUP_FAILURE:"FAILED",SUCCESS:"SUCCESS",TIMED_OUT:"ERROR"}[r]},Ln=s=>({ERROR:"ERROR",EXPECTED:"PENDING",FAILURE:"FAILED",PENDING:"PENDING",SUCCESS:"SUCCESS"})[s],Wt=s=>{let r=null;s.author?r=s.author:r=De;let e=(s.reviewRequests?.nodes||[]).filter(O).filter(i=>!i.asCodeOwner),t=s.headRepository?.url;t&&!t.endsWith(".git")&&(t=`${t}.git`);let n=s.repository?.url;n&&!n.endsWith(".git")&&(n=`${n}.git`);let o=e.filter(i=>i.requestedReviewer&&"__typename"in i.requestedReviewer).map(i=>({reviewer:M(i.requestedReviewer),state:"REVIEW_REQUESTED"})).concat((s.latestReviews?.nodes||[]).filter(O).map(i=>{let a=De;return i.author&&i.author.__typename&&(a=i.author),{reviewer:M(a),state:yn[i.state]}}));return{id:s.fullDatabaseId!==void 0?s.fullDatabaseId:s.databaseId.toString(),graphQLId:s.id,title:s.title,description:s.body,number:s.number,state:Dn[s.state],commentCount:s.comments.totalCount,upvoteCount:s.reactions.totalCount,author:r&&r.__typename?M(r):null,createdDate:new Date(s.createdAt),isDraft:s.isDraft,repository:{id:s.repository.databaseId.toString(),graphQLId:s.repository.id,name:s.repository.name,owner:{login:s.repository.owner.login},remoteInfo:{cloneUrlHTTPS:n,cloneUrlSSH:s.repository.sshUrl}},headRepository:s.headRepository?{id:s.headRepository.databaseId.toString(),graphQLId:s.headRepository.id,name:s.headRepository.name,owner:{login:s.headRepository.owner.login},remoteInfo:{cloneUrlHTTPS:t,cloneUrlSSH:s.headRepository.sshUrl}}:null,headCommit:{buildStatuses:s.commits.nodes?.filter(O)[0]?.commit.statusCheckRollup?.contexts.nodes?.filter(O).map(i=>"context"in i?{completedAt:null,description:i.description,name:i.context,state:Ln(i.state),startedAt:new Date(i.createdAt),stage:null,url:i.targetUrl}:{completedAt:i.completedAt?new Date(i.completedAt):null,description:null,name:i.name,state:An(i.status,i.conclusion),startedAt:i.startedAt?new Date(i.startedAt):null,stage:null,url:i.permalink})??[]},headRef:s.headRef?{name:s.headRef.name,oid:s.headRef.target?.oid??null}:null,baseRef:s.baseRef?{name:s.baseRef.name,oid:s.baseRef.target?.oid??null}:null,url:s.url,updatedDate:new Date(s.updatedAt),closedDate:s.closedAt?new Date(s.closedAt):null,mergedDate:s.mergedAt?new Date(s.mergedAt):null,assignees:s.assignees.nodes?s.assignees.nodes.filter(O).map(i=>M(i)):null,reviews:o,reviewDecision:H(o),additions:s.additions,deletions:s.deletions,fileCount:s.changedFiles,commitCount:s.commits.totalCount,mergeableState:wn[s.mergeStateStatus]??Pn[s.mergeable],milestone:s.milestone?Jt(s.milestone):null,labels:s.labels?.nodes?.filter(O).map(Ht)??[],permissions:{canMerge:vn.includes(s.repository.viewerPermission),canMergeAndBypassProtections:s.viewerCanMergeAsAdmin??!1}}},Un=s=>{let{id:r,comments:e,isOutdated:t,isResolved:n,line:o,startLine:i,diffSide:a,originalLine:u,originalStartLine:l,startDiffSide:p}=s,c=e.nodes?.[0];if(!c)return null;let{author:d,body:g,databaseId:m,fullDatabaseId:I,id:y,path:h,publishedAt:v,url:D}=c,
|
|
371
|
+
`,yn={APPROVED:"APPROVED",CHANGES_REQUESTED:"CHANGES_REQUESTED",COMMENTED:"COMMENTED",REVIEW_REQUESTED:"REVIEW_REQUESTED"},Pn={MERGEABLE:"MERGEABLE",CONFLICTING:"CONFLICTS",UNKNOWN:"UNKNOWN"},wn={BEHIND:"BEHIND",BLOCKED:"BLOCKED",UNKNOWN:"UNKNOWN_AND_BLOCKED",UNSTABLE:"UNSTABLE",CLEAN:null,DIRTY:null,DRAFT:null,HAS_HOOKS:null},qn={OPEN:"OPEN",CLOSED:"CLOSED"},vn=["ADMIN","MAINTAIN","TRIAGE","WRITE"],Ht=s=>({color:`#${s.color}`,description:s.description,graphQLId:s.id,id:null,name:s.name}),En=s=>({canCreateWebhook:s==="ADMIN",canPush:s==="ADMIN"||s==="MAINTAIN"||s==="WRITE",isAdmin:s==="ADMIN"}),zt=s=>({id:s.databaseId.toString(),graphQLId:s.id,namespace:s.owner.login,name:s.name,webUrl:s.url,httpsUrl:s.url.endsWith(".git")?s.url:`${s.url}.git`,sshUrl:s.sshUrl,defaultBranch:s.defaultBranchRef,permissions:En(s.viewerPermission)}),Sn=s=>({canCreateWebhook:s.admin,canPush:s.admin||s.maintain||s.push,isAdmin:s.admin}),rs=s=>({id:s.id.toString(),graphQLId:s.node_id,namespace:s.owner.login,name:s.name,webUrl:s.html_url,httpsUrl:s.clone_url,sshUrl:s.ssh_url,defaultBranch:{name:s.default_branch},permissions:Sn(s.permissions)}),Cn=s=>({path:s.path,isDirectory:s.type==="tree"}),Dn={OPEN:"OPEN",CLOSED:"CLOSED",MERGED:"MERGED"},$n={id:!0,graphQLId:!0,name:!0,username:!0,email:!0,avatarUrl:!0,url:!0},M=(s,r=$n)=>{let e={};return r.id&&(e.id="databaseId"in s?s.databaseId.toString():s.id),r.graphQLId&&(e.graphQLId=s.id),r.name&&(e.name=s.name??s.login),r.username&&(e.username=s.login),r.email&&(e.email=s.email??null),r.avatarUrl&&(e.avatarUrl=s.avatarUrl),r.url&&(e.url=s.url),e},An=(s,r)=>{let e={IN_PROGRESS:"RUNNING",PENDING:"PENDING",QUEUED:"PENDING",REQUESTED:"PENDING",WAITING:"PENDING"};return s!=="COMPLETED"?e[s]:{ACTION_REQUIRED:"ACTION_REQUIRED",CANCELLED:"CANCELLED",FAILURE:"FAILED",NEUTRAL:null,SKIPPED:"SKIPPED",STALE:"FAILED",STARTUP_FAILURE:"FAILED",SUCCESS:"SUCCESS",TIMED_OUT:"ERROR"}[r]},Ln=s=>({ERROR:"ERROR",EXPECTED:"PENDING",FAILURE:"FAILED",PENDING:"PENDING",SUCCESS:"SUCCESS"})[s],Wt=s=>{let r=null;s.author?r=s.author:r=De;let e=(s.reviewRequests?.nodes||[]).filter(O).filter(i=>!i.asCodeOwner),t=s.headRepository?.url;t&&!t.endsWith(".git")&&(t=`${t}.git`);let n=s.repository?.url;n&&!n.endsWith(".git")&&(n=`${n}.git`);let o=e.filter(i=>i.requestedReviewer&&"__typename"in i.requestedReviewer).map(i=>({reviewer:M(i.requestedReviewer),state:"REVIEW_REQUESTED"})).concat((s.latestReviews?.nodes||[]).filter(O).map(i=>{let a=De;return i.author&&i.author.__typename&&(a=i.author),{reviewer:M(a),state:yn[i.state]}}));return{id:s.fullDatabaseId!==void 0?s.fullDatabaseId:s.databaseId.toString(),graphQLId:s.id,title:s.title,description:s.body,number:s.number,state:Dn[s.state],commentCount:s.comments.totalCount,upvoteCount:s.reactions.totalCount,author:r&&r.__typename?M(r):null,createdDate:new Date(s.createdAt),isDraft:s.isDraft,repository:{id:s.repository.databaseId.toString(),graphQLId:s.repository.id,name:s.repository.name,owner:{login:s.repository.owner.login},remoteInfo:{cloneUrlHTTPS:n,cloneUrlSSH:s.repository.sshUrl}},headRepository:s.headRepository?{id:s.headRepository.databaseId.toString(),graphQLId:s.headRepository.id,name:s.headRepository.name,owner:{login:s.headRepository.owner.login},remoteInfo:{cloneUrlHTTPS:t,cloneUrlSSH:s.headRepository.sshUrl}}:null,headCommit:{buildStatuses:s.commits.nodes?.filter(O)[0]?.commit.statusCheckRollup?.contexts.nodes?.filter(O).map(i=>"context"in i?{completedAt:null,description:i.description,name:i.context,state:Ln(i.state),startedAt:new Date(i.createdAt),stage:null,url:i.targetUrl}:{completedAt:i.completedAt?new Date(i.completedAt):null,description:null,name:i.name,state:An(i.status,i.conclusion),startedAt:i.startedAt?new Date(i.startedAt):null,stage:null,url:i.permalink})??[]},headRef:s.headRef?{name:s.headRef.name,oid:s.headRef.target?.oid??null}:null,baseRef:s.baseRef?{name:s.baseRef.name,oid:s.baseRef.target?.oid??null}:null,url:s.url,updatedDate:new Date(s.updatedAt),closedDate:s.closedAt?new Date(s.closedAt):null,mergedDate:s.mergedAt?new Date(s.mergedAt):null,assignees:s.assignees.nodes?s.assignees.nodes.filter(O).map(i=>M(i)):null,reviews:o,reviewDecision:H(o),additions:s.additions,deletions:s.deletions,fileCount:s.changedFiles,commitCount:s.commits.totalCount,mergeableState:wn[s.mergeStateStatus]??Pn[s.mergeable],milestone:s.milestone?Jt(s.milestone):null,labels:s.labels?.nodes?.filter(O).map(Ht)??[],permissions:{canMerge:vn.includes(s.repository.viewerPermission),canMergeAndBypassProtections:s.viewerCanMergeAsAdmin??!1}}},Un=s=>{let{id:r,comments:e,isOutdated:t,isResolved:n,line:o,startLine:i,diffSide:a,originalLine:u,originalStartLine:l,startDiffSide:p}=s,c=e.nodes?.[0];if(!c)return null;let{author:d,body:g,databaseId:m,fullDatabaseId:I,id:y,path:h,publishedAt:v,url:D}=c,x=o??u,S=i??l,P=a??p;return{author:d?{avatarUrl:d.avatarUrl,email:null,name:d.login}:null,body:g,createdAt:v?new Date(v):null,diffLines:Hr(c.diffHunk,x,S,P),id:I??m.toString(),isOutdated:t,isResolved:n,graphQLId:y,threadId:r,filename:h,replies:e.nodes?.filter(O).slice(1).map(Tn)??[],url:D,line:x,startLine:S,side:P}},Tn=s=>({author:s.author?{avatarUrl:s.author.avatarUrl,email:null,name:s.author.login}:null,body:s.body,createdAt:s.publishedAt?new Date(s.publishedAt):null,graphQLId:s.id,id:s.fullDatabaseId??s.databaseId.toString(),url:s.url}),Gn=s=>{let r=null;return s.author?r=s.author:r=De,{id:s.fullDatabaseId!==void 0?s.fullDatabaseId:s.databaseId.toString(),graphQLId:s.id,number:s.number,title:s.title,author:r&&r.__typename?M(r):null,commentCount:s.comments.totalCount,closedDate:s.closedAt?new Date(s.closedAt):null,createdDate:new Date(s.createdAt),description:null,state:{name:qn[s.state],color:null},type:null,repository:{id:s.repository.databaseId.toString(),graphQLId:s.repository.id,name:s.repository.name,owner:{login:s.repository.owner.login}},url:s.url,updatedDate:new Date(s.updatedAt),assignees:s.assignees.nodes?.filter(O).map(e=>M(e))??[],upvoteCount:s.reactions.totalCount,milestone:s.milestone?Jt(s.milestone):null,labels:s.labels?.nodes?.filter(O).map(Ht)??[]}},Jt=s=>({id:s.number.toString(),graphQLId:s.id.toString(),number:s.number,title:s.title,description:s.description,isOpen:s.state=="OPEN",url:s.url,startDate:null,dueDate:s.dueOn?new Date(s.dueOn):null}),fe=class extends j{constructor(){super(...arguments);this._scopesCache={};this._enterpriseVersionsCache={}}async getScopes(e){let t=e.token||this.config.token;if(!t)return[];let n=this._scopesCache[t];if(!n){let i=(await b(this.config,{query:"query { rateLimit(dryRun: true) { __typename } }"},e)).headers["x-oauth-scopes"];n=i?i.split(", "):[],this._scopesCache[t]=n}return n}async getEnterpriseVersion(e){let t=e.baseUrl||this.config.baseUrl;if(!t)return null;let n=this._enterpriseVersionsCache[t];if(!n){let o=await this.config.request({url:`${V(this.config,e)}/meta`,headers:f(e.token||this.config.token)});if(!o.body.installed_version)return null;n=o.body.installed_version.split(".").slice(0,3).map(i=>parseInt(i,10)),this._enterpriseVersionsCache[t]=n}return n}getEnterpriseAvatarUrlIfNeeded(e,t,n){let o=n.baseUrl||this.config.baseUrl;return!o||o.startsWith(Be)?e:t?`https://avatars.githubusercontent.com/u/e?email=${encodeURIComponent(t)}`:""}async getCurrentUser(e={},t={}){if(e.fields&&!e.fields.length)throw new Error('"fields" must contain at least one field or be omitted');let n=Gr(e.fields),o=await this.getScopes(t),i=await b(this.config,{query:`
|
|
372
372
|
query getCurrentUser {
|
|
373
373
|
viewer {
|
|
374
374
|
${B(!1,Z(o),n)}
|
|
@@ -500,7 +500,7 @@ query getRepo($owner: String!, $name: String!) {
|
|
|
500
500
|
query batchGetRepos {
|
|
501
501
|
${n}
|
|
502
502
|
}
|
|
503
|
-
`},t);if(!o.body.data)throw new R("Could not fetch repos",o.body.errors);let i=[],a=[];return e.forEach((u,l)=>{let p=o.body.data[`getRepo_${l}`];p?i.push(zt(p)):a.push({input:u})}),{data:i,errors:a}}async fetchMultipleRESTPages(e,t,n,o){let i=[];for(let c=0;c<t;c++)i.push(n(e+c));let a=await Promise.all(i),u=[];for(let c of a){if(!c.body)throw new Error(c.statusText||"Unknown error");u=u.concat(c.body.map(d=>o(d)))}let l=a.every(c=>c.body.length===100),p=e+t;return{data:u,pageInfo:{hasNextPage:l,nextPage:l?p:null}}}async getReposForCurrentUser(e,t={}){if(e.simultaneousPagesToFetch&&e.simultaneousPagesToFetch>40)throw new Error("The argument 'simultaneousPagesToFetch' cannot exceed 40 for 'getReposForCurrentUser'");let n=new URLSearchParams;n.append("per_page","100"),e.affiliations&&n.append("affiliation",e.affiliations.join(","));let o=i=>this.config.request({url:`${
|
|
503
|
+
`},t);if(!o.body.data)throw new R("Could not fetch repos",o.body.errors);let i=[],a=[];return e.forEach((u,l)=>{let p=o.body.data[`getRepo_${l}`];p?i.push(zt(p)):a.push({input:u})}),{data:i,errors:a}}async fetchMultipleRESTPages(e,t,n,o){let i=[];for(let c=0;c<t;c++)i.push(n(e+c));let a=await Promise.all(i),u=[];for(let c of a){if(!c.body)throw new Error(c.statusText||"Unknown error");u=u.concat(c.body.map(d=>o(d)))}let l=a.every(c=>c.body.length===100),p=e+t;return{data:u,pageInfo:{hasNextPage:l,nextPage:l?p:null}}}async getReposForCurrentUser(e,t={}){if(e.simultaneousPagesToFetch&&e.simultaneousPagesToFetch>40)throw new Error("The argument 'simultaneousPagesToFetch' cannot exceed 40 for 'getReposForCurrentUser'");let n=new URLSearchParams;n.append("per_page","100"),e.affiliations&&n.append("affiliation",e.affiliations.join(","));let o=i=>this.config.request({url:`${V(this.config,t)}/user/repos?${n.toString()}&page=${i}`,headers:{...f(t.token||this.config.token),Accept:"application/vnd.github.raw+json","X-Github-Next-Global-ID":1}});return await this.fetchMultipleRESTPages(e.page??1,e.simultaneousPagesToFetch??4,o,rs)}async getReposForOrg(e,t={}){if(e.simultaneousPagesToFetch&&e.simultaneousPagesToFetch>40)throw new Error("The argument 'simultaneousPagesToFetch' cannot exceed 40 for 'getReposForOrg'");let n=o=>this.config.request({url:`${V(this.config,t)}/orgs/${e.orgName}/repos?per_page=100&page=${o}`,headers:{...f(t.token||this.config.token),Accept:"application/vnd.github.raw+json","X-Github-Next-Global-ID":1}});return await this.fetchMultipleRESTPages(e.page??1,e.simultaneousPagesToFetch??4,n,rs)}async getReposForUsernames(e,t={}){if(!e.usernames.length)return{pageInfo:{endCursor:null,hasNextPage:!1},data:[]};let n=await b(this.config,{query:`
|
|
504
504
|
query getReposForUsernames($query: String!, $cursor: String, $first: Int!) {
|
|
505
505
|
search(query: $query, type: REPOSITORY, first: $first, after: $cursor) {
|
|
506
506
|
pageInfo {
|
|
@@ -574,7 +574,7 @@ query getBlame($owner: String!, $name: String!, $ref: String!, $path: String!) {
|
|
|
574
574
|
}
|
|
575
575
|
}
|
|
576
576
|
}
|
|
577
|
-
`,variables:{owner:e.repo.namespace,name:e.repo.name,ref:e.ref,path:e.path}},t),o=n.body.data?.repository;if(!o)throw new R("Blame repository not found.",n.body.errors);let i=o.object;if(!i||!("blame"in i))throw new R("Ref not found.",n.body.errors);if(i.blame.ranges.length===0)throw new R("File not found.",n.body.errors);return{data:{ranges:i.blame.ranges.map(a=>({startingLine:a.startingLine,endingLine:a.endingLine,commit:{oid:a.commit.oid,parentOids:a.commit.parents.nodes?.map(u=>u.oid)||[],authoredDate:new Date(a.commit.authoredDate),author:a.commit.author?{name:a.commit.author.name,email:a.commit.author.email,avatarUrl:a.commit.author.avatarUrl}:null,committedDate:new Date(a.commit.committedDate),committer:a.commit.committer?{name:a.commit.committer.name,email:a.commit.committer.email,avatarUrl:a.commit.committer.avatarUrl}:null,message:a.commit.message,fileCount:a.commit.changedFilesIfAvailable,additions:a.commit.additions,deletions:a.commit.deletions}}))}}}async getFileContents(e,t={}){let n=await this.config.request({url:`${
|
|
577
|
+
`,variables:{owner:e.repo.namespace,name:e.repo.name,ref:e.ref,path:e.path}},t),o=n.body.data?.repository;if(!o)throw new R("Blame repository not found.",n.body.errors);let i=o.object;if(!i||!("blame"in i))throw new R("Ref not found.",n.body.errors);if(i.blame.ranges.length===0)throw new R("File not found.",n.body.errors);return{data:{ranges:i.blame.ranges.map(a=>({startingLine:a.startingLine,endingLine:a.endingLine,commit:{oid:a.commit.oid,parentOids:a.commit.parents.nodes?.map(u=>u.oid)||[],authoredDate:new Date(a.commit.authoredDate),author:a.commit.author?{name:a.commit.author.name,email:a.commit.author.email,avatarUrl:a.commit.author.avatarUrl}:null,committedDate:new Date(a.commit.committedDate),committer:a.commit.committer?{name:a.commit.committer.name,email:a.commit.committer.email,avatarUrl:a.commit.committer.avatarUrl}:null,message:a.commit.message,fileCount:a.commit.changedFilesIfAvailable,additions:a.commit.additions,deletions:a.commit.deletions}}))}}}async getFileContents(e,t={}){let n=await this.config.request({url:`${V(this.config,t)}/repos/${e.repo.namespace}/${e.repo.name}/contents/${encodeURIComponent(e.path)}?ref=${e.ref}`,headers:{...f(t.token||this.config.token),Accept:"application/vnd.github.raw+json"}});if(n.headers["content-type"].startsWith("application/json"))throw new Error(`GitHub: got directory when fetching "${e.path}", getFileContents does not support fetching directories`);if(!n.headers["content-type"].startsWith("application/vnd.github.raw+json"))throw new Error(`GitHub: unsupported content type "${n.headers["content-type"]}" when fetching "${e.path}"`);return{data:new Blob([n.body])}}async getMergeBase(e,t={}){return{data:(await this.config.request({url:`${V(this.config,t)}/repos/${e.repo.namespace}/${e.repo.name}/compare/${encodeURIComponent(e.base)}...${encodeURIComponent(e.head)}`,headers:f(t.token||this.config.token)})).body.merge_base_commit.sha}}async getPullRequestDiff(e,t={}){return(await this.config.request({url:`${V(this.config,t)}/repos/${e.repo.namespace}/${e.repo.name}/pulls/${e.pullRequestId}`,headers:{...f(t.token||this.config.token),Accept:"application/vnd.github.diff"}})).body??""}async searchPullRequests(e,t={}){let n=await this.getEnterpriseVersion(t),o=await this.getScopes(t),i=Z(o),a=p=>{let c=p&&typeof e.isDraft=="boolean"?`${e.query} draft:${e.isDraft}`:e.query;return Ft("pr",c,e.cursor,{maxPageSize:e.maxPageSize??Fr,supportsEmail:i,supportsDrafts:p,enterpriseVersion:n,includeFromArchivedRepos:e.includeFromArchivedRepos})},u=await b(this.config,a(!0),t);u.body.errors&&ze(u.body.errors)&&(this.config.baseUrl||t.baseUrl)&&(u=await b(this.config,a(!1),t));let{data:l}=u.body;if(!l)throw new R("Could not search pull requests",u.body.errors);return{pageInfo:{hasNextPage:l.search.pageInfo.hasNextPage,endCursor:l.search.pageInfo.endCursor},data:l.search.nodes?.filter(O).map(Wt)||[]}}async searchIssues(e,t={}){let n=await this.getEnterpriseVersion(t),o=await this.getScopes(t),i=Z(o),a=await b(this.config,Ft("issue",e.query,e.cursor,{supportsEmail:i,includeFromArchivedRepos:e.includeFromArchivedRepos,maxPageSize:e.maxPageSize??Mr,enterpriseVersion:n}),t),{data:u}=a.body;if(!u)throw new R("Could not search issues",a.body.errors);return{pageInfo:{hasNextPage:u.search.pageInfo.hasNextPage,endCursor:u.search.pageInfo.endCursor},data:u.search.nodes?.filter(O).map(Gn)||[]}}async getPullRequestsAssociatedWithUser(e,t={}){let n=[`involves:${e.username}`];return e.repos?.length&&e.repos.forEach(o=>{n.push(`repo:${o.namespace}/${o.name}`)}),e.labelNames&&e.labelNames.forEach(o=>{n.push(`label:"${o}"`)}),this.searchPullRequests({query:n.join(" "),cursor:e.cursor,includeFromArchivedRepos:e.includeFromArchivedRepos,maxPageSize:e.maxPageSize},t)}async getPullRequestsForRepos(e,t={}){let{assigneeLogins:n,updatedBefore:o,authorLogin:i,repos:a,reviewRequestedLogin:u,startQuery:l,mentionLogin:p,labelNames:c,maxPageSize:d}=e,g=Qt(l||"");return a.forEach(m=>{g.push(`repo:${m.namespace}/${m.name}`)}),n&&n.forEach(m=>{g.push(`assignee:${m}`)}),o&&g.push(`updated:<${o}`),i&&g.push(`author:${i}`),u&&g.push(`review-requested:${u}`),p&&g.push(`mentions:${p}`),c&&c.forEach(m=>{g.push(`label:"${m}"`)}),this.searchPullRequests({query:`sort:updated ${g.join(" ")}`,isDraft:e.isDraft,cursor:e.cursor,includeFromArchivedRepos:e.includeFromArchivedRepos,maxPageSize:d},t)}async getPullRequestForRepo(e,t={}){let n=await this.getEnterpriseVersion(t),o=await this.getScopes(t),i=Z(o),a=c=>({query:`query getPullRequest(
|
|
578
578
|
$owner: String!
|
|
579
579
|
$name: String!
|
|
580
580
|
$number: Int!
|
|
@@ -587,7 +587,7 @@ query getBlame($owner: String!, $name: String!, $ref: String!, $path: String!) {
|
|
|
587
587
|
${Me(c,i,n)}
|
|
588
588
|
}
|
|
589
589
|
}
|
|
590
|
-
}`,variables:{owner:e.repo.namespace,name:e.repo.name,number:e.number}}),u=await b(this.config,a(!0),t);u.body.errors&&ze(u.body.errors)&&(this.config.baseUrl||t.baseUrl)&&(u=await b(this.config,a(!1),t));let{data:l}=u.body;if(!l)throw new R("Could not fetch pull request by number",u.body.errors);let p=u.body.data?.repository.pullRequest;return{data:p?Wt(p):null}}async getPullRequestDescription(e,t={}){try{let n=await this.config.request({url:`${
|
|
590
|
+
}`,variables:{owner:e.repo.namespace,name:e.repo.name,number:e.number}}),u=await b(this.config,a(!0),t);u.body.errors&&ze(u.body.errors)&&(this.config.baseUrl||t.baseUrl)&&(u=await b(this.config,a(!1),t));let{data:l}=u.body;if(!l)throw new R("Could not fetch pull request by number",u.body.errors);let p=u.body.data?.repository.pullRequest;return{data:p?Wt(p):null}}async getPullRequestDescription(e,t={}){try{let n=await this.config.request({url:`${V(this.config,t)}/repos/${e.repo.namespace}/${e.repo.name}/pulls/${e.number}`,headers:{...f(t.token||this.config.token),Accept:"application/vnd.github.full+json"}});return{data:{description:n.body?.body??"",descriptionHtml:n.body?.body_html||null}}}catch{return{data:{description:null,descriptionHtml:null}}}}async setPullRequestDescription(e,t={}){let n=await this.config.request({method:"PATCH",url:`${V(this.config,t)}/repos/${e.repo.namespace}/${e.repo.name}/pulls/${e.number}`,headers:{...f(t.token||this.config.token),Accept:"application/vnd.github+json","Content-Type":"application/json"},body:JSON.stringify({body:e.description})});return{data:{description:n.body?.body??e.description,descriptionHtml:n.body?.body_html||null}}}async getPullRequestByGraphQLId(e,t={}){let n=await this.getEnterpriseVersion(t),o=await this.getScopes(t),i=Z(o),a=c=>({query:`query getPullRequest(
|
|
591
591
|
$graphQLId: ID!
|
|
592
592
|
) {
|
|
593
593
|
node(id: $graphQLId) {
|
|
@@ -654,7 +654,7 @@ query getBlame($owner: String!, $name: String!, $ref: String!, $path: String!) {
|
|
|
654
654
|
id
|
|
655
655
|
}
|
|
656
656
|
}
|
|
657
|
-
}`,a=await b(this.config,{query:i,variables:{pullRequestId:n.graphQLId,body:o}},t);if(!a.body.data?.addPullRequestReview?.pullRequestReview?.id)throw new R("Could not comment on pull request",a.body.errors)}async addCommentToPullRequest(e,t={}){let{pullRequest:n,comment:o}=e;if(!n.graphQLId)throw new Error('GitHub requires "graphQLId" for this function.');if(!o||o.trim()==="")throw new Error("GitHub requires a comment when adding a comment to a pull request.");let i=`mutation AddCommentToPullRequest(
|
|
657
|
+
}`,a=await b(this.config,{query:i,variables:{pullRequestId:n.graphQLId,body:o}},t);if(!a.body.data?.addPullRequestReview?.pullRequestReview?.id)throw new R("Could not comment on pull request",a.body.errors)}async reviewPullRequest(e,t={}){let{pullRequest:n,reviewEvent:o,comment:i}=e;switch(o){case"APPROVE":return this.approvePullRequest({pullRequest:n,comment:i},t);case"REQUEST_CHANGES":return this.requestPullRequestChanges({pullRequest:n,comment:i??""},t);case"COMMENT":return this.commentOnPullRequest({pullRequest:n,comment:i??""},t)}}async addCommentToPullRequest(e,t={}){let{pullRequest:n,comment:o}=e;if(!n.graphQLId)throw new Error('GitHub requires "graphQLId" for this function.');if(!o||o.trim()==="")throw new Error("GitHub requires a comment when adding a comment to a pull request.");let i=`mutation AddCommentToPullRequest(
|
|
658
658
|
$subjectId: ID!,
|
|
659
659
|
$body: String!
|
|
660
660
|
) {
|
|
@@ -868,7 +868,7 @@ query getLabelsForRepo($owner: String!, $name: String! $cursor: String, $first:
|
|
|
868
868
|
}
|
|
869
869
|
}
|
|
870
870
|
}
|
|
871
|
-
`,variables:{owner:n,name:o,cursor:i,first:$}},t);if(!a.body.data)throw new R("Could not fetch labels",a.body.errors);return{pageInfo:a.body.data.repository.labels?.pageInfo??{endCursor:null,hasNextPage:!1},data:a.body.data.repository.labels?.nodes?.map(Ht)??[]}}async getTreeForRepo(e,t={}){let n=await this.config.request({url:`${
|
|
871
|
+
`,variables:{owner:n,name:o,cursor:i,first:$}},t);if(!a.body.data)throw new R("Could not fetch labels",a.body.errors);return{pageInfo:a.body.data.repository.labels?.pageInfo??{endCursor:null,hasNextPage:!1},data:a.body.data.repository.labels?.nodes?.map(Ht)??[]}}async getTreeForRepo(e,t={}){let n=await this.config.request({url:`${V(this.config,t)}/repos/${e.repo.namespace}/${e.repo.name}/git/trees/${e.branch}?recursive=1`,headers:{...f(t.token||this.config.token)}});if(!n.body)throw new Error("Could not fetch trees");return{data:n.body.tree.map(Cn)}}};var On="https://gitlab.com/api/v4",kn="https://gitlab.com/api/graphql",Vt=/\/api\/v\d+$/,ns=s=>{if(s.endsWith("/api/graphql"))throw new Error("The graphql endpoint is being used as the baseUrl. This package uses both GraphQL and REST APIs, and the REST version cannot be assumed. Use the REST endpoint as the baseUrl instead.")},A=(s,r)=>{let e=r.baseUrl||s.baseUrl;return e?(e=e.replace(/\/$/,""),ns(e),Vt.test(e)||(e=e+"/api/v4"),e):On},xn=(s,r)=>{let e=r.baseUrl||s.baseUrl;return e?(e=e.replace(/\/$/,""),ns(e),Vt.test(e)&&(e=e.replace(Vt,"")),`${e}/api/graphql`):kn},q=(s,r,e)=>{let t=f(e.token||s.token);return s.request({url:xn(s,e),method:"POST",headers:{...t,"Content-Type":"application/json"},body:JSON.stringify(r)})},$e=s=>s?.map(r=>`"${r.message}"`).join(", ");var nr=s=>s.split("/").slice(0,-1).join("/"),or=s=>s.split("/").at(-1)??"",We=s=>({id:s.id.replace(Re,""),graphQLId:s.id,namespace:nr(s.fullPath),name:or(s.fullPath),webUrl:s.webUrl}),He=s=>({id:s.id.replace(Re,""),graphQLId:s.id,httpsUrl:s.httpUrlToRepo,namespace:nr(s.fullPath),name:or(s.fullPath),sshUrl:s.sshUrlToRepo,webUrl:s.webUrl}),_n={assigned:"assignedMergeRequests",authored:"authoredMergeRequests",reviewRequested:"reviewRequestedMergeRequests"},Nn={CAN_BE_MERGED:"MERGEABLE",CANNOT_BE_MERGED:"CONFLICTS",CANNOT_BE_MERGED_RECHECK:"UNKNOWN",UNCHECKED:"UNKNOWN",CHECKING:"UNKNOWN"};var is="gid://gitlab/User/",Re="gid://gitlab/Project/",jn="gid://gitlab/MergeRequest/",Bn="gid://gitlab/Issue/",Qn="gid://gitlab/ProjectLabel/",Fn="gid://gitlab/Milestone/",Mn="gid://gitlab/Ci::Build/",ir=`
|
|
872
872
|
description
|
|
873
873
|
dueDate
|
|
874
874
|
id
|
|
@@ -1104,7 +1104,7 @@ query getPullRequestsForUser($username: String! $cursor: String $labelNames: [St
|
|
|
1104
1104
|
}
|
|
1105
1105
|
}
|
|
1106
1106
|
}
|
|
1107
|
-
`,variables:{username:r.username,cursor:r.cursor,labelNames:r.labelNames}},e);if(!o.body.data)throw new Error($e(o.body.errors)||o.statusText||"Unknown error");if(!o.body.data.user)throw new Error("User not found");let i=o.body.data.user[n];if(!i)throw new Error("Unexpected response");return{pageInfo:i.pageInfo,data:i.nodes?.filter(a=>r.includeFromArchivedRepos||!a.project.archived).map(a=>er(a,He(a.project),He(a.sourceProject),this.getIsSelfHosted(e),this.config.baseUrl??e.baseUrl))||[]}}async getPullRequestsAssociatedWithUser(r,e={}){let[t,n,o]=r.cursor?.split(";")||[void 0,void 0,void 0],i=t?.split("-")||[],a=n?.split("-")||[],u=o?.split("-")||[],l=[],p=[],c=[],d=0;do{let S=r.repos&&r.repos[d];i[d]==="null"?l.push(null):l.push(this.getPullRequestsForUser({username:r.username,association:"authored",cursor:i[d],includeFromArchivedRepos:r.includeFromArchivedRepos,labelNames:r.labelNames,...S&&{repo:S}},e)),a[d]==="null"?p.push(null):p.push(this.getPullRequestsForUser({username:r.username,association:"assigned",cursor:a[d],includeFromArchivedRepos:r.includeFromArchivedRepos,labelNames:r.labelNames,...S&&{repo:S}},e)),u[d]==="null"?c.push(null):c.push(this.getPullRequestsForUser({username:r.username,association:"reviewRequested",cursor:u[d],includeFromArchivedRepos:r.includeFromArchivedRepos,labelNames:r.labelNames,...S&&{repo:S}},e)),d++}while(d<(r.repos?.length||0));let g=[l,p,c].flat(),m=await Promise.all(g),I={},y=[],h=S=>{I[S.id]||(I[S.id]=!0,y.push(S))},v=!1,
|
|
1107
|
+
`,variables:{username:r.username,cursor:r.cursor,labelNames:r.labelNames}},e);if(!o.body.data)throw new Error($e(o.body.errors)||o.statusText||"Unknown error");if(!o.body.data.user)throw new Error("User not found");let i=o.body.data.user[n];if(!i)throw new Error("Unexpected response");return{pageInfo:i.pageInfo,data:i.nodes?.filter(a=>r.includeFromArchivedRepos||!a.project.archived).map(a=>er(a,He(a.project),He(a.sourceProject),this.getIsSelfHosted(e),this.config.baseUrl??e.baseUrl))||[]}}async getPullRequestsAssociatedWithUser(r,e={}){let[t,n,o]=r.cursor?.split(";")||[void 0,void 0,void 0],i=t?.split("-")||[],a=n?.split("-")||[],u=o?.split("-")||[],l=[],p=[],c=[],d=0;do{let S=r.repos&&r.repos[d];i[d]==="null"?l.push(null):l.push(this.getPullRequestsForUser({username:r.username,association:"authored",cursor:i[d],includeFromArchivedRepos:r.includeFromArchivedRepos,labelNames:r.labelNames,...S&&{repo:S}},e)),a[d]==="null"?p.push(null):p.push(this.getPullRequestsForUser({username:r.username,association:"assigned",cursor:a[d],includeFromArchivedRepos:r.includeFromArchivedRepos,labelNames:r.labelNames,...S&&{repo:S}},e)),u[d]==="null"?c.push(null):c.push(this.getPullRequestsForUser({username:r.username,association:"reviewRequested",cursor:u[d],includeFromArchivedRepos:r.includeFromArchivedRepos,labelNames:r.labelNames,...S&&{repo:S}},e)),d++}while(d<(r.repos?.length||0));let g=[l,p,c].flat(),m=await Promise.all(g),I={},y=[],h=S=>{I[S.id]||(I[S.id]=!0,y.push(S))},v=!1,x=m.map((S,P)=>{let E="";return S&&S.data.forEach(h),S?.pageInfo.hasNextPage?(v=!0,E+=`${S.pageInfo.endCursor||"null"}`):E+="null",r.repos?.length&&(P+1)%r.repos.length!==0?E+="-":P+1<m.length&&(E+=";"),E}).join("");return{pageInfo:{hasNextPage:v,endCursor:x},data:y}}getVariablesForPullRequests(r){let{updatedBefore:e,isDraft:t,authorLogin:n,assigneeLogins:o,labelNames:i,reviewRequestedLogin:a}=r||{},u={},l=[],p=[],c=(d,g,m)=>{l.push(`$${d}: ${m}`),p.push(`${d}: $${d}`),u[d]=g};return e&&c("updatedBefore",e,"Time"),n&&c("authorUsername",n,"String"),o&&c("assigneeUsername",o[0],"String"),i&&c("labelName",i,"[String]"),t!=null&&c("draft",t,"Boolean"),a&&c("reviewerUsername",a,"String"),{variables:u,variableTypes:l,mergeRequestArguments:p}}async getPullRequestsForRepoBase(r,e={},t){let{cursor:n,repo:o}=r||{},i=G(o),{variables:a,variableTypes:u,mergeRequestArguments:l}=this.getVariablesForPullRequests(r),p={fullPath:i,...a},c=await q(this.config,{query:`
|
|
1108
1108
|
query getPullRequestsForRepo(
|
|
1109
1109
|
$fullPath: ID!
|
|
1110
1110
|
$after: String
|
|
@@ -1358,7 +1358,7 @@ query getPullRequestForRepo($fullPath: ID!, $iid: String!) {
|
|
|
1358
1358
|
}
|
|
1359
1359
|
}
|
|
1360
1360
|
}
|
|
1361
|
-
`,variables:{fullPath:t,iid:r.number.toString()}},e)).body.data?.project,i=o?.mergeRequest;if(!o||!i)return{data:null};let a=He(o),u=i.sourceProject?He(i.sourceProject):null;return{data:er(i,a,u,this.getIsSelfHosted(e),this.config.baseUrl??e.baseUrl)}}getMergeRequestUrl(r,e,t){let n=G(r);return`${A(this.config,t)}/projects/${encodeURIComponent(n)}/merge_requests/${e}`}async getPullRequestDescription(r,e={}){try{return{data:{description:(await this.config.request({url:this.getMergeRequestUrl(r.repo,r.number,e),headers:f(e.token||this.config.token)})).body?.description??""}}}catch{return{data:{description:null}}}}async setPullRequestDescription(r,e={}){return{data:{description:(await this.config.request({method:"PUT",url:this.getMergeRequestUrl(r.repo,r.number,e),headers:{...f(e.token||this.config.token),"Content-Type":"application/json"},body:JSON.stringify({description:r.description})})).body?.description??r.description}}}async getFileContents(r,e={}){let t=G(r.repo),n=new URL(`${A(this.config,e)}/projects/${encodeURIComponent(t)}/repository/files/${encodeURIComponent(r.path)}/raw`);n.searchParams.set("ref",r.ref);let o=await this.config.request({url:n.toString(),headers:f(e.token||this.config.token)});return{data:new Blob([o.body])}}async getCommentsForPullRequest(r,e={}){let t=G(r.repo),{page:n,perPage:o}=eo(r.cursor,$),i=new URL(`${A(this.config,e)}/projects/${encodeURIComponent(t)}/merge_requests/${r.pullRequestNumber}/notes`);i.searchParams.set("page",n.toString()),i.searchParams.set("per_page",o.toString()),i.searchParams.set("sort","asc"),i.searchParams.set("order_by","created_at");let a=await this.config.request({url:i.toString(),headers:f(e.token||this.config.token)}),u=this.getIsSelfHosted(e),l=this.config.baseUrl??e.baseUrl,p={namespace:r.repo.namespace,name:r.repo.name,mergeRequestIid:r.pullRequestNumber},c=a.body.filter(m=>!m.system&&!m.position).map(m=>rr(m,u,l,p)),d=!!a.headers["x-next-page"],g=d?Zn({page:n+1,perPage:o}):null;return{data:c,pageInfo:{endCursor:g,hasNextPage:d}}}async getReviewsForPullRequest(r,e={}){let t=G(r.repo),n=this.getIsSelfHosted(e),o=this.config.baseUrl??e.baseUrl,i=f(e.token||this.config.token),a=A(this.config,e),u=encodeURIComponent(t),[l,p]=await Promise.all([this.config.request({url:`${a}/projects/${u}/merge_requests/${r.pullRequestId}/approvals`,headers:i}),this.fetchAllMergeRequestDiscussions(t,r.pullRequestId,e)]),c=(l.body.approved_by??[]).map(m=>m?.user).filter(m=>!!m).map(m=>{let I=os(m,n,o),y=`approval-${m.id}`;return{author:I,body:"",createdAt:l.body.updated_at?new Date(l.body.updated_at):null,id:y,graphQLId:y,reviewComments:[],url:l.body.web_url??""}}),d={namespace:r.repo.namespace,name:r.repo.name,mergeRequestIid:r.pullRequestId},g=p.filter(m=>m.notes.some(I=>!I.system&&!!I.position)).map(m=>{let I=m.notes.filter(P=>!P.system),h=I.filter(P=>!!P.position)[0];if(!h)return null;let v=I.filter(P=>P.id!==h.id).map(P=>rr(P,n,o,d)),k={...rr(h,n,o,d),diffLines:[],filename:h.position?.new_path??h.position?.old_path??"",line:h.position?.new_line??h.position?.old_line??null,startLine:h.position?.line_range?.start?.new_line??null,side:ro(h.position),isOutdated:!1,isResolved:!!m.resolved,threadId:m.id,replies:v};return{author:h.author?os(h.author,n,o):null,body:h.body??"",createdAt:h.created_at?new Date(h.created_at):null,id:m.id,graphQLId:m.id,reviewComments:[k],url:""}}).filter(m=>m!==null);return{data:[...c,...g]}}async getPullRequestDiff(r,e={}){let t=G(r.repo),n=encodeURIComponent(t),o=A(this.config,e);return(await this.fetchAllPagedGitLabREST(`${o}/projects/${n}/merge_requests/${r.pullRequestId}/diffs`,e)).map(so).join("")}async getMergeBase(r,e={}){let t=G(r.repo),n=new URL(`${A(this.config,e)}/projects/${encodeURIComponent(t)}/repository/merge_base`);n.searchParams.append("refs[]",r.base),n.searchParams.append("refs[]",r.head);let i=(await this.config.request({url:n.toString(),headers:f(e.token||this.config.token)})).body?.id;if(!i)throw new Error("No merge base found between the specified commits.");return{data:i}}async fetchAllMergeRequestDiscussions(r,e,t){let n=A(this.config,t),o=encodeURIComponent(r);return this.fetchAllPagedGitLabREST(`${n}/projects/${o}/merge_requests/${e}/discussions`,t)}async fetchAllPagedGitLabREST(r,e){let t=f(e.token||this.config.token),n=[],o=1,i=50;for(;o<=i;){let a=new URL(r);a.searchParams.set("page",o.toString()),a.searchParams.set("per_page",$.toString());let u=await this.config.request({url:a.toString(),headers:t});n.push(...u.body);let l=u.headers["x-next-page"];if(!l)break;let p=parseInt(`${l}`,10);if(Number.isNaN(p))break;o=p}return n}async addCommentToPullRequest(r,e={}){let{pullRequest:t,comment:n}=r;if(!n||n.trim()==="")throw new Error("GitLab requires a comment when adding a comment to a pull request.");let o=`${t.repository.owner.login}/${t.repository.name}`,i=`${A(this.config,e)}/projects/${encodeURIComponent(o)}/merge_requests/${t.number}/notes`;if(!(await this.config.request({method:"POST",url:i,headers:{...f(e.token||this.config.token),"Content-Type":"application/json"},body:JSON.stringify({body:n})})).body?.id)throw new Error("Could not add comment to pull request")}async addInlineCommentToPullRequest(r,e={}){let{pullRequest:t,comment:n,path:o,line:i,side:a="RIGHT",threadId:u}=r;if(!n?.trim())throw new Error("GitLab requires a comment when adding an inline comment to a pull request.");let l=`${t.repository.owner.login}/${t.repository.name}`,p=encodeURIComponent(l),c=A(this.config,e),d={...f(e.token||this.config.token),"Content-Type":"application/json"};if(u){let v=await this.config.request({method:"POST",url:`${c}/projects/${p}/merge_requests/${t.number}/discussions/${encodeURIComponent(u)}/notes`,headers:d,body:JSON.stringify({body:n})});return v.body?.id!=null?sr(t.repository.owner.login,t.repository.name,t.number,v.body.id):void 0}if(!o?.trim())throw new Error("GitLab requires a file path when adding an inline comment to a pull request.");if(!Number.isInteger(i)||i<1)throw new Error("GitLab requires a positive line number when adding an inline comment to a pull request.");if(a!=="LEFT"&&a!=="RIGHT")throw new Error('GitLab requires side to be either "LEFT" or "RIGHT".');let m=(await this.config.request({url:`${c}/projects/${p}/merge_requests/${t.number}`,headers:f(e.token||this.config.token)})).body?.diff_refs;if(!m?.base_sha||!m?.start_sha||!m?.head_sha)throw new Error("Could not resolve merge request diff refs required to create an inline comment");let I={position_type:"text",base_sha:m.base_sha,start_sha:m.start_sha,head_sha:m.head_sha,new_path:o,old_path:o};a==="RIGHT"?I.new_line=i:I.old_line=i;let h=(await this.config.request({method:"POST",url:`${c}/projects/${p}/merge_requests/${t.number}/discussions`,headers:d,body:JSON.stringify({body:n,position:I})})).body?.notes?.[0]?.id;return h!=null?sr(t.repository.owner.login,t.repository.name,t.number,h):void 0}getNoteUrl(r,e){if(!r)throw new Error('GitLab requires "commentId" for this function.');let{namespace:t,name:n,mergeRequestIid:o,noteId:i}=no(r);return`${A(this.config,e)}/projects/${encodeURIComponent(`${t}/${n}`)}/merge_requests/${o}/notes/${i}`}async deleteNote(r,e){await this.config.request({method:"DELETE",url:this.getNoteUrl(r,e),headers:f(e.token||this.config.token)})}async deleteComment(r,e={}){await this.deleteNote(r.commentId,e)}async deleteInlineComment(r,e={}){await this.deleteNote(r.commentId,e)}async editNote(r,e,t){if(!e?.trim())throw new Error("GitLab requires a body when editing a comment.");if(!(await this.config.request({method:"PUT",url:this.getNoteUrl(r,t),headers:{...f(t.token||this.config.token),"Content-Type":"application/json"},body:JSON.stringify({body:e})})).body?.id)throw new Error("Could not edit comment")}async editComment(r,e={}){await this.editNote(r.commentId,r.body,e)}async editInlineComment(r,e={}){await this.editNote(r.commentId,r.body,e)}async resolveReviewThread(r,e={}){await this.setReviewThreadResolved(r,!0,e)}async unresolveReviewThread(r,e={}){await this.setReviewThreadResolved(r,!1,e)}async setReviewThreadResolved(r,e,t){if(!r.repo||r.pullRequestNumber==null)throw new Error("GitLab requires input.repo and input.pullRequestNumber to locate the discussion to (un)resolve.");if(!r.threadId)throw new Error("GitLab requires input.threadId to (un)resolve a discussion.");let n=G(r.repo),o=new URL(`${A(this.config,t)}/projects/${encodeURIComponent(n)}/merge_requests/${r.pullRequestNumber}/discussions/${encodeURIComponent(r.threadId)}`);o.searchParams.set("resolved",e?"true":"false"),await this.config.request({url:o.toString(),method:"PUT",headers:f(t.token||this.config.token)})}async approvePullRequest(r,e={}){let{pullRequest:t,comment:n}=r,o=`${t.repository.owner.login}/${t.repository.name}`,i=A(this.config,e),a=encodeURIComponent(o),u=f(e.token||this.config.token);await this.config.request({url:`${i}/projects/${a}/merge_requests/${t.number}/approve`,method:"POST",headers:u}),n&&n.trim()!==""&&await this.postMergeRequestNote(o,t.number,n,e)}async commentOnPullRequest(r,e={}){let{pullRequest:t,comment:n}=r;if(!n||n.trim()==="")throw new Error("GitLab requires a comment when commenting on a pull request.");let o=`${t.repository.owner.login}/${t.repository.name}`;await this.postMergeRequestNote(o,t.number,n,e)}async requestPullRequestChanges(r,e={}){let{pullRequest:t,comment:n}=r;if(!n||n.trim()==="")throw new Error("GitLab requires a comment when requesting changes on a pull request.");let o=`${t.repository.owner.login}/${t.repository.name}`;if(!await this.tryRequestChangesMutation(o,t.number,e)){let u=`${A(this.config,e)}/projects/${encodeURIComponent(o)}/merge_requests/${t.number}`,l=f(e.token||this.config.token);(await this.config.request({url:`${u}/approvals`,method:"GET",headers:l})).body?.user_has_approved&&await this.config.request({url:`${u}/unapprove`,method:"POST",headers:l})}await this.postMergeRequestNote(o,t.number,n,e)}async tryRequestChangesMutation(r,e,t){let n=`mutation MergeRequestRequestChanges($fullPath: ID!, $pullRequestId: String!) {
|
|
1361
|
+
`,variables:{fullPath:t,iid:r.number.toString()}},e)).body.data?.project,i=o?.mergeRequest;if(!o||!i)return{data:null};let a=He(o),u=i.sourceProject?He(i.sourceProject):null;return{data:er(i,a,u,this.getIsSelfHosted(e),this.config.baseUrl??e.baseUrl)}}getMergeRequestUrl(r,e,t){let n=G(r);return`${A(this.config,t)}/projects/${encodeURIComponent(n)}/merge_requests/${e}`}async getPullRequestDescription(r,e={}){try{return{data:{description:(await this.config.request({url:this.getMergeRequestUrl(r.repo,r.number,e),headers:f(e.token||this.config.token)})).body?.description??""}}}catch{return{data:{description:null}}}}async setPullRequestDescription(r,e={}){return{data:{description:(await this.config.request({method:"PUT",url:this.getMergeRequestUrl(r.repo,r.number,e),headers:{...f(e.token||this.config.token),"Content-Type":"application/json"},body:JSON.stringify({description:r.description})})).body?.description??r.description}}}async getFileContents(r,e={}){let t=G(r.repo),n=new URL(`${A(this.config,e)}/projects/${encodeURIComponent(t)}/repository/files/${encodeURIComponent(r.path)}/raw`);n.searchParams.set("ref",r.ref);let o=await this.config.request({url:n.toString(),headers:f(e.token||this.config.token)});return{data:new Blob([o.body])}}async getCommentsForPullRequest(r,e={}){let t=G(r.repo),{page:n,perPage:o}=eo(r.cursor,$),i=new URL(`${A(this.config,e)}/projects/${encodeURIComponent(t)}/merge_requests/${r.pullRequestNumber}/notes`);i.searchParams.set("page",n.toString()),i.searchParams.set("per_page",o.toString()),i.searchParams.set("sort","asc"),i.searchParams.set("order_by","created_at");let a=await this.config.request({url:i.toString(),headers:f(e.token||this.config.token)}),u=this.getIsSelfHosted(e),l=this.config.baseUrl??e.baseUrl,p={namespace:r.repo.namespace,name:r.repo.name,mergeRequestIid:r.pullRequestNumber},c=a.body.filter(m=>!m.system&&!m.position).map(m=>rr(m,u,l,p)),d=!!a.headers["x-next-page"],g=d?Zn({page:n+1,perPage:o}):null;return{data:c,pageInfo:{endCursor:g,hasNextPage:d}}}async getReviewsForPullRequest(r,e={}){let t=G(r.repo),n=this.getIsSelfHosted(e),o=this.config.baseUrl??e.baseUrl,i=f(e.token||this.config.token),a=A(this.config,e),u=encodeURIComponent(t),[l,p]=await Promise.all([this.config.request({url:`${a}/projects/${u}/merge_requests/${r.pullRequestId}/approvals`,headers:i}),this.fetchAllMergeRequestDiscussions(t,r.pullRequestId,e)]),c=(l.body.approved_by??[]).map(m=>m?.user).filter(m=>!!m).map(m=>{let I=os(m,n,o),y=`approval-${m.id}`;return{author:I,body:"",createdAt:l.body.updated_at?new Date(l.body.updated_at):null,id:y,graphQLId:y,reviewComments:[],url:l.body.web_url??""}}),d={namespace:r.repo.namespace,name:r.repo.name,mergeRequestIid:r.pullRequestId},g=p.filter(m=>m.notes.some(I=>!I.system&&!!I.position)).map(m=>{let I=m.notes.filter(P=>!P.system),h=I.filter(P=>!!P.position)[0];if(!h)return null;let v=I.filter(P=>P.id!==h.id).map(P=>rr(P,n,o,d)),x={...rr(h,n,o,d),diffLines:[],filename:h.position?.new_path??h.position?.old_path??"",line:h.position?.new_line??h.position?.old_line??null,startLine:h.position?.line_range?.start?.new_line??null,side:ro(h.position),isOutdated:!1,isResolved:!!m.resolved,threadId:m.id,replies:v};return{author:h.author?os(h.author,n,o):null,body:h.body??"",createdAt:h.created_at?new Date(h.created_at):null,id:m.id,graphQLId:m.id,reviewComments:[x],url:""}}).filter(m=>m!==null);return{data:[...c,...g]}}async getPullRequestDiff(r,e={}){let t=G(r.repo),n=encodeURIComponent(t),o=A(this.config,e);return(await this.fetchAllPagedGitLabREST(`${o}/projects/${n}/merge_requests/${r.pullRequestId}/diffs`,e)).map(so).join("")}async getMergeBase(r,e={}){let t=G(r.repo),n=new URL(`${A(this.config,e)}/projects/${encodeURIComponent(t)}/repository/merge_base`);n.searchParams.append("refs[]",r.base),n.searchParams.append("refs[]",r.head);let i=(await this.config.request({url:n.toString(),headers:f(e.token||this.config.token)})).body?.id;if(!i)throw new Error("No merge base found between the specified commits.");return{data:i}}async fetchAllMergeRequestDiscussions(r,e,t){let n=A(this.config,t),o=encodeURIComponent(r);return this.fetchAllPagedGitLabREST(`${n}/projects/${o}/merge_requests/${e}/discussions`,t)}async fetchAllPagedGitLabREST(r,e){let t=f(e.token||this.config.token),n=[],o=1,i=50;for(;o<=i;){let a=new URL(r);a.searchParams.set("page",o.toString()),a.searchParams.set("per_page",$.toString());let u=await this.config.request({url:a.toString(),headers:t});n.push(...u.body);let l=u.headers["x-next-page"];if(!l)break;let p=parseInt(`${l}`,10);if(Number.isNaN(p))break;o=p}return n}async addCommentToPullRequest(r,e={}){let{pullRequest:t,comment:n}=r;if(!n||n.trim()==="")throw new Error("GitLab requires a comment when adding a comment to a pull request.");let o=`${t.repository.owner.login}/${t.repository.name}`,i=`${A(this.config,e)}/projects/${encodeURIComponent(o)}/merge_requests/${t.number}/notes`;if(!(await this.config.request({method:"POST",url:i,headers:{...f(e.token||this.config.token),"Content-Type":"application/json"},body:JSON.stringify({body:n})})).body?.id)throw new Error("Could not add comment to pull request")}async addInlineCommentToPullRequest(r,e={}){let{pullRequest:t,comment:n,path:o,line:i,side:a="RIGHT",threadId:u}=r;if(!n?.trim())throw new Error("GitLab requires a comment when adding an inline comment to a pull request.");let l=`${t.repository.owner.login}/${t.repository.name}`,p=encodeURIComponent(l),c=A(this.config,e),d={...f(e.token||this.config.token),"Content-Type":"application/json"};if(u){let v=await this.config.request({method:"POST",url:`${c}/projects/${p}/merge_requests/${t.number}/discussions/${encodeURIComponent(u)}/notes`,headers:d,body:JSON.stringify({body:n})});return v.body?.id!=null?sr(t.repository.owner.login,t.repository.name,t.number,v.body.id):void 0}if(!o?.trim())throw new Error("GitLab requires a file path when adding an inline comment to a pull request.");if(!Number.isInteger(i)||i<1)throw new Error("GitLab requires a positive line number when adding an inline comment to a pull request.");if(a!=="LEFT"&&a!=="RIGHT")throw new Error('GitLab requires side to be either "LEFT" or "RIGHT".');let m=(await this.config.request({url:`${c}/projects/${p}/merge_requests/${t.number}`,headers:f(e.token||this.config.token)})).body?.diff_refs;if(!m?.base_sha||!m?.start_sha||!m?.head_sha)throw new Error("Could not resolve merge request diff refs required to create an inline comment");let I={position_type:"text",base_sha:m.base_sha,start_sha:m.start_sha,head_sha:m.head_sha,new_path:o,old_path:o};a==="RIGHT"?I.new_line=i:I.old_line=i;let h=(await this.config.request({method:"POST",url:`${c}/projects/${p}/merge_requests/${t.number}/discussions`,headers:d,body:JSON.stringify({body:n,position:I})})).body?.notes?.[0]?.id;return h!=null?sr(t.repository.owner.login,t.repository.name,t.number,h):void 0}getNoteUrl(r,e){if(!r)throw new Error('GitLab requires "commentId" for this function.');let{namespace:t,name:n,mergeRequestIid:o,noteId:i}=no(r);return`${A(this.config,e)}/projects/${encodeURIComponent(`${t}/${n}`)}/merge_requests/${o}/notes/${i}`}async deleteNote(r,e){await this.config.request({method:"DELETE",url:this.getNoteUrl(r,e),headers:f(e.token||this.config.token)})}async deleteComment(r,e={}){await this.deleteNote(r.commentId,e)}async deleteInlineComment(r,e={}){await this.deleteNote(r.commentId,e)}async editNote(r,e,t){if(!e?.trim())throw new Error("GitLab requires a body when editing a comment.");if(!(await this.config.request({method:"PUT",url:this.getNoteUrl(r,t),headers:{...f(t.token||this.config.token),"Content-Type":"application/json"},body:JSON.stringify({body:e})})).body?.id)throw new Error("Could not edit comment")}async editComment(r,e={}){await this.editNote(r.commentId,r.body,e)}async editInlineComment(r,e={}){await this.editNote(r.commentId,r.body,e)}async resolveReviewThread(r,e={}){await this.setReviewThreadResolved(r,!0,e)}async unresolveReviewThread(r,e={}){await this.setReviewThreadResolved(r,!1,e)}async setReviewThreadResolved(r,e,t){if(!r.repo||r.pullRequestNumber==null)throw new Error("GitLab requires input.repo and input.pullRequestNumber to locate the discussion to (un)resolve.");if(!r.threadId)throw new Error("GitLab requires input.threadId to (un)resolve a discussion.");let n=G(r.repo),o=new URL(`${A(this.config,t)}/projects/${encodeURIComponent(n)}/merge_requests/${r.pullRequestNumber}/discussions/${encodeURIComponent(r.threadId)}`);o.searchParams.set("resolved",e?"true":"false"),await this.config.request({url:o.toString(),method:"PUT",headers:f(t.token||this.config.token)})}async approvePullRequest(r,e={}){let{pullRequest:t,comment:n}=r,o=`${t.repository.owner.login}/${t.repository.name}`,i=A(this.config,e),a=encodeURIComponent(o),u=f(e.token||this.config.token);await this.config.request({url:`${i}/projects/${a}/merge_requests/${t.number}/approve`,method:"POST",headers:u}),n&&n.trim()!==""&&await this.postMergeRequestNote(o,t.number,n,e)}async commentOnPullRequest(r,e={}){let{pullRequest:t,comment:n}=r;if(!n||n.trim()==="")throw new Error("GitLab requires a comment when commenting on a pull request.");let o=`${t.repository.owner.login}/${t.repository.name}`;await this.postMergeRequestNote(o,t.number,n,e)}async requestPullRequestChanges(r,e={}){let{pullRequest:t,comment:n}=r;if(!n||n.trim()==="")throw new Error("GitLab requires a comment when requesting changes on a pull request.");let o=`${t.repository.owner.login}/${t.repository.name}`;if(!await this.tryRequestChangesMutation(o,t.number,e)){let u=`${A(this.config,e)}/projects/${encodeURIComponent(o)}/merge_requests/${t.number}`,l=f(e.token||this.config.token);(await this.config.request({url:`${u}/approvals`,method:"GET",headers:l})).body?.user_has_approved&&await this.config.request({url:`${u}/unapprove`,method:"POST",headers:l})}await this.postMergeRequestNote(o,t.number,n,e)}async tryRequestChangesMutation(r,e,t){let n=`mutation MergeRequestRequestChanges($fullPath: ID!, $pullRequestId: String!) {
|
|
1362
1362
|
mergeRequestRequestChanges(input: { projectPath: $fullPath, iid: $pullRequestId }) {
|
|
1363
1363
|
errors
|
|
1364
1364
|
mergeRequest {
|
|
@@ -1591,4 +1591,4 @@ OR comment ~ currentUser() OR summary ~ currentUser() OR description ~ currentUs
|
|
|
1591
1591
|
${at}
|
|
1592
1592
|
}
|
|
1593
1593
|
}
|
|
1594
|
-
`,c=(await this.rawRequest(e,l,{first:bs,after:i})).data?.issues;return c?{data:await Tt(c.nodes.map(hr)),pageInfo:{hasNextPage:c.pageInfo.hasNextPage,endCursor:c.pageInfo.endCursor??null}}:{data:[],pageInfo:{hasNextPage:!1,endCursor:null}}}};var V="https://api.trello.com",vo=1e3,K=(s,r)=>({...f(r),Authorization:`OAuth oauth_consumer_key="${s}", oauth_token="${r}"`}),Eo=s=>({id:s.id,username:s.username,url:s.url,name:s.fullName,email:s.email,avatarUrl:s.avatarUrl}),So=(s,r)=>{let e=new Date(1e3*parseInt(s.id.substring(0,8),16));return{id:s.id,commentCount:s.badges.comments,number:s.idShort.toString(),title:s.name,url:s.url,closedDate:null,createdDate:new Date(e.toISOString()),author:null,updatedDate:new Date(s.dateLastActivity),assignees:s.members.map(t=>({id:t.id,username:t.username,name:t.fullName,email:null,avatarUrl:t.avatarUrl,url:null})),description:null,state:r[s.idList??""]?{id:s.idList,name:r[s.idList].name,color:null}:null,type:null,repository:null,upvoteCount:s.badges.votes,labels:s.labels.map(t=>({color:t.color,description:null,id:t.id,name:t.name}))}},we=class extends F{async getCurrentUser(r,e={}){let t=await this.config.request({url:`${e.baseUrl||V}/1/members/me`,headers:K(r.appKey,e.token||this.config.token)});return{data:{name:t.body.fullName,email:t.body.email,avatarUrl:t.body.avatarHash?`https://trello-members.s3.amazonaws.com/${t.body.id}/${t.body.avatarHash}/50.png`:null,id:t.body.id,username:t.body.username,url:t.body.url}}}async getBoardsForCurrentUser(r,e={}){return{data:(await this.config.request({url:`${e.baseUrl||V}/1/members/me/boards?fields=name&filter=open`,headers:K(r.appKey,e.token||this.config.token)})).body.map(n=>({id:n.id,name:n.name}))}}async getListsForTrelloBoard(r,e={}){let{appKey:t,boardId:n}=r;return{data:(await this.config.request({url:`${e.baseUrl||V}/1/boards/${n}/lists`,headers:K(t,e.token||this.config.token)})).body}}async getAccountForId(r,e={}){let{appKey:t,memberId:n}=r,o=await this.config.request({url:`${e.baseUrl||V}/1/members/${n}`,headers:K(t,e.token||this.config.token)});return{data:Eo(o.body)}}async getAccountsForTrelloBoard(r,e={}){let{appKey:t,boardId:n}=r;return{data:(await this.config.request({url:`${e.baseUrl||V}/1/boards/${n}/members`,headers:K(t,e.token||this.config.token)})).body.map(i=>({id:i.id,name:i.fullName,username:i.username,email:null,avatarUrl:null,url:null}))}}async getIssuesForBoard(r,e={}){let t=["-is:archived","sort:edited"],{appKey:n,boardId:o,filterText:i,assigneeLogins:a,labelNamesOrColors:u,trelloBoardListsById:l}=r||{};a&&t.push("@me"),u&&u.forEach(d=>t.push(`label:"${d}"`));let p=`${i?`${i}`:""}${t.join(" ")} board:${o}`;return{data:(await this.config.request({url:`${e.baseUrl||V}/1/search?query=${p}&cards_limit=${vo}&card_members=true`,headers:K(n,e.token||this.config.token)})).body.cards.map(d=>So(d,l||{}))}}async updateIssue(r,e,t,n){return await this.config.request({method:"PUT",url:`${n.baseUrl||V}/1/cards/${e.id}?${t}`,headers:K(r,n.token||this.config.token)})}async setIssueStatus(r,e={}){let{appKey:t,issue:n,status:o}=r;if(!o.id)throw new Error('Trello requires a status "id" for this function.');let i=`idList=${o.id}`;if(!(await this.updateIssue(t,n,i,e)).body.id)throw new Error("Could not set issue status")}async setIssueAssignees(r,e={}){let{appKey:t,issue:n,assignees:o}=r,i=o.map(l=>l.id),a=`idMembers=${encodeURIComponent(i.join(","))}`;if(!(await this.updateIssue(t,n,a,e)).body.id)throw new Error("Could not set issue status")}async setIssueLabels(r,e={}){let{appKey:t,issue:n,labels:o}=r,i=o.map(u=>u.id).join(",");if(!(await this.config.request({method:"PUT",url:`${e.baseUrl||V}/1/cards/${n.id}?idLabels=${encodeURIComponent(i)}`,headers:K(t,e.token||this.config.token)})).body.id)throw new Error("Could not set issue status")}async setIssueArchived(r,e={}){let{appKey:t,issue:n,archived:o}=r;if(!(await this.config.request({method:"PUT",url:`${e.baseUrl||V}/1/cards/${n.id}?closed=${o}`,headers:K(t,e.token||this.config.token)})).body.id)throw new Error("Could not update issue archived status")}async archiveIssue(r,e={}){await this.setIssueArchived({...r,archived:!0},e)}async unArchiveIssue(r,e={}){await this.setIssueArchived({...r,archived:!1},e)}async getLabelsForBoard(r,e={}){let{appKey:t,boardId:n}=r;return{data:(await this.config.request({url:`${e.baseUrl||V}/1/boards/${n}/labels`,headers:K(t,e.token||this.config.token)})).body.map(i=>({color:i.color,description:null,id:i.id,name:i.name}))}}};var lt={};z(lt,{default:()=>Co});var Co={};var pt={};z(pt,{default:()=>Do});var Do={};var wt={};z(wt,{decode:()=>Rr,decodeV0:()=>Uo,encode:()=>Lo,validate:()=>Ao});var _=(e=>(e.Zero="0",e.One="1",e))(_||{}),N=(e=>(e.PullRequest="pr",e.Issue="issue",e))(N||{}),x=(d=>(d.Azure="azure",d.AzureDevOpsServer="azureDevOpsServer",d.Github="github",d.GithubEnterprise="githubEnterprise",d.Gitlab="gitlab",d.GitlabSelfHosted="gitlabSelfHosted",d.Bitbucket="bitbucket",d.BitbucketServer="bitbucketServer",d.Jira="jira",d.JiraServer="jiraServer",d.Linear="linear",d.Trello="trello",d))(x||{});var dt=class{constructor(){}validate(r){if(!r.organizationName)throw new Error("organizationName is required");if(!r.projectId)throw new Error("projectId is required");if(!r.entityId)throw new Error("issueId is required")}encode(r){if(this.validate(r),!r.organizationName||!r.projectId||!r.entityId)throw new Error("Missing required fields for Azure DevOps issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="azureDevOpsServer"?e.push(r.domain):e.push(""),e.push(r.organizationName),e.push(r.projectId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<7)throw new Error("Invalid Azure DevOps issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:r[4],projectId:r[5],repoId:null,entityId:r[6]}}};var ct=class{constructor(){}validate(r){if(!r.organizationName)throw new Error("organizationName is required");if(!r.projectId)throw new Error("projectId is required");if(!r.repoId)throw new Error("repoId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.organizationName||!r.projectId||!r.repoId||!r.entityId)throw new Error("Missing required fields for Azure DevOps pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="azureDevOpsServer"?e.push(r.domain):e.push(""),e.push(r.organizationName),e.push(r.projectId),e.push(r.repoId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<8)throw new Error("Invalid Azure DevOps pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:r[4],projectId:r[5],repoId:r[6],entityId:r[7]}}};var mt=class{constructor(){}validate(r){if(!r.repoId)throw new Error("repoId is required");if(!r.entityId)throw new Error("issueId is required")}encode(r){if(this.validate(r),!r.repoId||!r.entityId)throw new Error("Missing required fields for Bitbucket DevOps issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="bitbucketServer"?e.push(r.domain):e.push(""),e.push(r.repoId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<6)throw new Error("Invalid Bitbucket DevOps issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:r[4],entityId:r[5]}}};var gt=class{constructor(){}validate(r){if(!r.repoId)throw new Error("repoId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.repoId||!r.entityId)throw new Error("Missing required fields for Bitbucket DevOps pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="bitbucketServer"?e.push(r.domain):e.push(""),e.push(r.repoId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<6)throw new Error("Invalid Bitbucket DevOps pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:r[4],entityId:r[5]}}};var ht=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Github issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="githubEnterprise"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Github issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var ft=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Github pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="githubEnterprise"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Github pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var Rt=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Gitlab issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="gitlabSelfHosted"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Gitlab issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var It=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Gitlab pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="gitlabSelfHosted"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Gitlab pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var bt=class{constructor(){}validate(r){if(!r.projectId)throw new Error("projectId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.projectId||!r.entityId)throw new Error("Missing required fields for Jira issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider=="jira"?(e.push(""),e.push(r.resourceId)):(e.push(r.domain),e.push("")),e.push(r.projectId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<7)throw new Error("Invalid Jira issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:r[4]==""?null:r[4],accountOrOrgId:null,organizationName:null,projectId:r[5],repoId:null,entityId:r[6]}}};var yt=class{constructor(){}validate(r){if(!r.accountOrOrgId)throw new Error("accountOrOrgId is required");if(!r.projectId)throw new Error("projectId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.accountOrOrgId||!r.projectId||!r.entityId)throw new Error("Missing required fields for Trello issue uniqueId");let e=[];return e.push("trello"),e.push("issue"),e.push("1"),e.push(""),e.push(r.accountOrOrgId),e.push(r.projectId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<7)throw new Error("Invalid Trello issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:r[4],organizationName:null,projectId:r[5],repoId:null,entityId:r[6]}}};var Pt=(s,r)=>{if(r!=="issue"&&r!=="pr")throw new Error("unknown entityType");switch(s){case"azure":case"azureDevOpsServer":return r==="pr"?new ct:new dt;case"bitbucket":case"bitbucketServer":return r==="pr"?new gt:new mt;case"github":case"githubEnterprise":return r==="pr"?new ft:new ht;case"gitlab":case"gitlabSelfHosted":return r==="pr"?new It:new Rt;case"jira":case"jiraServer":if(r==="pr")throw new Error("EntityType PullRequest is not valid for Jira");return new bt;case"trello":if(r==="pr")throw new Error("EntityType PullRequest is not valid for Jira");return new yt;default:throw new Error("unknown provider")}},$o=s=>{if(!s.entityType)throw new Error("entityType is required");if(!s.provider)throw new Error("provider is required");if(!s.entityId)throw new Error("entityID is required")},Ao=s=>{if(s.version==="0"){$o(s);return}Pt(s.provider,s.entityType).validate(s)},Lo=s=>Pt(s.provider,s.entityType).encode(s),Rr=s=>{let r=JSON.parse(s);if(!r||!r.length)throw new Error("invalid issue unique id");return Pt(r[0],r[1]).decode(r)},Uo=(s,r,e)=>{if(!e)throw new Error("entityID is required");try{let t=JSON.parse(e);if(!t||!t.length)throw new Error("Invalid pull request uniqueId");let n=[s,r,"0",...t];return Pt(s,r).decode(n)}catch{return{provider:s,entityType:r,version:"0",domain:"",resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:e}}};var qt={};z(qt,{CHANGES_REQUESTED_ACTION_CATEGORY:()=>Ds,CHANGES_REQUESTED_BUCKET_ID:()=>vr,CONFLICTS_ACTION_CATEGORY:()=>Ss,CONFLICTS_BUCKET_ID:()=>wr,DRAFT_ACTION_CATEGORY:()=>Ls,DRAFT_BUCKET_ID:()=>Cr,FAILING_CI_ACTION_CATEGORY:()=>Es,FAILING_CI_BUCKET_ID:()=>Pr,NEEDS_MY_REVIEW_ACTION_CATEGORY:()=>Cs,NEEDS_MY_REVIEW_BUCKET_ID:()=>qr,OTHER_ACTION_CATEGORY:()=>Us,OTHER_BUCKET_ID:()=>Dr,PINNED_BUCKET_ID:()=>Ir,READY_TO_MERGE_ACTION_CATEGORY:()=>qs,READY_TO_MERGE_BUCKET_ID:()=>br,REVIEWER_COMMENTED_ACTION_CATEGORY:()=>$s,REVIEWER_COMMENTED_BUCKET_ID:()=>Er,SNOOZED_BUCKET_ID:()=>$r,UNASSIGNED_REVIEWERS_ACTION_CATEGORY:()=>vs,UNASSIGNED_REVIEWERS_BUCKET_ID:()=>yr,WAITING_FOR_REVIEW_ACTION_CATEGORY:()=>As,WAITING_FOR_REVIEW_BUCKET_ID:()=>Sr,getActionablePullRequests:()=>Ts,groupPullRequestsByAssignee:()=>Oo,groupPullRequestsByAuthor:()=>xo,groupPullRequestsByGitKrakenTeam:()=>jo,groupPullRequestsByRepo:()=>Go,groupPullRequestsByReviewer:()=>ko,groupPullRequestsByWorkspace:()=>No,groupPullRequestsIntoBuckets:()=>To});var Q=(s,r,e,t)=>({id:s,faIconName:e,name:r,priority:t,pullRequests:[]}),Ir="pinned",br="readyToMerge",yr="unassignedReviewers",Pr="failingCI",wr="conflicts",qr="needsMyReview",vr="changesRequested",Er="reviewerCommented",Sr="waitingForReview",Cr="draft",Dr="other",$r="snoozed",qs="readyToMerge",vs="unassignedReviewers",Es="failingCI",Ss="conflicts",Cs="needsMyReview",Ds="changesRequested",$s="reviewerCommented",As="waitingForReview",Ls="draft",Us="other",Ts=(s,r,e)=>s.map(t=>{let o={...t,...{suggestedActionCategory:Us,priority:1e3,viewer:{canMerge:!1,isAuthor:!1,isAssignee:!1,isReviewer:!1,shouldMerge:!1,shouldAssignReviewer:!1,waitingOnReviews:!1,shouldReview:!1},failingCI:!1,hasConflicts:!1,changeRequestReviewCount:0,codeSuggestionsCount:0,commentReviewCount:0,approvalReviewCount:0}};r&&(o.viewer.isAuthor=t.author?.id===r.id,o.viewer.isAssignee=t.assignees?.some(u=>u.id===r.id)??!1,o.viewer.isReviewer=t.reviews?.some(u=>u.reviewer.id===r.id)??!1),o.viewer.canMerge=t.permissions?.canMerge??!0,o.hasConflicts=t.mergeableState==="CONFLICTS",o.failingCI=t.headCommit?.buildStatuses?.some(u=>u.state==="ERROR"||u.state==="FAILED")||t.mergeableState==="FAILING_CHECKS",o.commentReviewCount=t.reviews?.filter(u=>u.state==="COMMENTED").length??0,o.approvalReviewCount=t.reviews?.filter(u=>u.state==="APPROVED").length??0,o.changeRequestReviewCount=t.reviews?.filter(u=>u.state==="CHANGES_REQUESTED").length??0;let i=e?.enrichedItemsByUniqueId?.[t.uuid];i!=null&&(o.viewer.enrichedItems=i,i.some(u=>u.type==="pin")&&(o.viewer.pinned=!0,o.priority-=800),i.some(u=>u.type==="snooze")&&(o.viewer.snoozed=!0));let a=e?.codeSuggestionsCountByPrUuid?.[t.uuid]?.count||0;return a&&(o.codeSuggestionsCount=a),(!r||o.viewer.isAuthor||o.viewer.isAssignee&&!o.viewer.isReviewer)&&o.viewer.canMerge&&!o.isDraft&&!o.failingCI&&t.mergeableState==="MERGEABLE"&&(o.viewer.shouldMerge=!0,o.suggestedActionCategory=qs),(!r||o.viewer.isAuthor)&&t.isDraft&&(o.suggestedActionCategory=Ls),(!r||o.viewer.isAuthor)&&t.reviewDecision==="REVIEW_REQUESTED"&&(o.suggestedActionCategory=As,o.viewer.waitingOnReviews=!0),(!r||o.viewer.isAuthor)&&t.reviewDecision==="COMMENTED"&&(o.suggestedActionCategory=$s),(!r||o.viewer.isAuthor)&&o.failingCI&&(o.suggestedActionCategory=Es),(!r||o.viewer.isAuthor)&&o.hasConflicts&&(o.suggestedActionCategory=Ss),(!r||o.viewer.isAuthor)&&(t.reviewDecision==="CHANGES_REQUESTED"||o.codeSuggestionsCount>0)&&(o.suggestedActionCategory=Ds),(!r||o.viewer.isAuthor)&&!t.reviews?.length&&(o.suggestedActionCategory=vs,o.viewer.shouldAssignReviewer=!0),r&&t.reviews?.some(u=>u.reviewer.id===r.id&&u.state==="REVIEW_REQUESTED")&&(o.suggestedActionCategory=Cs,o.viewer.shouldReview=!0),o}),To=(s,r,e)=>{let t={pinned:Q(Ir,"Pinned","thumbtack",e?.bucketPriorityOverride?.pinned??-1),readyToMerge:Q(br,"Ready to Merge","code-merge",e?.bucketPriorityOverride?.readyToMerge??0),unassignedReviewers:Q(yr,"Unassigned Reviewers","user-plus",e?.bucketPriorityOverride?.unassignedReviewers??1),failingCI:Q(Pr,"Failing CI","circle-x",e?.bucketPriorityOverride?.failingCI??2),conflicts:Q(wr,"Resolve Conflicts","triangle-exclamation",e?.bucketPriorityOverride?.conflicts??3),needsMyReview:Q(qr,"Needs My Review","eye",e?.bucketPriorityOverride?.needsMyReview??4),changesRequested:Q(vr,"Suggested Changes","file-plus",e?.bucketPriorityOverride?.changesRequested??5),reviewerCommented:Q(Er,"Reviewer Commented","comment",e?.bucketPriorityOverride?.reviewerCommented??6),waitingForReview:Q(Sr,"Waiting for Review","circle-pause",e?.bucketPriorityOverride?.waitingForReview??7),draft:Q(Cr,"Draft","compass-drafting",e?.bucketPriorityOverride?.draft??8),other:Q(Dr,"Other","ellipsis",e?.bucketPriorityOverride?.other??9),snoozed:Q($r,"Snoozed","snooze",e?.bucketPriorityOverride?.snoozed??10)},o=Ts(s,r,e).reduce((i,a)=>(i[a.uuid]=a,i),{});return s.forEach(i=>{let a=o[i.uuid],u=!0;if(a.viewer.snoozed){t[$r].pullRequests.push(i);return}a.viewer.pinned&&t[Ir].pullRequests.push(i),(!r||a.viewer.isAuthor||a.viewer.isAssignee&&!a.viewer.isReviewer)&&!a.isDraft&&a.viewer.canMerge&&a.mergeableState==="MERGEABLE"&&(t[br].pullRequests.push(i),u=!1),a.viewer.shouldAssignReviewer&&(t[yr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.failingCI&&(t[Pr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.hasConflicts&&(t[wr].pullRequests.push(i),u=!1),a.viewer.shouldReview&&(t[qr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&(a.reviewDecision==="CHANGES_REQUESTED"||a.codeSuggestionsCount>0)&&(t[vr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.reviewDecision==="COMMENTED"&&(t[Er].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.reviewDecision==="REVIEW_REQUESTED"&&(t[Sr].pullRequests.push(i),u=!1),a.isDraft&&(t[Cr].pullRequests.push(i),u=!1),u&&t[Dr].pullRequests.push(i)}),Object.values(t).forEach(i=>{i.pullRequests.sort((a,u)=>o[a.uuid].priority-o[u.uuid].priority)}),t},Go=s=>{let r={};return s.forEach(e=>{let t=e.repository.id;r[t]?r[t].pullRequests.push(e):r[t]={name:e.repository.name,priority:0,pullRequests:[e],id:t}}),ue(r)},Oo=s=>{let r="internal-no-assignees",e={[r]:{name:"No assignees",priority:-1,pullRequests:[],id:r,faIconName:"user-slash"}};return s.forEach(t=>{t.assignees&&t.assignees.length?t.assignees.forEach(n=>{let o=n.id;e[o]?e[o].pullRequests.push(t):e[o]={accountData:n,name:Te(n,`Unknown Assignee ${Object.keys(e).length}`),priority:0,pullRequests:[t],id:o}}):e[r].pullRequests.push(t)}),ue(e)},xo=s=>{let r="internal-no-author",e={[r]:{name:"No author",priority:-1,pullRequests:[],id:r,faIconName:"user-slash"}};return s.forEach(t=>{if(t.author){let n=t.author.id;e[n]?e[n].pullRequests.push(t):e[n]={accountData:t.author,name:Te(t.author,`Unknown Author ${Object.keys(e).length}`),priority:0,pullRequests:[t],id:n}}else e[r].pullRequests.push(t)}),ue(e)},ko=s=>{let r="internal-no-reviewer",e={[r]:{name:"No reviewers",priority:-1,pullRequests:[],id:r,faIconName:"user-slash"}};return s.forEach(t=>{t.reviews&&t.reviews.length?t.reviews.forEach(n=>{let o=n.reviewer.id;e[o]?e[o].pullRequests.push(t):e[o]={accountData:n.reviewer,name:Te(n.reviewer,`Unknown Reviewer ${Object.keys(e).length}`),priority:0,pullRequests:[t],id:o}}):e[r].pullRequests.push(t)}),ue(e)},_o=s=>s.azureProject?[`${s.azureProject}-${s.azureOrganizationId}`]:s.providerData?.repositories.nodes.map(r=>`${s.provider}-${r.repositoryId}`)??[],No=(s,r)=>{let e="internal-no-workspace",t={[e]:{name:"No workspace",priority:-1,pullRequests:[],id:e,faIconName:"folder-xmark"}};if(r.length){let n=r.reduce((o,i)=>(_o(i).forEach(u=>{o[u]?o[u].push(i):o[u]=[i]}),o),{});s.forEach(o=>{let{provider:i}=Rr(o.uuid),a=i==="github"?o.repository.graphQLId:o.repository.id,u=i==="azure"?[`${i}-${a}`,`${o.repository.project}-${o.repository.owner.login}`]:[`${i}-${a}`],l=!1,p=u.reduce((c,d)=>n[d]?c.concat(n[d]):c,[]);p?.length&&p.forEach(c=>{l=!0;let d=c.id;t[d]?t[d].pullRequests.push(o):t[d]={name:c.name,priority:0,pullRequests:[o],id:d,faIconName:"folder"}}),l||t[e].pullRequests.push(o)})}else t[e].pullRequests=s;return ue(t)},jo=(s,r,e,t)=>{let n="internal-no-team",o={[n]:{name:"No team",priority:-1,pullRequests:[],id:n}};return t.length?s.forEach(i=>{let a=!1,u=new Set;u.add(i.author?.id),i.assignees?.forEach(l=>u.add(l.id)),i.reviews?.forEach(l=>u.add(l.reviewer.id)),t.forEach(l=>{if(l.members?.some(c=>{let d=r[c.id]?.[e]?.providerID;return d&&u.has(d)})){a=!0;let c=l.id;o[c]?o[c].pullRequests.push(i):o[c]={name:l.name,priority:0,pullRequests:[i],id:c,teamData:l}}}),a||o[n].pullRequests.push(i)}):o[n].pullRequests=s,ue(o)};var vt={};z(vt,{getPullRequestRank:()=>Bo});var Bo=(s,r,e)=>{let t=0,n,o;return s.reviews?.forEach(i=>{i.reviewer.id===r&&(n=i.state),i.state==="CHANGES_REQUESTED"?o="CHANGES_REQUESTED":i.state==="APPROVED"&&o!=="CHANGES_REQUESTED"&&(o="APPROVED")}),o||(o="REVIEW_REQUESTED"),s.author?.id===r?t+=1e3:s.assignees?.find(i=>i.id===r)?t+=900:n==="REVIEW_REQUESTED"?t+=800:e&&(t+=700),o==="APPROVED"?s.mergeableState==="MERGEABLE"?t+=100:s.mergeableState==="CONFLICTS"?t+=90:t+=80:o=="CHANGES_REQUESTED"&&(t+=70),t};var Et={};z(Et,{default:()=>Qo});var Qo={};var St={};z(St,{default:()=>Fo});var Fo={};var Ct={};z(Ct,{default:()=>Mo});var Mo={};var Gs=s=>{let r={request:s?.request};return{azureDevOps:new me({...r,...s?.azureDevOps}),bitbucket:new ge({...r,...s?.bitbucket}),bitbucketServer:new he({...r,...s?.bitbucketServer}),github:new fe({...r,...s?.github}),gitlab:new Ie({...r,...s?.gitlab}),jira:new be({...r,...s?.jira}),jiraServer:new ye({...r,...s?.jiraServer}),linear:new Pe({...r,...s?.linear}),trello:new we({...r,...s?.trello})}};var Os=(i=>(i.Conflicts="conflicts",i.Failure="failure",i.NotSet="notSet",i.Queued="queued",i.RejectedByPolicy="rejectedByPolicy",i.Succeeded="succeeded",i))(Os||{});var xs=(e=>(e.Completed="COMPLETED",e.NotPlanned="NOT_PLANNED",e))(xs||{});var zo=Gs;var Wo={azureDevOps:lt,bitbucket:pt,bitbucketServer:_e,github:vt,gitlab:Et,gitProvider:qt,jira:St,trello:Ct,entityIdentifier:wt};
|
|
1594
|
+
`,c=(await this.rawRequest(e,l,{first:bs,after:i})).data?.issues;return c?{data:await Tt(c.nodes.map(hr)),pageInfo:{hasNextPage:c.pageInfo.hasNextPage,endCursor:c.pageInfo.endCursor??null}}:{data:[],pageInfo:{hasNextPage:!1,endCursor:null}}}};var K="https://api.trello.com",vo=1e3,X=(s,r)=>({...f(r),Authorization:`OAuth oauth_consumer_key="${s}", oauth_token="${r}"`}),Eo=s=>({id:s.id,username:s.username,url:s.url,name:s.fullName,email:s.email,avatarUrl:s.avatarUrl}),So=(s,r)=>{let e=new Date(1e3*parseInt(s.id.substring(0,8),16));return{id:s.id,commentCount:s.badges.comments,number:s.idShort.toString(),title:s.name,url:s.url,closedDate:null,createdDate:new Date(e.toISOString()),author:null,updatedDate:new Date(s.dateLastActivity),assignees:s.members.map(t=>({id:t.id,username:t.username,name:t.fullName,email:null,avatarUrl:t.avatarUrl,url:null})),description:null,state:r[s.idList??""]?{id:s.idList,name:r[s.idList].name,color:null}:null,type:null,repository:null,upvoteCount:s.badges.votes,labels:s.labels.map(t=>({color:t.color,description:null,id:t.id,name:t.name}))}},we=class extends F{async getCurrentUser(r,e={}){let t=await this.config.request({url:`${e.baseUrl||K}/1/members/me`,headers:X(r.appKey,e.token||this.config.token)});return{data:{name:t.body.fullName,email:t.body.email,avatarUrl:t.body.avatarHash?`https://trello-members.s3.amazonaws.com/${t.body.id}/${t.body.avatarHash}/50.png`:null,id:t.body.id,username:t.body.username,url:t.body.url}}}async getBoardsForCurrentUser(r,e={}){return{data:(await this.config.request({url:`${e.baseUrl||K}/1/members/me/boards?fields=name&filter=open`,headers:X(r.appKey,e.token||this.config.token)})).body.map(n=>({id:n.id,name:n.name}))}}async getListsForTrelloBoard(r,e={}){let{appKey:t,boardId:n}=r;return{data:(await this.config.request({url:`${e.baseUrl||K}/1/boards/${n}/lists`,headers:X(t,e.token||this.config.token)})).body}}async getAccountForId(r,e={}){let{appKey:t,memberId:n}=r,o=await this.config.request({url:`${e.baseUrl||K}/1/members/${n}`,headers:X(t,e.token||this.config.token)});return{data:Eo(o.body)}}async getAccountsForTrelloBoard(r,e={}){let{appKey:t,boardId:n}=r;return{data:(await this.config.request({url:`${e.baseUrl||K}/1/boards/${n}/members`,headers:X(t,e.token||this.config.token)})).body.map(i=>({id:i.id,name:i.fullName,username:i.username,email:null,avatarUrl:null,url:null}))}}async getIssuesForBoard(r,e={}){let t=["-is:archived","sort:edited"],{appKey:n,boardId:o,filterText:i,assigneeLogins:a,labelNamesOrColors:u,trelloBoardListsById:l}=r||{};a&&t.push("@me"),u&&u.forEach(d=>t.push(`label:"${d}"`));let p=`${i?`${i}`:""}${t.join(" ")} board:${o}`;return{data:(await this.config.request({url:`${e.baseUrl||K}/1/search?query=${p}&cards_limit=${vo}&card_members=true`,headers:X(n,e.token||this.config.token)})).body.cards.map(d=>So(d,l||{}))}}async updateIssue(r,e,t,n){return await this.config.request({method:"PUT",url:`${n.baseUrl||K}/1/cards/${e.id}?${t}`,headers:X(r,n.token||this.config.token)})}async setIssueStatus(r,e={}){let{appKey:t,issue:n,status:o}=r;if(!o.id)throw new Error('Trello requires a status "id" for this function.');let i=`idList=${o.id}`;if(!(await this.updateIssue(t,n,i,e)).body.id)throw new Error("Could not set issue status")}async setIssueAssignees(r,e={}){let{appKey:t,issue:n,assignees:o}=r,i=o.map(l=>l.id),a=`idMembers=${encodeURIComponent(i.join(","))}`;if(!(await this.updateIssue(t,n,a,e)).body.id)throw new Error("Could not set issue status")}async setIssueLabels(r,e={}){let{appKey:t,issue:n,labels:o}=r,i=o.map(u=>u.id).join(",");if(!(await this.config.request({method:"PUT",url:`${e.baseUrl||K}/1/cards/${n.id}?idLabels=${encodeURIComponent(i)}`,headers:X(t,e.token||this.config.token)})).body.id)throw new Error("Could not set issue status")}async setIssueArchived(r,e={}){let{appKey:t,issue:n,archived:o}=r;if(!(await this.config.request({method:"PUT",url:`${e.baseUrl||K}/1/cards/${n.id}?closed=${o}`,headers:X(t,e.token||this.config.token)})).body.id)throw new Error("Could not update issue archived status")}async archiveIssue(r,e={}){await this.setIssueArchived({...r,archived:!0},e)}async unArchiveIssue(r,e={}){await this.setIssueArchived({...r,archived:!1},e)}async getLabelsForBoard(r,e={}){let{appKey:t,boardId:n}=r;return{data:(await this.config.request({url:`${e.baseUrl||K}/1/boards/${n}/labels`,headers:X(t,e.token||this.config.token)})).body.map(i=>({color:i.color,description:null,id:i.id,name:i.name}))}}};var lt={};z(lt,{default:()=>Co});var Co={};var pt={};z(pt,{default:()=>Do});var Do={};var wt={};z(wt,{decode:()=>Rr,decodeV0:()=>Uo,encode:()=>Lo,validate:()=>Ao});var _=(e=>(e.Zero="0",e.One="1",e))(_||{}),N=(e=>(e.PullRequest="pr",e.Issue="issue",e))(N||{}),k=(d=>(d.Azure="azure",d.AzureDevOpsServer="azureDevOpsServer",d.Github="github",d.GithubEnterprise="githubEnterprise",d.Gitlab="gitlab",d.GitlabSelfHosted="gitlabSelfHosted",d.Bitbucket="bitbucket",d.BitbucketServer="bitbucketServer",d.Jira="jira",d.JiraServer="jiraServer",d.Linear="linear",d.Trello="trello",d))(k||{});var dt=class{constructor(){}validate(r){if(!r.organizationName)throw new Error("organizationName is required");if(!r.projectId)throw new Error("projectId is required");if(!r.entityId)throw new Error("issueId is required")}encode(r){if(this.validate(r),!r.organizationName||!r.projectId||!r.entityId)throw new Error("Missing required fields for Azure DevOps issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="azureDevOpsServer"?e.push(r.domain):e.push(""),e.push(r.organizationName),e.push(r.projectId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<7)throw new Error("Invalid Azure DevOps issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:r[4],projectId:r[5],repoId:null,entityId:r[6]}}};var ct=class{constructor(){}validate(r){if(!r.organizationName)throw new Error("organizationName is required");if(!r.projectId)throw new Error("projectId is required");if(!r.repoId)throw new Error("repoId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.organizationName||!r.projectId||!r.repoId||!r.entityId)throw new Error("Missing required fields for Azure DevOps pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="azureDevOpsServer"?e.push(r.domain):e.push(""),e.push(r.organizationName),e.push(r.projectId),e.push(r.repoId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<8)throw new Error("Invalid Azure DevOps pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:r[4],projectId:r[5],repoId:r[6],entityId:r[7]}}};var mt=class{constructor(){}validate(r){if(!r.repoId)throw new Error("repoId is required");if(!r.entityId)throw new Error("issueId is required")}encode(r){if(this.validate(r),!r.repoId||!r.entityId)throw new Error("Missing required fields for Bitbucket DevOps issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="bitbucketServer"?e.push(r.domain):e.push(""),e.push(r.repoId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<6)throw new Error("Invalid Bitbucket DevOps issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:r[4],entityId:r[5]}}};var gt=class{constructor(){}validate(r){if(!r.repoId)throw new Error("repoId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.repoId||!r.entityId)throw new Error("Missing required fields for Bitbucket DevOps pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="bitbucketServer"?e.push(r.domain):e.push(""),e.push(r.repoId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<6)throw new Error("Invalid Bitbucket DevOps pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:r[4],entityId:r[5]}}};var ht=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Github issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="githubEnterprise"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Github issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var ft=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Github pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="githubEnterprise"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Github pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var Rt=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Gitlab issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider==="gitlabSelfHosted"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Gitlab issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var It=class{constructor(){}validate(r){if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.entityId)throw new Error("Missing required fields for Gitlab pull request uniqueId");let e=[];return e.push(r.provider),e.push("pr"),e.push("1"),r.provider==="gitlabSelfHosted"?e.push(r.domain):e.push(""),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<5)throw new Error("Invalid Gitlab pull request uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:r[4]}}};var bt=class{constructor(){}validate(r){if(!r.projectId)throw new Error("projectId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.projectId||!r.entityId)throw new Error("Missing required fields for Jira issue uniqueId");let e=[];return e.push(r.provider),e.push("issue"),e.push("1"),r.provider=="jira"?(e.push(""),e.push(r.resourceId)):(e.push(r.domain),e.push("")),e.push(r.projectId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<7)throw new Error("Invalid Jira issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:r[4]==""?null:r[4],accountOrOrgId:null,organizationName:null,projectId:r[5],repoId:null,entityId:r[6]}}};var yt=class{constructor(){}validate(r){if(!r.accountOrOrgId)throw new Error("accountOrOrgId is required");if(!r.projectId)throw new Error("projectId is required");if(!r.entityId)throw new Error("entityId is required")}encode(r){if(this.validate(r),!r.accountOrOrgId||!r.projectId||!r.entityId)throw new Error("Missing required fields for Trello issue uniqueId");let e=[];return e.push("trello"),e.push("issue"),e.push("1"),e.push(""),e.push(r.accountOrOrgId),e.push(r.projectId),e.push(r.entityId),JSON.stringify(e)}decode(r){if(r.length<7)throw new Error("Invalid Trello issue uniqueId, check version");return{provider:r[0],entityType:r[1],version:r[2],domain:r[3]==""?null:r[3],resourceId:null,accountOrOrgId:r[4],organizationName:null,projectId:r[5],repoId:null,entityId:r[6]}}};var Pt=(s,r)=>{if(r!=="issue"&&r!=="pr")throw new Error("unknown entityType");switch(s){case"azure":case"azureDevOpsServer":return r==="pr"?new ct:new dt;case"bitbucket":case"bitbucketServer":return r==="pr"?new gt:new mt;case"github":case"githubEnterprise":return r==="pr"?new ft:new ht;case"gitlab":case"gitlabSelfHosted":return r==="pr"?new It:new Rt;case"jira":case"jiraServer":if(r==="pr")throw new Error("EntityType PullRequest is not valid for Jira");return new bt;case"trello":if(r==="pr")throw new Error("EntityType PullRequest is not valid for Jira");return new yt;default:throw new Error("unknown provider")}},$o=s=>{if(!s.entityType)throw new Error("entityType is required");if(!s.provider)throw new Error("provider is required");if(!s.entityId)throw new Error("entityID is required")},Ao=s=>{if(s.version==="0"){$o(s);return}Pt(s.provider,s.entityType).validate(s)},Lo=s=>Pt(s.provider,s.entityType).encode(s),Rr=s=>{let r=JSON.parse(s);if(!r||!r.length)throw new Error("invalid issue unique id");return Pt(r[0],r[1]).decode(r)},Uo=(s,r,e)=>{if(!e)throw new Error("entityID is required");try{let t=JSON.parse(e);if(!t||!t.length)throw new Error("Invalid pull request uniqueId");let n=[s,r,"0",...t];return Pt(s,r).decode(n)}catch{return{provider:s,entityType:r,version:"0",domain:"",resourceId:null,accountOrOrgId:null,organizationName:null,projectId:null,repoId:null,entityId:e}}};var qt={};z(qt,{CHANGES_REQUESTED_ACTION_CATEGORY:()=>Ds,CHANGES_REQUESTED_BUCKET_ID:()=>vr,CONFLICTS_ACTION_CATEGORY:()=>Ss,CONFLICTS_BUCKET_ID:()=>wr,DRAFT_ACTION_CATEGORY:()=>Ls,DRAFT_BUCKET_ID:()=>Cr,FAILING_CI_ACTION_CATEGORY:()=>Es,FAILING_CI_BUCKET_ID:()=>Pr,NEEDS_MY_REVIEW_ACTION_CATEGORY:()=>Cs,NEEDS_MY_REVIEW_BUCKET_ID:()=>qr,OTHER_ACTION_CATEGORY:()=>Us,OTHER_BUCKET_ID:()=>Dr,PINNED_BUCKET_ID:()=>Ir,READY_TO_MERGE_ACTION_CATEGORY:()=>qs,READY_TO_MERGE_BUCKET_ID:()=>br,REVIEWER_COMMENTED_ACTION_CATEGORY:()=>$s,REVIEWER_COMMENTED_BUCKET_ID:()=>Er,SNOOZED_BUCKET_ID:()=>$r,UNASSIGNED_REVIEWERS_ACTION_CATEGORY:()=>vs,UNASSIGNED_REVIEWERS_BUCKET_ID:()=>yr,WAITING_FOR_REVIEW_ACTION_CATEGORY:()=>As,WAITING_FOR_REVIEW_BUCKET_ID:()=>Sr,getActionablePullRequests:()=>Ts,groupPullRequestsByAssignee:()=>Oo,groupPullRequestsByAuthor:()=>ko,groupPullRequestsByGitKrakenTeam:()=>jo,groupPullRequestsByRepo:()=>Go,groupPullRequestsByReviewer:()=>xo,groupPullRequestsByWorkspace:()=>No,groupPullRequestsIntoBuckets:()=>To});var Q=(s,r,e,t)=>({id:s,faIconName:e,name:r,priority:t,pullRequests:[]}),Ir="pinned",br="readyToMerge",yr="unassignedReviewers",Pr="failingCI",wr="conflicts",qr="needsMyReview",vr="changesRequested",Er="reviewerCommented",Sr="waitingForReview",Cr="draft",Dr="other",$r="snoozed",qs="readyToMerge",vs="unassignedReviewers",Es="failingCI",Ss="conflicts",Cs="needsMyReview",Ds="changesRequested",$s="reviewerCommented",As="waitingForReview",Ls="draft",Us="other",Ts=(s,r,e)=>s.map(t=>{let o={...t,...{suggestedActionCategory:Us,priority:1e3,viewer:{canMerge:!1,isAuthor:!1,isAssignee:!1,isReviewer:!1,shouldMerge:!1,shouldAssignReviewer:!1,waitingOnReviews:!1,shouldReview:!1},failingCI:!1,hasConflicts:!1,changeRequestReviewCount:0,codeSuggestionsCount:0,commentReviewCount:0,approvalReviewCount:0}};r&&(o.viewer.isAuthor=t.author?.id===r.id,o.viewer.isAssignee=t.assignees?.some(u=>u.id===r.id)??!1,o.viewer.isReviewer=t.reviews?.some(u=>u.reviewer.id===r.id)??!1),o.viewer.canMerge=t.permissions?.canMerge??!0,o.hasConflicts=t.mergeableState==="CONFLICTS",o.failingCI=t.headCommit?.buildStatuses?.some(u=>u.state==="ERROR"||u.state==="FAILED")||t.mergeableState==="FAILING_CHECKS",o.commentReviewCount=t.reviews?.filter(u=>u.state==="COMMENTED").length??0,o.approvalReviewCount=t.reviews?.filter(u=>u.state==="APPROVED").length??0,o.changeRequestReviewCount=t.reviews?.filter(u=>u.state==="CHANGES_REQUESTED").length??0;let i=e?.enrichedItemsByUniqueId?.[t.uuid];i!=null&&(o.viewer.enrichedItems=i,i.some(u=>u.type==="pin")&&(o.viewer.pinned=!0,o.priority-=800),i.some(u=>u.type==="snooze")&&(o.viewer.snoozed=!0));let a=e?.codeSuggestionsCountByPrUuid?.[t.uuid]?.count||0;return a&&(o.codeSuggestionsCount=a),(!r||o.viewer.isAuthor||o.viewer.isAssignee&&!o.viewer.isReviewer)&&o.viewer.canMerge&&!o.isDraft&&!o.failingCI&&t.mergeableState==="MERGEABLE"&&(o.viewer.shouldMerge=!0,o.suggestedActionCategory=qs),(!r||o.viewer.isAuthor)&&t.isDraft&&(o.suggestedActionCategory=Ls),(!r||o.viewer.isAuthor)&&t.reviewDecision==="REVIEW_REQUESTED"&&(o.suggestedActionCategory=As,o.viewer.waitingOnReviews=!0),(!r||o.viewer.isAuthor)&&t.reviewDecision==="COMMENTED"&&(o.suggestedActionCategory=$s),(!r||o.viewer.isAuthor)&&o.failingCI&&(o.suggestedActionCategory=Es),(!r||o.viewer.isAuthor)&&o.hasConflicts&&(o.suggestedActionCategory=Ss),(!r||o.viewer.isAuthor)&&(t.reviewDecision==="CHANGES_REQUESTED"||o.codeSuggestionsCount>0)&&(o.suggestedActionCategory=Ds),(!r||o.viewer.isAuthor)&&!t.reviews?.length&&(o.suggestedActionCategory=vs,o.viewer.shouldAssignReviewer=!0),r&&t.reviews?.some(u=>u.reviewer.id===r.id&&u.state==="REVIEW_REQUESTED")&&(o.suggestedActionCategory=Cs,o.viewer.shouldReview=!0),o}),To=(s,r,e)=>{let t={pinned:Q(Ir,"Pinned","thumbtack",e?.bucketPriorityOverride?.pinned??-1),readyToMerge:Q(br,"Ready to Merge","code-merge",e?.bucketPriorityOverride?.readyToMerge??0),unassignedReviewers:Q(yr,"Unassigned Reviewers","user-plus",e?.bucketPriorityOverride?.unassignedReviewers??1),failingCI:Q(Pr,"Failing CI","circle-x",e?.bucketPriorityOverride?.failingCI??2),conflicts:Q(wr,"Resolve Conflicts","triangle-exclamation",e?.bucketPriorityOverride?.conflicts??3),needsMyReview:Q(qr,"Needs My Review","eye",e?.bucketPriorityOverride?.needsMyReview??4),changesRequested:Q(vr,"Suggested Changes","file-plus",e?.bucketPriorityOverride?.changesRequested??5),reviewerCommented:Q(Er,"Reviewer Commented","comment",e?.bucketPriorityOverride?.reviewerCommented??6),waitingForReview:Q(Sr,"Waiting for Review","circle-pause",e?.bucketPriorityOverride?.waitingForReview??7),draft:Q(Cr,"Draft","compass-drafting",e?.bucketPriorityOverride?.draft??8),other:Q(Dr,"Other","ellipsis",e?.bucketPriorityOverride?.other??9),snoozed:Q($r,"Snoozed","snooze",e?.bucketPriorityOverride?.snoozed??10)},o=Ts(s,r,e).reduce((i,a)=>(i[a.uuid]=a,i),{});return s.forEach(i=>{let a=o[i.uuid],u=!0;if(a.viewer.snoozed){t[$r].pullRequests.push(i);return}a.viewer.pinned&&t[Ir].pullRequests.push(i),(!r||a.viewer.isAuthor||a.viewer.isAssignee&&!a.viewer.isReviewer)&&!a.isDraft&&a.viewer.canMerge&&a.mergeableState==="MERGEABLE"&&(t[br].pullRequests.push(i),u=!1),a.viewer.shouldAssignReviewer&&(t[yr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.failingCI&&(t[Pr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.hasConflicts&&(t[wr].pullRequests.push(i),u=!1),a.viewer.shouldReview&&(t[qr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&(a.reviewDecision==="CHANGES_REQUESTED"||a.codeSuggestionsCount>0)&&(t[vr].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.reviewDecision==="COMMENTED"&&(t[Er].pullRequests.push(i),u=!1),(!r||a.viewer.isAuthor)&&a.reviewDecision==="REVIEW_REQUESTED"&&(t[Sr].pullRequests.push(i),u=!1),a.isDraft&&(t[Cr].pullRequests.push(i),u=!1),u&&t[Dr].pullRequests.push(i)}),Object.values(t).forEach(i=>{i.pullRequests.sort((a,u)=>o[a.uuid].priority-o[u.uuid].priority)}),t},Go=s=>{let r={};return s.forEach(e=>{let t=e.repository.id;r[t]?r[t].pullRequests.push(e):r[t]={name:e.repository.name,priority:0,pullRequests:[e],id:t}}),ue(r)},Oo=s=>{let r="internal-no-assignees",e={[r]:{name:"No assignees",priority:-1,pullRequests:[],id:r,faIconName:"user-slash"}};return s.forEach(t=>{t.assignees&&t.assignees.length?t.assignees.forEach(n=>{let o=n.id;e[o]?e[o].pullRequests.push(t):e[o]={accountData:n,name:Te(n,`Unknown Assignee ${Object.keys(e).length}`),priority:0,pullRequests:[t],id:o}}):e[r].pullRequests.push(t)}),ue(e)},ko=s=>{let r="internal-no-author",e={[r]:{name:"No author",priority:-1,pullRequests:[],id:r,faIconName:"user-slash"}};return s.forEach(t=>{if(t.author){let n=t.author.id;e[n]?e[n].pullRequests.push(t):e[n]={accountData:t.author,name:Te(t.author,`Unknown Author ${Object.keys(e).length}`),priority:0,pullRequests:[t],id:n}}else e[r].pullRequests.push(t)}),ue(e)},xo=s=>{let r="internal-no-reviewer",e={[r]:{name:"No reviewers",priority:-1,pullRequests:[],id:r,faIconName:"user-slash"}};return s.forEach(t=>{t.reviews&&t.reviews.length?t.reviews.forEach(n=>{let o=n.reviewer.id;e[o]?e[o].pullRequests.push(t):e[o]={accountData:n.reviewer,name:Te(n.reviewer,`Unknown Reviewer ${Object.keys(e).length}`),priority:0,pullRequests:[t],id:o}}):e[r].pullRequests.push(t)}),ue(e)},_o=s=>s.azureProject?[`${s.azureProject}-${s.azureOrganizationId}`]:s.providerData?.repositories.nodes.map(r=>`${s.provider}-${r.repositoryId}`)??[],No=(s,r)=>{let e="internal-no-workspace",t={[e]:{name:"No workspace",priority:-1,pullRequests:[],id:e,faIconName:"folder-xmark"}};if(r.length){let n=r.reduce((o,i)=>(_o(i).forEach(u=>{o[u]?o[u].push(i):o[u]=[i]}),o),{});s.forEach(o=>{let{provider:i}=Rr(o.uuid),a=i==="github"?o.repository.graphQLId:o.repository.id,u=i==="azure"?[`${i}-${a}`,`${o.repository.project}-${o.repository.owner.login}`]:[`${i}-${a}`],l=!1,p=u.reduce((c,d)=>n[d]?c.concat(n[d]):c,[]);p?.length&&p.forEach(c=>{l=!0;let d=c.id;t[d]?t[d].pullRequests.push(o):t[d]={name:c.name,priority:0,pullRequests:[o],id:d,faIconName:"folder"}}),l||t[e].pullRequests.push(o)})}else t[e].pullRequests=s;return ue(t)},jo=(s,r,e,t)=>{let n="internal-no-team",o={[n]:{name:"No team",priority:-1,pullRequests:[],id:n}};return t.length?s.forEach(i=>{let a=!1,u=new Set;u.add(i.author?.id),i.assignees?.forEach(l=>u.add(l.id)),i.reviews?.forEach(l=>u.add(l.reviewer.id)),t.forEach(l=>{if(l.members?.some(c=>{let d=r[c.id]?.[e]?.providerID;return d&&u.has(d)})){a=!0;let c=l.id;o[c]?o[c].pullRequests.push(i):o[c]={name:l.name,priority:0,pullRequests:[i],id:c,teamData:l}}}),a||o[n].pullRequests.push(i)}):o[n].pullRequests=s,ue(o)};var vt={};z(vt,{getPullRequestRank:()=>Bo});var Bo=(s,r,e)=>{let t=0,n,o;return s.reviews?.forEach(i=>{i.reviewer.id===r&&(n=i.state),i.state==="CHANGES_REQUESTED"?o="CHANGES_REQUESTED":i.state==="APPROVED"&&o!=="CHANGES_REQUESTED"&&(o="APPROVED")}),o||(o="REVIEW_REQUESTED"),s.author?.id===r?t+=1e3:s.assignees?.find(i=>i.id===r)?t+=900:n==="REVIEW_REQUESTED"?t+=800:e&&(t+=700),o==="APPROVED"?s.mergeableState==="MERGEABLE"?t+=100:s.mergeableState==="CONFLICTS"?t+=90:t+=80:o=="CHANGES_REQUESTED"&&(t+=70),t};var Et={};z(Et,{default:()=>Qo});var Qo={};var St={};z(St,{default:()=>Fo});var Fo={};var Ct={};z(Ct,{default:()=>Mo});var Mo={};var Gs=s=>{let r={request:s?.request};return{azureDevOps:new me({...r,...s?.azureDevOps}),bitbucket:new ge({...r,...s?.bitbucket}),bitbucketServer:new he({...r,...s?.bitbucketServer}),github:new fe({...r,...s?.github}),gitlab:new Ie({...r,...s?.gitlab}),jira:new be({...r,...s?.jira}),jiraServer:new ye({...r,...s?.jiraServer}),linear:new Pe({...r,...s?.linear}),trello:new we({...r,...s?.trello})}};var Os=(i=>(i.Conflicts="conflicts",i.Failure="failure",i.NotSet="notSet",i.Queued="queued",i.RejectedByPolicy="rejectedByPolicy",i.Succeeded="succeeded",i))(Os||{});var ks=(e=>(e.Completed="COMPLETED",e.NotPlanned="NOT_PLANNED",e))(ks||{});var zo=Gs;var Wo={azureDevOps:lt,bitbucket:pt,bitbucketServer:_e,github:vt,gitlab:Et,gitProvider:qt,jira:St,trello:Ct,entityIdentifier:wt};
|