3fc5c9ff7a
- Datenbank auf utf8mb4_unicode_ci migriert (migrate_to_utf8mb4.sh) - beos: Spalte 'role' (kommagetrennte Rollen: guide, admin, key, deleted) - BEO-Auswahl im Formular filtert nur noch role='guide' - logbuch_objekte: ObjektName-Spalte entfernt, stattdessen JOIN auf objekte - lib/db.ts: charset utf8mb4 in Connection-Pool - Session und Auth um role-Feld erweitert - compose.yml: phpMyAdmin mit Traefik unter /myadmin - compose.yml: MySQL auf 127.0.0.1:3336 für SSH-Tunnel (lokale Entwicklung) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
30 lines
776 B
TypeScript
30 lines
776 B
TypeScript
import mysql from 'mysql2/promise';
|
|
import type { QueryResult } from 'mysql2/promise';
|
|
|
|
const dbConfig = {
|
|
host: process.env.DB_HOST || 'mydbase_mysql',
|
|
port: process.env.DB_PORT ? parseInt(process.env.DB_PORT) : 3306,
|
|
user: process.env.DB_USER,
|
|
password: process.env.DB_PASS,
|
|
database: process.env.DB_NAME || 'logbuch',
|
|
charset: 'utf8mb4',
|
|
waitForConnections: true,
|
|
connectionLimit: 10,
|
|
queueLimit: 0,
|
|
};
|
|
|
|
let pool: mysql.Pool | null = null;
|
|
|
|
export function getPool() {
|
|
if (!pool) {
|
|
pool = mysql.createPool(dbConfig);
|
|
}
|
|
return pool;
|
|
}
|
|
|
|
export async function query(sql: string, params?: (string | number | null)[]): Promise<QueryResult> {
|
|
const p = getPool();
|
|
const [rows] = await p.execute(sql, params || []);
|
|
return rows as QueryResult;
|
|
}
|