Skip to content

Commit

Permalink
Merge pull request #69 from pavlovcik/revert-68-refactor/remove-axios…
Browse files Browse the repository at this point in the history
…-call

Revert "feat: remove axios call"
  • Loading branch information
0x4007 authored Feb 2, 2024
2 parents beb5c9f + 9bc1583 commit e402d16
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 47 deletions.
33 changes: 10 additions & 23 deletions src/handlers/assign/check-pull-requests.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
import axios from "axios";
import { HTMLElement, parse } from "node-html-parser";
import { getAllPullRequests, addAssignees } from "../../helpers/issue";
import { Context } from "../../types/context";

Expand All @@ -13,7 +15,6 @@ export async function checkPullRequests(context: Context) {
// Loop through the pull requests and assign them to their respective issues if needed
for (const pull of pulls) {
const linkedIssue = await getLinkedIssues({
context,
owner: payload.repository.owner.login,
repository: payload.repository.name,
pull: pull.number,
Expand Down Expand Up @@ -59,31 +60,18 @@ export async function checkPullRequests(context: Context) {
return logger.debug(`Checking pull requests done!`);
}

export async function getLinkedIssues({ context, owner, repository, pull }: GetLinkedParams) {
if (!pull || !context) return null;
const { data } = await context.octokit.pulls.get({
owner,
repo: repository,
pull_number: pull,
});
export async function getLinkedIssues({ owner, repository, pull }: GetLinkedParams) {
const { data } = await axios.get(`https://github.com/${owner}/${repository}/pull/${pull}`);
const dom = parse(data);
const devForm = dom.querySelector("[data-target='create-branch.developmentForm']") as HTMLElement;
const linkedIssues = devForm.querySelectorAll(".my-1");

const body = data.body;
if (!body) return null;

const match = body.match(/#(\d+)/);
const issueNumber = match ? match[1] : null;

if (!issueNumber) {
if (linkedIssues.length === 0) {
return null;
}

const issue = await context.octokit.issues.get({
owner,
repo: repository,
issue_number: Number(issueNumber),
});

return issue.data.html_url;
const issueUrl = linkedIssues[0].querySelector("a")?.attrs?.href || null;
return issueUrl;
}

export async function getPullByNumber(context: Context, pull: number) {
Expand Down Expand Up @@ -117,7 +105,6 @@ export async function getIssueByNumber(context: Context, issueNumber: number) {
}
}
export interface GetLinkedParams {
context?: Context;
owner: string;
repository: string;
issue?: number;
Expand Down
55 changes: 31 additions & 24 deletions src/helpers/get-linked-pull-requests.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { GetLinkedParams, getLinkedIssues } from "../handlers/assign/check-pull-requests";
import axios from "axios";
import { HTMLElement, parse } from "node-html-parser";
import { GetLinkedParams } from "../handlers/assign/check-pull-requests";
import { Context } from "../types/context";
import { getAllPullRequests } from "./issue";
interface GetLinkedResults {
organization: string;
repository: string;
Expand All @@ -11,31 +12,37 @@ export async function getLinkedPullRequests(
context: Context,
{ owner, repository, issue }: GetLinkedParams
): Promise<GetLinkedResults[]> {
if (!issue) return [];
// const logger = context.logger;
const logger = context.logger;
const collection = [] as GetLinkedResults[];
const pulls = await getAllPullRequests(context);
const currentIssue = await context.octokit.issues.get({
owner,
repo: repository,
issue_number: issue,
});
for (const pull of pulls) {
const linkedIssue = await getLinkedIssues({
context,
owner: owner,
repository: repository,
pull: pull.number,
});
const { data } = await axios.get(`https://github.com/${owner}/${repository}/issues/${issue}`);
const dom = parse(data);
const devForm = dom.querySelector("[data-target='create-branch.developmentForm']") as HTMLElement;
const linkedList = devForm.querySelectorAll(".my-1");
if (linkedList.length === 0) {
context.logger.info(`No linked pull requests found`);
return [];
}

for (const linked of linkedList) {
const relativeHref = linked.querySelector("a")?.attrs?.href;
if (!relativeHref) continue;
const parts = relativeHref.split("/");

// check if array size is at least 4
if (parts.length < 4) continue;

if (linkedIssue === currentIssue.data.html_url) {
collection.push({
organization: owner,
repository,
number: pull.number,
href: pull.html_url,
});
// extract the organization name and repo name from the link:(e.g. "
const organization = parts[parts.length - 4];
const repository = parts[parts.length - 3];
const number = Number(parts[parts.length - 1]);
const href = `https://github.com${relativeHref}`;

if (`${organization}/${repository}` !== `${owner}/${repository}`) {
logger.info("Skipping linked pull request from another repository", href);
continue;
}

collection.push({ organization, repository, number, href });
}

return collection;
Expand Down

0 comments on commit e402d16

Please sign in to comment.