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.
137 lines
3.9 KiB
137 lines
3.9 KiB
module.exports = (shepherd) => {
|
|
/*
|
|
* type: POST
|
|
* params: herd, lastLines
|
|
*/
|
|
shepherd.post('/debuglog', (req, res) => {
|
|
if (shepherd.checkToken(req.body.token)) {
|
|
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));
|
|
});
|
|
} else {
|
|
const errorObj = {
|
|
msg: 'error',
|
|
result: 'unauthorized access',
|
|
};
|
|
|
|
res.end(JSON.stringify(errorObj));
|
|
}
|
|
});
|
|
|
|
shepherd.get('/coind/stdout', (req, res) => {
|
|
if (shepherd.checkToken(req.query.token)) {
|
|
const _daemonName = req.query.chain !== 'komodod' ? req.query.chain : 'komodod';
|
|
const _daemonLogName = `${shepherd.agamaDir}/${_daemonName}.log`;
|
|
|
|
shepherd.readDebugLog(_daemonLogName, 'all')
|
|
.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));
|
|
});
|
|
} else {
|
|
const errorObj = {
|
|
msg: 'error',
|
|
result: 'unauthorized access',
|
|
};
|
|
|
|
res.end(JSON.stringify(errorObj));
|
|
}
|
|
});
|
|
|
|
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');
|
|
let lastLine;
|
|
|
|
if (lastNLines === 'all') {
|
|
lastLine = data.trim();
|
|
} else {
|
|
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;
|
|
};
|