1
0
Fork 0
mirror of https://github.com/classchartsapi/classcharts-api-js.git synced 2026-05-14 03:56:59 +00:00
classcharts-api-js/src/parentClient.ts

100 lines
3.1 KiB
TypeScript
Raw Normal View History

2022-05-07 12:58:42 +01:00
import axios, { AxiosInstance, AxiosRequestConfig } from "axios";
2022-03-12 11:37:28 +00:00
import type { GetPupilsResponse } from "./types";
2022-03-12 11:30:03 +00:00
2022-03-12 12:08:41 +00:00
import { ClasschartsClient } from "./baseClient";
2022-03-12 11:30:03 +00:00
import { API_BASE_PARENT, BASE_URL } from "./consts";
/**
* The base client
*/
export class ClasschartsParentClient extends ClasschartsClient {
2022-03-12 11:34:56 +00:00
private password = "";
private email = "";
2022-03-12 12:00:28 +00:00
// @ts-expect-error Init in .login
public pupils: GetPupilsResponse;
2022-03-12 11:30:03 +00:00
/**
*
* @param email Parents email address
* @param password Parents password
*/
2022-05-07 12:58:42 +01:00
constructor(
email: string,
password: string,
axiosConfig?: AxiosRequestConfig
) {
super(API_BASE_PARENT, axiosConfig);
2022-03-12 11:30:03 +00:00
this.email = String(email);
this.password = String(password);
}
/**
* Logs the user in the client and authenticates with classcharts
*/
async login(): Promise<void> {
if (!this.email) throw new Error("Email not inputted");
const formData = new URLSearchParams();
formData.append("_method", "POST");
formData.append("email", this.email);
formData.append("logintype", "existing");
formData.append("password", this.password);
formData.append("recaptcha-token", "no-token-avaliable");
2022-05-07 12:58:42 +01:00
const request = await this.axios.request({
2022-03-24 18:56:33 +00:00
url: BASE_URL + "/parent/login",
2022-03-12 11:30:03 +00:00
method: "POST",
2022-03-24 18:56:33 +00:00
data: formData.toString(),
maxRedirects: 0,
2022-03-12 11:30:03 +00:00
headers: {
"Content-Type": "application/x-www-form-urlencoded",
},
2022-03-24 18:56:33 +00:00
validateStatus: () => true,
2022-03-12 11:30:03 +00:00
});
2022-03-24 18:56:33 +00:00
if (request.status != 302 || !request.headers["set-cookie"])
2022-03-12 11:30:03 +00:00
throw new Error("Unauthenticated: Classcharts returned an error");
const cookies = request.headers["set-cookie"];
for (let i = 0; i < cookies.length; i++) {
cookies[i] = cookies[i].substring(0, cookies[i].indexOf(";"));
}
this.authCookies = cookies;
// eslint-disable-next-line @typescript-eslint/no-explicit-any
let sessionID: any = decodeURI(cookies[2])
.replace(/%3A/g, ":")
.replace(/%2C/g, ",");
sessionID = JSON.parse(
sessionID.substring(sessionID.indexOf("{"), sessionID.length)
);
this.sessionId = sessionID.session_id;
2022-03-12 12:00:28 +00:00
this.pupils = await this.getPupils();
if (!this.pupils) throw new Error("Account has no pupils attached");
this.studentId = this.pupils[0].id;
this.studentName = this.pupils[0].name;
2022-03-12 11:30:03 +00:00
}
/**
* Get Pupil details
* @returns an array fo Pupils connected to this parent's account
*/
2022-03-12 11:34:56 +00:00
async getPupils(): Promise<GetPupilsResponse> {
2022-03-12 11:37:28 +00:00
return this.makeAuthedRequest(this.API_BASE + "/pupils", {
2022-03-12 11:34:56 +00:00
method: "GET",
});
}
2022-03-12 12:00:28 +00:00
/**
2022-03-12 12:02:30 +00:00
* Selects a pupil to be used with API requests
2022-03-12 12:00:28 +00:00
* @param pupilId Pupil ID obtained from this.pupils or getPupils
*/
async selectPupil(pupilId: number): Promise<void> {
if (!pupilId) throw new Error("No pupil ID specified");
const pupils = this.pupils;
for (let i = 0; i < pupils.length; i++) {
const pupil = pupils[i];
if (pupil.id == pupilId) {
this.studentId = pupil.id;
this.studentName = pupil.name;
return;
}
}
throw new Error("No pupil with specified ID returned");
}
2022-03-12 11:30:03 +00:00
}