Files
minisrv/zefie_wtvp_minisrv/includes/classes/WTVShenanigans.js
zefie 55cbf592ee new experimental feature: shenanigans
- will allow server operates to intentionally enable bugs/exploits for fun shenanigans
2022-12-01 09:18:25 -05:00

42 lines
1.4 KiB
JavaScript

class WTVShenanigans {
minisrv_config = null;
shenanigans = {
// PLEASE NOTE: anything that is broken with any shenigan level besides "false" is NOT a bug!!!!
"NO_SHENANIGANS": false, // no shenanigans, minisrv as intended, most secure option
"ENABLE_TRICKS_URLACCESS": 1, // allows users to use wtv-tricks:/access?url=
"DISABLE_HTML_ENTITIZER": 4, // disables HTML Entitizer, allowing things such as HTML in email/usenet subjects
"DISABLE_HTML_SANITIZER": 5 // disables HTML Sanitizer, allowing all sorts of chaos in email/usenet posts and signatures
}
constructor(minisrv_config) {
this.minisrv_config = minisrv_config;
}
getShenanigansLevel() {
return this.minisrv_config.config.shenanigans;
}
checkShenanigan(value) {
var level = this.getShenanigansLevel();
// shenanigans are disabled, don't iterate
if (level === false) return false;
var retval = false;
var shenanigans = this.shenanigans;
// shenanigans are enabled, so check if the requested shenanigan is within the level enabled
Object.keys(shenanigans).forEach((k) => {
if (shenanigans[k] == value) {
if (level >= shenanigans[k]) {
retval = true;
return false;
}
}
});
return retval;
}
}
module.exports = WTVShenanigans;