diff options
author | The Arcane Brony <myrainbowdash949@gmail.com> | 2021-12-22 17:43:39 +0000 |
---|---|---|
committer | The Arcane Brony <myrainbowdash949@gmail.com> | 2021-12-22 18:43:39 +0100 |
commit | 252051b95abb427f2bc8acf20de1c2b1fe64bcba (patch) | |
tree | b4e5317d8b84d075d7f221ca70fd27efb2d66d93 /bundle | |
parent | Improve build scripts, strip more fs-extras (diff) | |
download | server-252051b95abb427f2bc8acf20de1c2b1fe64bcba.tar.xz |
Add Sentry, fix compile errors
Diffstat (limited to 'bundle')
-rw-r--r-- | bundle/package.json | 7 | ||||
-rw-r--r-- | bundle/src/Server.ts | 26 | ||||
-rw-r--r-- | bundle/tsconfig.json | 6 |
3 files changed, 37 insertions, 2 deletions
diff --git a/bundle/package.json b/bundle/package.json index 17d59a25..97066bd8 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -59,6 +59,12 @@ "@aws-sdk/node-http-handler": "^3.36.0", "@babel/preset-env": "^7.15.8", "@babel/preset-typescript": "^7.15.0", + "@fosscord/api": "file:../api", + "@fosscord/cdn": "file:../cdn", + "@fosscord/gateway": "file:../gateway", + "@fosscord/util": "file:../util", + "@sentry/node": "^6.16.1", + "@sentry/tracing": "^6.16.1", "ajv": "8.6.2", "ajv-formats": "^2.1.1", "amqplib": "^0.8.0", @@ -95,6 +101,7 @@ "reflect-metadata": "^0.1.13", "sqlite3": "^5.0.2", "supertest": "^6.1.6", + "tslib": "^2.3.1", "typeorm": "^0.2.37", "typescript": "^4.1.2", "typescript-json-schema": "^0.50.1", diff --git a/bundle/src/Server.ts b/bundle/src/Server.ts index e461ec5f..d07a6ce0 100644 --- a/bundle/src/Server.ts +++ b/bundle/src/Server.ts @@ -8,6 +8,8 @@ import { CDNServer } from "@fosscord/cdn"; import express from "express"; import { green, bold } from "nanocolors"; import { Config, initDatabase } from "@fosscord/util"; +import * as Sentry from "@sentry/node"; +import * as Tracing from "@sentry/tracing"; const app = express(); const server = http.createServer(); @@ -56,7 +58,31 @@ async function main() { // }, } as any); + //Sentry + if (Config.get().sentry.enabled) { + console.log( + "[Bundle] You are using Sentry! This may slightly impact performance on large loads!" + ); + Sentry.init({ + dsn: Config.get().sentry.endpoint, + integrations: [ + new Sentry.Integrations.Http({ tracing: true }), + new Tracing.Integrations.Express({ app }), + ], + tracesSampleRate: Config.get().sentry.traceSampleRate, + }); + + app.use(Sentry.Handlers.requestHandler()); + app.use(Sentry.Handlers.tracingHandler()); + } await Promise.all([api.start(), cdn.start(), gateway.start()]); + if (Config.get().sentry.enabled) { + app.use(Sentry.Handlers.errorHandler()); + app.use(function onError(err: any, req: any, res: any, next: any) { + res.statusCode = 500; + res.end(res.sentry + "\n"); + }); + } console.log(`[Server] ${green(`listening on port ${bold(port)}`)}`); } diff --git a/bundle/tsconfig.json b/bundle/tsconfig.json index 58c61132..2257b4ab 100644 --- a/bundle/tsconfig.json +++ b/bundle/tsconfig.json @@ -45,7 +45,7 @@ // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ /* Module Resolution Options */ - // "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ + "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ // "typeRoots": [], /* List of folders to include type definitions from. */ "types": [ @@ -79,6 +79,8 @@ "@fosscord/cdn": ["cdn/src/index"], "@fosscord/util": ["util/src/index"] }, - "plugins": [{ "transform": "@zerollup/ts-transform-paths" }] + "plugins": [{ "transform": "@zerollup/ts-transform-paths" }], + "noEmitHelpers": true, + "importHelpers": true } } |