laconic-console/packages/console-server/src/resolvers/log.js

93 lines
2.3 KiB
JavaScript
Raw Normal View History

2020-06-10 20:36:54 +00:00
//
// Copyright 2020 DxOS.org
//
2020-06-10 22:15:07 +00:00
import { spawnSync } from 'child_process';
2020-06-10 20:36:54 +00:00
class LogCache {
constructor(maxLines = 500) {
// Sets in JS iterate in insertion order.
this.buffer = new Set();
this.maxLines = maxLines;
}
append(lines) {
const added = [];
for (const line of lines) {
if (!this.buffer.has(line)) {
this.buffer.add(line);
added.push(line);
}
}
if (this.buffer.size > this.maxLines) {
this.buffer = new Set(Array.from(this.buffer).slice(parseInt(this.maxLines / 2)));
}
return added;
}
}
const _caches = new Map();
2020-06-10 22:56:08 +00:00
2020-06-10 20:36:54 +00:00
const getLogCache = (name) => {
let cache = _caches.get(name);
if (!cache) {
cache = new LogCache();
_caches.set(name, cache);
}
return cache;
}
2020-06-10 22:56:08 +00:00
const getLogs = async (name, incremental = false, lines = 100) => {
2020-06-10 20:36:54 +00:00
const command = 'wire';
const args = ['service', 'logs', '--lines', lines, name];
const child = spawnSync(command, args, { encoding: 'utf8' });
const logLines = child.stdout.split(/\n/);
const cache = getLogCache(name);
2020-06-10 22:56:08 +00:00
const added = cache.append(logLines);
return incremental ? added : Array.from(cache.buffer);
2020-06-10 20:36:54 +00:00
};
export const logResolvers = {
Query: {
2020-06-10 22:56:08 +00:00
wns_log: async (_, { incremental }) => {
const logs = await getLogs('wns-lite', incremental);
2020-06-10 20:36:54 +00:00
return {
timestamp: new Date().toUTCString(),
json: JSON.stringify(logs)
};
2020-06-10 22:15:07 +00:00
},
2020-06-10 22:56:08 +00:00
signal_log: async (_, { incremental }) => {
const logs = await getLogs('signal', incremental);
2020-06-10 22:15:07 +00:00
return {
timestamp: new Date().toUTCString(),
json: JSON.stringify(logs)
};
},
2020-06-10 22:56:08 +00:00
ipfs_log: async (_, { incremental }) => {
const logs = await getLogs('ipfs', incremental);
2020-06-10 22:15:07 +00:00
return {
timestamp: new Date().toUTCString(),
json: JSON.stringify(logs)
};
},
2020-06-10 22:56:08 +00:00
ipfs_swarm_log: async (_, { incremental }) => {
const logs = await getLogs('ipfs-swarm-connect', incremental);
2020-06-10 22:15:07 +00:00
return {
timestamp: new Date().toUTCString(),
json: JSON.stringify(logs)
};
},
2020-06-10 22:56:08 +00:00
app_log: async (_, { incremental }) => {
const logs = await getLogs('app', incremental);
2020-06-10 22:15:07 +00:00
return {
timestamp: new Date().toUTCString(),
json: JSON.stringify(logs)
};
2020-06-10 20:36:54 +00:00
}
}
};