mirror of https://github.com/lukechilds/Agama.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
92 lines
2.7 KiB
92 lines
2.7 KiB
7 years ago
|
module.exports = (shepherd) => {
|
||
|
/*
|
||
|
* type: GET
|
||
|
* params: herd, lastLines
|
||
|
*/
|
||
|
shepherd.post('/debuglog', (req, res) => {
|
||
|
let _herd = req.body.herdname;
|
||
|
let _ac = req.body.ac;
|
||
|
let _lastNLines = req.body.lastLines;
|
||
|
let _location;
|
||
|
|
||
|
if (shepherd.os.platform() === 'darwin') {
|
||
|
shepherd.komodoDir = shepherd.appConfig.dataDir.length ? shepherd.appConfig.dataDir : `${process.env.HOME}/Library/Application Support/Komodo`;
|
||
|
}
|
||
|
|
||
|
if (shepherd.os.platform() === 'linux') {
|
||
|
shepherd.komodoDir = shepherd.appConfig.dataDir.length ? shepherd.appConfig.dataDir : `${process.env.HOME}/.komodo`;
|
||
|
}
|
||
|
|
||
|
if (shepherd.os.platform() === 'win32') {
|
||
|
shepherd.komodoDir = shepherd.appConfig.dataDir.length ? shepherd.appConfig.dataDir : `${process.env.APPDATA}/Komodo`;
|
||
|
shepherd.komodoDir = shepherd.path.normalize(shepherd.komodoDir);
|
||
|
}
|
||
|
|
||
|
if (_herd === 'komodo') {
|
||
|
_location = shepherd.komodoDir;
|
||
|
}
|
||
|
|
||
|
if (_ac) {
|
||
|
_location = `${shepherd.komodoDir}/${_ac}`;
|
||
|
|
||
|
if (_ac === 'CHIPS') {
|
||
|
_location = shepherd.chipsDir;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
shepherd.readDebugLog(`${_location}/debug.log`, _lastNLines)
|
||
|
.then((result) => {
|
||
|
const _obj = {
|
||
|
msg: 'success',
|
||
|
result: result,
|
||
|
};
|
||
|
|
||
|
res.end(JSON.stringify(_obj));
|
||
|
}, (result) => {
|
||
|
const _obj = {
|
||
|
msg: 'error',
|
||
|
result: result,
|
||
|
};
|
||
|
|
||
|
res.end(JSON.stringify(_obj));
|
||
|
});
|
||
|
});
|
||
|
|
||
|
|
||
|
shepherd.readDebugLog = (fileLocation, lastNLines) => {
|
||
|
return new shepherd.Promise(
|
||
|
(resolve, reject) => {
|
||
|
if (lastNLines) {
|
||
|
try {
|
||
|
shepherd._fs.access(fileLocation, shepherd.fs.constants.R_OK, (err) => {
|
||
|
if (err) {
|
||
|
shepherd.log(`error reading ${fileLocation}`);
|
||
|
shepherd.writeLog(`error reading ${fileLocation}`);
|
||
|
reject(`readDebugLog error: ${err}`);
|
||
|
} else {
|
||
|
shepherd.log(`reading ${fileLocation}`);
|
||
|
shepherd._fs.readFile(fileLocation, 'utf-8', (err, data) => {
|
||
|
if (err) {
|
||
|
shepherd.writeLog(`readDebugLog err: ${err}`);
|
||
|
shepherd.log(`readDebugLog err: ${err}`);
|
||
|
}
|
||
|
|
||
|
const lines = data.trim().split('\n');
|
||
|
const lastLine = lines.slice(lines.length - lastNLines, lines.length).join('\n');
|
||
|
|
||
|
resolve(lastLine);
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
} catch (e) {
|
||
|
reject(`readDebugLog error: ${e}`);
|
||
|
}
|
||
|
} else {
|
||
|
reject('readDebugLog error: lastNLines param is not provided!');
|
||
|
}
|
||
|
}
|
||
|
);
|
||
|
};
|
||
|
|
||
|
return shepherd;
|
||
|
};
|