mirror of
https://github.com/ThisIsBenny/iOS-Widgets.git
synced 2025-04-19 23:37:41 +00:00
136 lines
No EOL
3.7 KiB
JavaScript
136 lines
No EOL
3.7 KiB
JavaScript
// Variables used by Scriptable.
|
|
// These must be at the very top of the file. Do not edit.
|
|
// icon-color: teal; icon-glyph: magic;
|
|
|
|
// Credits Sillium@GitHub (https://gist.github.com/Sillium/f904fb89444bc8dde12cfc07b8fa8728)
|
|
|
|
// How many minutes should the cache be valid
|
|
let cacheMinutes = 60;
|
|
|
|
async function getSessionCookies() {
|
|
let req;
|
|
req = new Request("https://www.vodafone.de/mint/rest/session/start")
|
|
req.method = "POST";
|
|
req.headers = {
|
|
'Content-Type': 'application/json',
|
|
'Accept': 'application/json'
|
|
}
|
|
|
|
req.body = JSON.stringify({
|
|
"authMethod": "AAA",
|
|
"byPIN": false,
|
|
"additionalParameters": {
|
|
"deviceType": "Smartphone"
|
|
}
|
|
})
|
|
try {
|
|
let res = await req.loadJSON()
|
|
return { cookies: req.response.cookies, msisdn: res.msisdn}
|
|
} catch (e) {
|
|
console.log(e)
|
|
throw e
|
|
}
|
|
};
|
|
|
|
async function getUsage() {
|
|
let {cookies, msisdn} = await getSessionCookies();
|
|
let CookieValues = cookies.map(function(v){
|
|
return v.name + "=" + v.value
|
|
})
|
|
let req;
|
|
req = new Request(`https://www.vodafone.de/api/enterprise-resources/core/bss/sub-nil/mobile/payment/service-usages/subscriptions/${msisdn}/unbilled-usage`)
|
|
req.headers = {
|
|
'x-vf-api': '1499082775305',
|
|
'Referer': 'https://www.vodafone.de/meinvodafone/services/',
|
|
'Accept': 'application/json',
|
|
'Cookies': CookieValues.join(';')
|
|
}
|
|
try {
|
|
let res = await req.loadJSON()
|
|
|
|
let datenContainer = res['serviceUsageVBO']['usageAccounts'][0]['usageGroup'].find(function(v){
|
|
return v.container == "Daten"
|
|
})
|
|
let datenvolumen = datenContainer.usage.find(function(v){
|
|
return v.code == "-1"
|
|
})
|
|
console.log(datenvolumen)
|
|
return {
|
|
total: datenvolumen.total,
|
|
used: datenvolumen.used,
|
|
remaining: datenvolumen.remaining
|
|
}
|
|
} catch (e) {
|
|
console.log(e)
|
|
throw e
|
|
}
|
|
};
|
|
|
|
var today = new Date();
|
|
|
|
// Set up the file manager.
|
|
const files = FileManager.local()
|
|
|
|
// Set up cache .
|
|
const cachePath = files.joinPath(files.documentsDirectory(), "widget-vodafone")
|
|
const cacheExists = files.fileExists(cachePath)
|
|
const cacheDate = cacheExists ? files.modificationDate(cachePath) : 0
|
|
|
|
// Get Data
|
|
let data;
|
|
let lastUpdate
|
|
try {
|
|
// If cache exists and it's been less than 30 minutes since last request, use cached data.
|
|
if (cacheExists && (today.getTime() - cacheDate.getTime()) < (cacheMinutes * 60 * 1000)) {
|
|
console.log("Get from Cache")
|
|
data = JSON.parse(files.readString(cachePath))
|
|
lastUpdate = cacheDate
|
|
} else {
|
|
console.log("Get from API")
|
|
data = await getUsage()
|
|
files.writeString(cachePath, JSON.stringify(data))
|
|
lastUpdate = today
|
|
}
|
|
} catch (e) {
|
|
console.log(e)
|
|
console.log("Get from Cache")
|
|
data = JSON.parse(files.readString(cachePath))
|
|
lastUpdate = cacheDate
|
|
}
|
|
|
|
// Create Widget
|
|
let widget = new ListWidget();
|
|
|
|
widget.backgroundColor = new Color("#FD0000")
|
|
|
|
let provider = widget.addText("Vodafone")
|
|
provider.font = Font.mediumSystemFont(12)
|
|
|
|
widget.addSpacer()
|
|
|
|
let remainingPercentage = (100 / data.total * data.remaining).toFixed(0);
|
|
|
|
const remainingPercentageText = widget.addText(remainingPercentage + "%")
|
|
remainingPercentageText.font = Font.boldSystemFont(36)
|
|
|
|
widget.addSpacer()
|
|
|
|
let remainingGB = (data.remaining / 1024).toFixed(1)
|
|
let totalGB = (data.total / 1024).toFixed(0)
|
|
let totalValuesText = widget.addText(`${remainingGB} GB von ${totalGB} GB`)
|
|
totalValuesText.font = Font.mediumSystemFont(12)
|
|
|
|
widget.addSpacer()
|
|
let lastUpdateText = widget.addDate(lastUpdate)
|
|
lastUpdateText.font = Font.mediumSystemFont(10)
|
|
lastUpdateText.centerAlignText()
|
|
lastUpdateText.applyTimeStyle()
|
|
lastUpdateText.textColor = Color.darkGray()
|
|
|
|
if(!config.runsInWidget) {
|
|
await widget.presentSmall()
|
|
} else {
|
|
// Tell the system to show the widget.
|
|
Script.setWidget(widget)
|
|
Script.complete()
|
|
} |