log login events

This commit is contained in:
Lea 2024-01-19 14:18:23 +01:00
parent 93bcd9a445
commit 6795fa130b
Signed by: Lea
GPG key ID: 1BAFFE8347019C42
2 changed files with 21 additions and 9 deletions

View file

@ -3,6 +3,7 @@ import CredentialProvider from "next-auth/providers/credentials";
import { sha256sum } from "@/lib/util"; import { sha256sum } from "@/lib/util";
import { validateCredentials } from "@/lib/db"; import { validateCredentials } from "@/lib/db";
import { GRAVATAR_DEFAULT } from "@/lib/constants"; import { GRAVATAR_DEFAULT } from "@/lib/constants";
import { auditLogRaw } from "@/lib/audit";
const authOptions: AuthOptions = { const authOptions: AuthOptions = {
providers: [ providers: [
@ -17,8 +18,15 @@ const authOptions: AuthOptions = {
if (credentials && await validateCredentials(credentials.email, credentials.password)) { if (credentials && await validateCredentials(credentials.email, credentials.password)) {
console.log(`[${credentials.email}] Authentication succeeded`); console.log(`[${credentials.email}] Authentication succeeded`);
const emailHash = sha256sum(credentials.email.trim().toLowerCase()); const emailHash = sha256sum(credentials.email.trim().toLowerCase());
await auditLogRaw({
user: credentials.email,
ts: new Date().toISOString(),
action: "login",
});
return { return {
id: credentials.email, id: credentials.email,
email: credentials.email, email: credentials.email,

View file

@ -8,7 +8,7 @@ export type AuditLog = {
user?: string | null, user?: string | null,
ts: string, ts: string,
action: AuditLogAction, action: AuditLogAction,
data: any, data?: any,
} }
export function auditLog(action: AuditLogAction, data?: any) { export function auditLog(action: AuditLogAction, data?: any) {
@ -23,16 +23,20 @@ export function auditLog(action: AuditLogAction, data?: any) {
data: data, data: data,
}; };
console.log("Audit event:", log); await auditLogRaw(log);
if (process.env.AUDIT_FILE_PATH) {
await fs.appendFile(
process.env.AUDIT_FILE_PATH,
JSON.stringify(log) + "\n",
);
}
} catch (e) { } catch (e) {
console.error("Failed to write to log file:", e); console.error("Failed to write to log file:", e);
} }
})(); })();
} }
export async function auditLogRaw(log: AuditLog) {
console.log("Audit event:", log);
if (process.env.AUDIT_FILE_PATH) {
await fs.appendFile(
process.env.AUDIT_FILE_PATH,
JSON.stringify(log) + "\n",
);
}
}