mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-26 07:38:33 -06:00
am calling canvas api
This commit is contained in:
@@ -1,11 +1,16 @@
|
||||
// services/canvasServiceUtils.ts
|
||||
|
||||
import { AxiosResponseHeaders, RawAxiosResponseHeaders } from "axios";
|
||||
import { webRequestor } from "./webRequestor";
|
||||
|
||||
const BASE_URL = "https://snow.instructure.com/api/v1/";
|
||||
const getNextUrl = (
|
||||
headers: AxiosResponseHeaders | RawAxiosResponseHeaders
|
||||
): string | undefined => {
|
||||
const linkHeader: string | undefined =
|
||||
typeof headers.get === "function"
|
||||
? (headers.get("link") as string)
|
||||
: ((headers as RawAxiosResponseHeaders)["link"] as string);
|
||||
|
||||
const getNextUrl = (headers: Headers): string | undefined => {
|
||||
const linkHeader = headers.get("Link");
|
||||
if (!linkHeader) return undefined;
|
||||
|
||||
const links = linkHeader.split(",").map((link) => link.trim());
|
||||
@@ -14,33 +19,24 @@ const getNextUrl = (headers: Headers): string | undefined => {
|
||||
if (!nextLink) return undefined;
|
||||
|
||||
const nextUrl = nextLink.split(";")[0].trim().slice(1, -1);
|
||||
return nextUrl.replace(BASE_URL, "").trim();
|
||||
return nextUrl;
|
||||
};
|
||||
|
||||
export const canvasServiceUtils = {
|
||||
async paginatedRequest<T>(request: { url: string }): Promise<T[]> {
|
||||
var requestCount = 1;
|
||||
const url = new URL(request.url!, BASE_URL);
|
||||
const url = new URL(request.url);
|
||||
url.searchParams.set("per_page", "100");
|
||||
|
||||
const { data: firstData, response: firstResponse } =
|
||||
await webRequestor.get<T>(url.toString());
|
||||
|
||||
if (!firstResponse.ok) {
|
||||
console.error(
|
||||
"error in response",
|
||||
firstResponse.statusText,
|
||||
firstResponse.body
|
||||
);
|
||||
throw new Error("error in response");
|
||||
}
|
||||
|
||||
var returnData: T[] = firstData ? [firstData] : [];
|
||||
var nextUrl = getNextUrl(firstResponse.headers);
|
||||
|
||||
while (nextUrl) {
|
||||
requestCount += 1;
|
||||
const {data, response} = await webRequestor.get<T>(nextUrl);
|
||||
const { data, response } = await webRequestor.get<T>(nextUrl);
|
||||
if (data) {
|
||||
returnData = [...returnData, data];
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user