1
0
mirror of https://git.tuxpa.in/a/code-server.git synced 2025-01-09 17:58:45 +00:00
code-server-2/src/insights.ts

59 lines
1.4 KiB
TypeScript
Raw Normal View History

2019-08-09 23:50:05 +00:00
import * as appInsights from "applicationinsights";
import * as https from "https";
import * as os from "os";
2019-07-16 19:57:02 +00:00
export class TelemetryClient implements appInsights.TelemetryClient {
public config: any = {};
public channel = {
setUseDiskRetryCaching: (): void => undefined,
};
2019-07-16 19:57:02 +00:00
public trackEvent(options: appInsights.EventTelemetry): void {
if (!options.properties) {
options.properties = {};
}
if (!options.measurements) {
options.measurements = {};
}
try {
const cpus = os.cpus();
2019-07-16 19:57:02 +00:00
options.measurements.cores = cpus.length;
options.properties["common.cpuModel"] = cpus[0].model;
} catch (error) {}
try {
2019-07-16 19:57:02 +00:00
options.measurements.memoryFree = os.freemem();
options.measurements.memoryTotal = os.totalmem();
} catch (error) {}
try {
2019-07-16 19:57:02 +00:00
options.properties["common.shell"] = os.userInfo().shell;
options.properties["common.release"] = os.release();
options.properties["common.arch"] = os.arch();
} catch (error) {}
try {
const request = https.request({
host: "v1.telemetry.coder.com",
port: 443,
path: "/track",
method: "POST",
headers: {
"Content-Type": "application/json",
},
});
2019-07-16 19:57:02 +00:00
request.on("error", () => { /* We don't care. */ });
request.write(JSON.stringify(options));
request.end();
2019-07-16 19:57:02 +00:00
} catch (error) {}
}
2019-07-16 19:57:02 +00:00
public flush(options: appInsights.FlushOptions): void {
if (options.callback) {
options.callback("");
}
}
}