Track queries with Sentry

This commit is contained in:
Alex Gleason 2023-12-06 14:49:01 -06:00
parent 709675754c
commit c532f54ea6
No known key found for this signature in database
GPG Key ID: 7211D1F99744FBB7
3 changed files with 24 additions and 17 deletions

11
src/sentry.ts Normal file
View File

@ -0,0 +1,11 @@
import { Conf } from './config.ts';
import { Sentry } from './deps.ts';
// Sentry
if (Conf.sentryDsn) {
console.log('Sentry enabled');
Sentry.init({
dsn: Conf.sentryDsn,
tracesSampleRate: 1.0,
});
}

View File

@ -1,15 +1,5 @@
import './precheck.ts'; import './precheck.ts';
import './sentry.ts';
import app from './app.ts'; import app from './app.ts';
import { Conf } from './config.ts';
import { Sentry } from './deps.ts';
// Sentry
if (Conf.sentryDsn) {
console.log('Sentry enabled');
Sentry.init({
dsn: Conf.sentryDsn,
tracesSampleRate: 1.0,
});
}
Deno.serve(app.fetch); Deno.serve(app.fetch);

View File

@ -1,6 +1,7 @@
/// <reference lib="webworker" /> /// <reference lib="webworker" />
import { Comlink, type CompiledQuery, DenoSqlite3, type QueryResult } from '@/deps.ts'; import { Comlink, type CompiledQuery, DenoSqlite3, type QueryResult, Sentry } from '@/deps.ts';
import '@/sentry.ts';
let db: DenoSqlite3 | undefined; let db: DenoSqlite3 | undefined;
@ -10,11 +11,16 @@ export const SqliteWorker = {
}, },
executeQuery<R>({ sql, parameters }: CompiledQuery): QueryResult<R> { executeQuery<R>({ sql, parameters }: CompiledQuery): QueryResult<R> {
if (!db) throw new Error('Database not open'); if (!db) throw new Error('Database not open');
return {
rows: db.prepare(sql).all(...parameters as any[]) as R[], const result: QueryResult<R> = Sentry.startSpan({ name: sql, op: 'db.query' }, () => {
numAffectedRows: BigInt(db.changes), return {
insertId: BigInt(db.lastInsertRowId), rows: db!.prepare(sql).all(...parameters as any[]) as R[],
}; numAffectedRows: BigInt(db!.changes),
insertId: BigInt(db!.lastInsertRowId),
};
});
return result;
}, },
destroy() { destroy() {
db?.close(); db?.close();