summaryrefslogtreecommitdiff
path: root/school/node_modules/pronote-api/src/axioRequest.js
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2023-02-23 19:34:56 +0100
committerMinteck <contact@minteck.org>2023-02-23 19:34:56 +0100
commit3d1cd02f27518f1a04374c7c8320cd5d82ede6e9 (patch)
tree75be5fba4368472fb11c8015aee026b2b9a71888 /school/node_modules/pronote-api/src/axioRequest.js
parent8cc1f13c17fa2fb5a4410542d39e650e02945634 (diff)
downloadpluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.gz
pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.tar.bz2
pluralconnect-3d1cd02f27518f1a04374c7c8320cd5d82ede6e9.zip
Updated 40 files, added 37 files, deleted 1103 files and renamed 3905 files (automated)
Diffstat (limited to 'school/node_modules/pronote-api/src/axioRequest.js')
-rw-r--r--school/node_modules/pronote-api/src/axioRequest.js86
1 files changed, 0 insertions, 86 deletions
diff --git a/school/node_modules/pronote-api/src/axioRequest.js b/school/node_modules/pronote-api/src/axioRequest.js
deleted file mode 100644
index 3e625c2..0000000
--- a/school/node_modules/pronote-api/src/axioRequest.js
+++ /dev/null
@@ -1,86 +0,0 @@
-const axios = require('axios');
-
-async function axioRequest({ url, body, data, method = 'GET', binary, jar = null }) {
- let userAgent = 'Mozilla/5.0 (X11; Linux x86_64; rv:59.0) Gecko/20100101 Firefox/59.0';
- if (url.includes('teleservices.ac-nancy-metz.fr')) {
- userAgent = 'FuckTheUselessProtection/1.0';
- }
-
- const params = encodeParams(data);
- const content = {
- url,
- method: method.toLowerCase(),
- headers: {
- 'User-Agent': userAgent,
- 'Content-Type': body !== undefined
- ? 'application/json'
- : (params !== '' && method !== 'GET' ? 'application/x-www-form-urlencoded' : ''),
- 'Cookie': encodeCookies(jar)
- },
- maxRedirects: 0,
- validateStatus(status) {
- return status === 401 || (status >= 200 && status <= 302)
- }
- };
-
- if (binary) {
- content.responseType = 'arraybuffer';
- }
-
- if (params) {
- if (method.toUpperCase() === 'GET') {
- content.url += '?' + params;
- } else {
- content.data = params;
- }
- } else if (body) {
- content.data = body;
- }
- const response = await axios(content)
-
- if (response.headers['set-cookie'] && jar !== null) {
- await updateCookies(response, jar, url);
- }
-
- return response;
-}
-
-function updateCookies(response, jar, url) {
- return new Promise((accept, reject) => {
- response.headers['set-cookie'].forEach(cookie => {
- jar.setCookie(cookie, url, err => (err ? reject(err) : accept()));
- });
- });
-}
-
-function encodeCookies(jar) {
- if (!jar) {
- return '';
- }
-
- let cookies = '';
- jar.toJSON().cookies.forEach(cookie => cookies += cookie.key + '=' + cookie.value + '; ');
-
- if (cookies.length !== 0) {
- cookies = cookies.substring(0, cookies.length - 2);
- }
-
- return cookies;
-}
-
-function encodeParams(data) {
- if (!data) {
- return '';
- }
-
- let params = '';
- for (const k of Object.keys(data)) {
- const v = data[k];
- params += `${k}=${encodeURIComponent(v)}&`
- }
-
- return params.substring(0, params.length - 1)
-}
-
-
-module.exports = axioRequest