|
|
@ -4,7 +4,7 @@ |
|
|
|
// killall onhygi ; nohup node . &
|
|
|
|
// killall onhygi ; nohup node . &
|
|
|
|
|
|
|
|
|
|
|
|
// to add on tridactyl :
|
|
|
|
// to add on tridactyl :
|
|
|
|
// autocmd DocStart .* js fetch('http://localhost:7788/check?url='+window.location.href).then(r => r.json()).then( r => { if(!r.passed) window.location.href = 'https://ggsc.berkeley.edu/' } )
|
|
|
|
// autocmd DocStart .* js fetch('http://localhost:7788/check?url='+window.location.href).then(r => r.json()).then( r => { if(!r.passed) { if (r.redirect) { window.location.href = r.redirect } else { window.location.href = 'https://ggsc.berkeley.edu/'} } } )
|
|
|
|
|
|
|
|
|
|
|
|
const http = require("http"); |
|
|
|
const http = require("http"); |
|
|
|
const fs = require("fs"); |
|
|
|
const fs = require("fs"); |
|
|
@ -34,7 +34,8 @@ function terminator(sig) { |
|
|
|
if (typeof sig === "string") { |
|
|
|
if (typeof sig === "string") { |
|
|
|
console.log('Received %s - terminating server app ...', sig); |
|
|
|
console.log('Received %s - terminating server app ...', sig); |
|
|
|
console.log('trying to save on exit') |
|
|
|
console.log('trying to save on exit') |
|
|
|
fs.writeFileSync(usageFilePath, JSON.stringify( usage )) |
|
|
|
if (quota.length) fs.writeFileSync(usageFilePath, JSON.stringify( usage )) |
|
|
|
|
|
|
|
// to avoiding busting usage quota
|
|
|
|
process.exit(1); |
|
|
|
process.exit(1); |
|
|
|
} |
|
|
|
} |
|
|
|
console.log('Node server stopped.'); |
|
|
|
console.log('Node server stopped.'); |
|
|
@ -50,18 +51,22 @@ console.log('past usage', usage) |
|
|
|
|
|
|
|
|
|
|
|
// does not apply in a P2P fashion, must rely on local configuration here config.json
|
|
|
|
// does not apply in a P2P fashion, must rely on local configuration here config.json
|
|
|
|
let quota = [ |
|
|
|
let quota = [ |
|
|
|
{id:"ownhome", pattern:/.*fabien\.benetou\.fr.*/, perHour:10, perDay:200}, |
|
|
|
// unlimited {id:"ownhome", pattern:/.*fabien\.benetou\.fr.*/, perHour:10, perDay:200},
|
|
|
|
{id:"twitter",pattern:/.*twitter\.com.*/,perHour:1,perDay:12}, |
|
|
|
{id:"twitter",pattern:/.*twitter\.com.*/,perHour:1,perDay:12}, |
|
|
|
{id:"proton",pattern:/.*proton\.me.*/,perHour:6,perDay:6*12}, |
|
|
|
{id:"proton",pattern:/.*proton\.me.*/,perHour:6,perDay:6*12}, |
|
|
|
{id:"yt",pattern:/.*youtube\.com.*/,perHour:1,perDay:12}, |
|
|
|
{id:"yt",pattern:/https:\/\/www\.youtube\.com.*/,perHour:2,perDay:12}, // allow for redirection
|
|
|
|
|
|
|
|
{id:"yts",pattern:/https:\/\/youtube\.com.*/,perHour:2,perDay:12}, // allow for redirection, consider merged IDs
|
|
|
|
{id:"linkedin",pattern:/.*linkedin\.com.*/,perHour:1,perDay:12}, |
|
|
|
{id:"linkedin",pattern:/.*linkedin\.com.*/,perHour:1,perDay:12}, |
|
|
|
{id:"reddit",pattern:/.*reddit\.com.*/,perHour:1,perDay:12}, |
|
|
|
{id:"reddit",pattern:/.*reddit\.com.*/,perHour:3,perDay:12,redirect:'https://lemmy.world'}, // redirection then enough to read private messages
|
|
|
|
// reconsider the tridactyl check for permanently open pages, e.g TabEnter rather than DocStart
|
|
|
|
// reconsider the tridactyl check for permanently open pages, e.g TabEnter rather than DocStart
|
|
|
|
{id:"element",pattern:/.*element\.io.*/,perHour:1,perDay:12}, |
|
|
|
{id:"element",pattern:/.*element\.io.*/,perHour:1,perDay:12}, |
|
|
|
{id:"discord",pattern:/.*discord\.com.*/,perHour:1,perDay:12}, |
|
|
|
{id:"discord",pattern:/.*discord\.com.*/,perHour:1,perDay:12}, |
|
|
|
] |
|
|
|
] |
|
|
|
// could also check on time, e.g not before 7am nor after 10pm as done via tridactyl now
|
|
|
|
// could also check on time, e.g not before 7am nor after 10pm as done via tridactyl now
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// bypass for e.g presentations
|
|
|
|
|
|
|
|
//quota = []
|
|
|
|
|
|
|
|
|
|
|
|
if (fs.existsSync( configFilePath ) ){ |
|
|
|
if (fs.existsSync( configFilePath ) ){ |
|
|
|
const configurationFromFile = JSON.parse( fs.readFileSync( configFilePath ).toString() ) |
|
|
|
const configurationFromFile = JSON.parse( fs.readFileSync( configFilePath ).toString() ) |
|
|
|
console.log('found quota file') |
|
|
|
console.log('found quota file') |
|
|
@ -111,10 +116,16 @@ app.get('/check', (req, res) => { |
|
|
|
let now = Date.now()/1000
|
|
|
|
let now = Date.now()/1000
|
|
|
|
usage[rule.id].push( now ) |
|
|
|
usage[rule.id].push( now ) |
|
|
|
if ( usage[rule.id].filter( t => t>now-60*60).length > rule.perHour ){ |
|
|
|
if ( usage[rule.id].filter( t => t>now-60*60).length > rule.perHour ){ |
|
|
|
res.json( { passed: false, msg: 'over quota per hour' } ) |
|
|
|
if (rule.redirect) |
|
|
|
|
|
|
|
res.json( { passed: false, msg: 'over quota per day', redirect:rule.redirect } ) |
|
|
|
|
|
|
|
else |
|
|
|
|
|
|
|
res.json( { passed: false, msg: 'over quota per day' } ) |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
|
if ( usage[rule.id].filter( t => t>now-60*60*24).length > rule.perDay ){ |
|
|
|
if ( usage[rule.id].filter( t => t>now-60*60*24).length > rule.perDay ){ |
|
|
|
|
|
|
|
if (rule.redirect) |
|
|
|
|
|
|
|
res.json( { passed: false, msg: 'over quota per day', redirect:rule.redirect } ) |
|
|
|
|
|
|
|
else |
|
|
|
res.json( { passed: false, msg: 'over quota per day' } ) |
|
|
|
res.json( { passed: false, msg: 'over quota per day' } ) |
|
|
|
return |
|
|
|
return |
|
|
|
} |
|
|
|
} |
|
|
|