add "get all from profile" feature

This commit is contained in:
iw0 2024-02-15 19:14:55 +01:00
parent 59e8e9f225
commit 8ca77c6343
4 changed files with 83 additions and 12 deletions

View File

@ -21,6 +21,29 @@ function correlationId() {
return crypto.randomUUID() + "_" + crypto.randomUUID() return crypto.randomUUID() + "_" + crypto.randomUUID()
} }
async function getKundenkontoV2(){
let tok = await getAuthToken();
let req = await fetch("https://www.bahn.de/web/api/kundenkonto/v2", {
headers: [
["Accept", "application/json"], ["authorization", "Bearer " + tok], //["X-Correlation-ID", correlationId()]
]
});
if(req.ok){
const data = await req.json();
return {
"addr__appellation": data.anrede,
"addr__firstName": data.vorname,
"addr__surName": data.nachname,
"bday": data.geburtsdatum,
"addr__email": data.email,
"addr__placename": data.hauptadresse.ort,
"addr__postcode": data.hauptadresse.plz,
"addr__street": data.hauptadresse.strasse
}
}
return {}
}
async function getBahncardInfo() { async function getBahncardInfo() {
let tok = await getAuthToken(); let tok = await getAuthToken();
let req = await fetch("https://www.bahn.de/web/api/kundenkonto/bahncard", { let req = await fetch("https://www.bahn.de/web/api/kundenkonto/bahncard", {
@ -46,16 +69,25 @@ async function getBahncardInfo() {
return false; return false;
} }
} }
browser.storage.sync.get("acquireBahncard").then(v => { browser.storage.sync.get(["acquireAll","acquireBahncard"]).then(v => {
if (v.acquireAll!=false){
Promise.all([getKundenkontoV2(), getBahncardInfo()]).then(data => {
const saveData = {...data[0], "bcnum": data[1]};
console.log("Saving", saveData);
browser.storage.sync.set(saveData).then(()=>{
alert("Saved all available data to settings.\nPlease enter your bank details on the bottom of the settings page.");
window.close();
})
})
}
if (v.acquireBahncard != false) { // may also be undefined, so no identity check here if (v.acquireBahncard != false) { // may also be undefined, so no identity check here
getBahncardInfo().then(v => { getBahncardInfo().then(v => {
if (!!v && v.length == 16) { if (!!v && v.length == 16) {
const saveData = { "bcnum": v, "acquireBahncard": false } const saveData = { "bcnum": v, "acquireBahncard": false }
console.log("Saving", saveData); console.log("Saving", saveData);
browser.storage.sync.set(saveData).then(success => { browser.storage.sync.set(saveData).then(() => {
if (window !== window.top) { alert("Saved your BahnCard number to settings.\nReload the settings page to continue.");
window.close(); window.close();
}
}); });
} }
}, f => console.log("Could not acquire BahnCard number.", f)) }, f => console.log("Could not acquire BahnCard number.", f))

View File

@ -13,12 +13,13 @@
<span class="fh">Enable autofill</span> <span class="fh">Enable autofill</span>
<input name="enable" id="enable" type="checkbox" /> <input name="enable" id="enable" type="checkbox" />
</label> </label>
<button id="all-get-from-profile">Get all the data from my profile</button>
<label class="item"> <label class="item">
<span class="fh">Your BahnCard 100 number</span><br /> <span class="fh">Your BahnCard 100 number</span><br />
<span class="sh">The number on the front of your card starting with <span class="ms">7081</span>.</span><br> <span class="sh">The number on the front of your card starting with <span class="ms">7081</span>.</span><br>
<input name="bcnum" id="bcnum" type="text" pattern="70814[0-9]{11}" required <input name="bcnum" id="bcnum" type="text" pattern="70814[0-9]{11}" required
title="Your BahnCard number is 16 digits long and starts with 7081." /> title="Your BahnCard number is 16 digits long and starts with 7081." />
<button id="bcnum-get-from-profile">Get from profile (experimental)</button> <button id="bcnum-get-from-profile">Get from profile</button>
</label> </label>
<label class="item"> <label class="item">
<span class="fh">Your date of birth</span><br> <span class="fh">Your date of birth</span><br>
@ -32,15 +33,26 @@
<fieldset> <fieldset>
<legend>Address data</legend> <legend>Address data</legend>
<label class="item"> <label class="item">
<span class="fh">Title</span> <span class="fh">Appellation</span>
<select name="title" id="title"> <select name="title" id="title">
<option value="">Please choose</option> <option value="">Please choose</option>
<option value="mr">Mr</option> <option value="HR">Mr</option>
<option value="ms">Ms</option> <option value="FR">Ms</option>
<option value="NA">Neutral</option>
</select> </select>
</label> </label>
<label class="item"> <label class="item">
<span class="fh">Name</span><br> <span class="fh">Title</span>
<select name="title_addl" id="title_addl">
<option value="">None</option>
<option value="DR">Dr.</option>
<option value="PD">Prof. Dr.</option>
<option value="DD">Dr. Dr.</option>
<option value="PDD">Prof. Dr. Dr.</option>
</select>
</label>
<label class="item">
<span class="fh">Given name</span><br>
<input name="firstname" id="firstname" /> <input name="firstname" id="firstname" />
</label> </label>
<label class="item"> <label class="item">

View File

@ -78,6 +78,7 @@ async function saveOptions(ev) {
let autoContinue = this.querySelector('#autocontinue').checked; let autoContinue = this.querySelector('#autocontinue').checked;
let enable = this.querySelector('#enable').checked; let enable = this.querySelector('#enable').checked;
let title = this.querySelector('#title').value; let title = this.querySelector('#title').value;
let title_addl = this.querySelector('#title_addl').value;
let firstName = this.querySelector('#firstname').value; let firstName = this.querySelector('#firstname').value;
let surName = this.querySelector('#surname').value; let surName = this.querySelector('#surname').value;
let emailAddress = this.querySelector('#email').value; let emailAddress = this.querySelector('#email').value;
@ -96,6 +97,7 @@ async function saveOptions(ev) {
autocontinue: autoContinue, autocontinue: autoContinue,
enable: enable, enable: enable,
addr__appellation: title, addr__appellation: title,
addr__title: title_addl,
addr__firstName: firstName, addr__firstName: firstName,
addr__surName: surName, addr__surName: surName,
addr__email: emailAddress, addr__email: emailAddress,
@ -129,6 +131,7 @@ async function restoreOptions() {
document.querySelector("#birthday").value = settings.bday || ""; document.querySelector("#birthday").value = settings.bday || "";
document.querySelector("#autocontinue").checked = settings.autocontinue || false; document.querySelector("#autocontinue").checked = settings.autocontinue || false;
document.querySelector('#title').value = settings.addr__appellation || ""; document.querySelector('#title').value = settings.addr__appellation || "";
document.querySelector('#title_addl').value = settings.addr__title || "";
document.querySelector('#firstname').value = settings.addr__firstName || ""; document.querySelector('#firstname').value = settings.addr__firstName || "";
document.querySelector('#surname').value = settings.addr__surName || ""; document.querySelector('#surname').value = settings.addr__surName || "";
document.querySelector('#email').value = settings.addr__email || ""; document.querySelector('#email').value = settings.addr__email || "";
@ -147,7 +150,6 @@ function startBcnumAcquisition(ev) {
console.log(changes); console.log(changes);
for (const [key, changeSet] of Object.entries(changes)) { for (const [key, changeSet] of Object.entries(changes)) {
if (key === "bcnum") { if (key === "bcnum") {
bahncardWindow.close();
browser.storage.sync.onChanged.removeListener(this); browser.storage.sync.onChanged.removeListener(this);
} }
} }
@ -158,7 +160,24 @@ function startBcnumAcquisition(ev) {
} }
}) })
} }
function startAllAcquisition(ev) {
browser.storage.sync.set({"acquireAll":true}).then(() => {
browser.storage.sync.onChanged.addListener(changes => {
console.log(changes);
for(const [key, changeSet] of Object.entries(changes)){
if (key === "acquireAll"){
document.location.reload();
}
}
})
bahncardWindow = window.open("https://www.bahn.de/buchung/kundenkonto/bahncard", "_blank", "popup")
if (bahncardWindow instanceof Window) {
bahncardWindow.postMessage("__WINDOW_OPENED_FOR_BC_ACQUISITION__");
}
})
}
document.addEventListener('DOMContentLoaded', restoreOptions); document.addEventListener('DOMContentLoaded', restoreOptions);
document.querySelector("form").addEventListener("submit", saveOptions); document.querySelector("form").addEventListener("submit", saveOptions);
document.querySelector("#bcnum-get-from-profile").addEventListener("click", startBcnumAcquisition) document.querySelector("#bcnum-get-from-profile").addEventListener("click", startBcnumAcquisition)
document.querySelector("#all-get-from-profile").addEventListener("click", startAllAcquisition)

View File

@ -50,3 +50,11 @@ input:focus {
} }
} }
#all-get-from-profile {
width:100%;
min-height:2rem;
text-align: center;
font-size: 18pt;
font-weight: bold;
}