-
Notifications
You must be signed in to change notification settings - Fork 0
/
clean.js
72 lines (60 loc) · 2.26 KB
/
clean.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
// Author: Jean-Marie Thewes
//Modules:
const path = require('path');
const fs = require("fs").promises;
const config = require("./config.js");
const log = require("./log.js");
//Global vars:
const configFileName = "config/config.json";
const now = new Date();
var maxLogAgeInMS;
//Environment vars:
process.env.configFileName = configFileName;
//Functions:
function reportAndClose(error){// Major Error occured, log error and close
if("message" in error){
log.error(`${error.name}: ${error.message}`);
log.debug(error.stack);
}else{
log.error(error);
}
return true //to let the next function (close()) know that an error occured
}//------------------------------------------------------------------------------------------
async function close(error){// Close Puppeteer if it is still open and exit
await log.flushLogs();
if(error){
process.exit(1);
}else{
process.exit(0);
}
}//------------------------------------------------------------------------------------------
async function getAges(){
maxLogAgeInMS = await config.getMaxLogAgeInDays()*24*60*60*1000;
}//------------------------------------------------------------------------------------------
async function deleteFiles(folder,extension,ageLimitInMS){
let hasExtension = input =>{return (input.search(extension) != -1)}
let folderContent = await fs.readdir(path.join(__dirname,folder));
let filteredContent = folderContent.filter(hasExtension)
for(element of filteredContent){
let stat = await fs.stat(path.join(__dirname,folder,element));
if((now - stat.birthtime) > ageLimitInMS){
await fs.unlink(path.join(__dirname,folder,element))
}
}
}//------------------------------------------------------------------------------------------
async function deleteLogs(){
var logConfigArray = await config.getLogConfig();
for (logConfig of logConfigArray){
if(logConfig.type == "file"){
await deleteFiles(logConfig.folder,logConfig.extension,maxLogAgeInMS);
}
}
return
}//------------------------------------------------------------------------------------------
//Main:
Promise.resolve()
.then(log.init)
.then(getAges)
.then(deleteLogs)
.catch(reportAndClose)
.then(close)