diff options
author | Minteck <contact@minteck.org> | 2022-10-18 08:59:09 +0200 |
---|---|---|
committer | Minteck <contact@minteck.org> | 2022-10-18 08:59:09 +0200 |
commit | 2c4ae43e688a9873e86211ea0e7aeb9ba770dd77 (patch) | |
tree | 17848d95522dab25d3cdeb9c4a6450e2a234861f /alarm/node_modules/pronote-api/src/cas/generics/kdecole-wayf.js | |
parent | 108525534c28013cfe1897c30e4565f9893f3766 (diff) | |
download | pluralconnect-2c4ae43e688a9873e86211ea0e7aeb9ba770dd77.tar.gz pluralconnect-2c4ae43e688a9873e86211ea0e7aeb9ba770dd77.tar.bz2 pluralconnect-2c4ae43e688a9873e86211ea0e7aeb9ba770dd77.zip |
Update
Diffstat (limited to 'alarm/node_modules/pronote-api/src/cas/generics/kdecole-wayf.js')
-rw-r--r-- | alarm/node_modules/pronote-api/src/cas/generics/kdecole-wayf.js | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/alarm/node_modules/pronote-api/src/cas/generics/kdecole-wayf.js b/alarm/node_modules/pronote-api/src/cas/generics/kdecole-wayf.js new file mode 100644 index 0000000..7d20163 --- /dev/null +++ b/alarm/node_modules/pronote-api/src/cas/generics/kdecole-wayf.js @@ -0,0 +1,45 @@ +const jsdom = require('jsdom'); + +const { getDOM, submitForm, extractStart } = require('../api'); +const aten = require('./aten'); + +async function login({ url, account, username, password, casUrl, idp, atenURL }) +{ + if (idp && !idp.includes('parent_eleve')) { + idp += '_parent_eleve'; + } + + casUrl = `https://${casUrl}/`; + + const jar = new jsdom.CookieJar(); + let dom = await getDOM({ + url: `${casUrl}login?${idp ? `selection=${idp}&` : ''}service=${encodeURIComponent(url)}`, + jar + }); + + if (atenURL) { + dom = await submitForm({ + dom, + jar, + runScripts: !!atenURL, + hook: atenURL && aten.hook, + actionRoot: casUrl + }); + + await aten.submit({ dom, jar, username, password, atenURL }); + } else { + dom.window.document.getElementById('username').value = username; + dom.window.document.getElementById('password').value = password; + + await submitForm({ + actionRoot: casUrl, + dom, + jar, + asIs: true + }); + } + + return extractStart(await getDOM({ url: url + account.value + '.html', jar, asIs: true })); +} + +module.exports = login; |