Add mitra online/offline status with heartbeat-based auto-offline, customer-mitra pairing via Valkey pub/sub blast, session management, and control center dashboard with real-time stats. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
32 lines
1.1 KiB
JavaScript
32 lines
1.1 KiB
JavaScript
import { getDb } from '../db/client.js'
|
|
|
|
const sql = getDb()
|
|
|
|
export const getAnonymityConfig = async () => {
|
|
const [row] = await sql`SELECT value FROM app_config WHERE key = 'anonymity'`
|
|
return { anonymity_enabled: row?.value?.enabled ?? true }
|
|
}
|
|
|
|
export const setAnonymityConfig = async (enabled) => {
|
|
await sql`
|
|
INSERT INTO app_config (key, value, updated_at)
|
|
VALUES ('anonymity', ${sql.json({ enabled })}, NOW())
|
|
ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value, updated_at = NOW()
|
|
`
|
|
return { anonymity_enabled: enabled }
|
|
}
|
|
|
|
export const getMaxCustomersPerMitra = async () => {
|
|
const [row] = await sql`SELECT value FROM app_config WHERE key = 'max_customers_per_mitra'`
|
|
return { max_customers_per_mitra: row?.value?.value ?? 3 }
|
|
}
|
|
|
|
export const setMaxCustomersPerMitra = async (value) => {
|
|
await sql`
|
|
INSERT INTO app_config (key, value, updated_at)
|
|
VALUES ('max_customers_per_mitra', ${sql.json({ value })}, NOW())
|
|
ON CONFLICT (key) DO UPDATE SET value = EXCLUDED.value, updated_at = NOW()
|
|
`
|
|
return { max_customers_per_mitra: value }
|
|
}
|