Fix: Checkboxes de eventos en formulario de webhook
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 1m2s

This commit is contained in:
2025-12-02 20:39:16 -06:00
parent 738584514d
commit ae8e4e37a7
6 changed files with 214 additions and 5 deletions

View File

@@ -0,0 +1,34 @@
/**
* GET /api/debug/blocklist
* Fetch the blocklist for an instance
*/
import { baileysManager } from '../../../services/baileys/manager'
export default defineEventHandler(async (event) => {
const username = getHeader(event, 'x-authentik-username')
if (!username) {
throw createError({ statusCode: 401, message: 'Unauthorized' })
}
const query = getQuery(event)
const instanceId = query.instanceId as string
if (!instanceId) {
throw createError({ statusCode: 400, message: 'instanceId is required' })
}
const socket = baileysManager.getSocket(instanceId)
if (!socket) {
throw createError({ statusCode: 400, message: 'Instance not connected' })
}
try {
const result = await socket.fetchBlocklist()
return { success: true, data: result }
} catch (error) {
throw createError({
statusCode: 500,
message: `Failed to fetch blocklist: ${(error as Error).message}`
})
}
})

View File

@@ -0,0 +1,42 @@
/**
* POST /api/debug/blocklist/update
* Block or unblock a JID
*/
import { baileysManager } from '../../../services/baileys/manager'
export default defineEventHandler(async (event) => {
const username = getHeader(event, 'x-authentik-username')
if (!username) {
throw createError({ statusCode: 401, message: 'Unauthorized' })
}
const body = await readBody(event)
const { instanceId, jid, action } = body
if (!instanceId) {
throw createError({ statusCode: 400, message: 'instanceId is required' })
}
if (!jid) {
throw createError({ statusCode: 400, message: 'jid is required' })
}
if (!action || !['block', 'unblock'].includes(action)) {
throw createError({ statusCode: 400, message: 'action must be "block" or "unblock"' })
}
const socket = baileysManager.getSocket(instanceId)
if (!socket) {
throw createError({ statusCode: 400, message: 'Instance not connected' })
}
try {
await socket.updateBlockStatus(jid, action)
return { success: true, message: `User ${action}ed successfully` }
} catch (error) {
throw createError({
statusCode: 500,
message: `Failed to ${action} user: ${(error as Error).message}`
})
}
})

View File

@@ -0,0 +1,34 @@
/**
* GET /api/debug/privacy
* Fetch privacy settings for an instance
*/
import { baileysManager } from '../../../services/baileys/manager'
export default defineEventHandler(async (event) => {
const username = getHeader(event, 'x-authentik-username')
if (!username) {
throw createError({ statusCode: 401, message: 'Unauthorized' })
}
const query = getQuery(event)
const instanceId = query.instanceId as string
if (!instanceId) {
throw createError({ statusCode: 400, message: 'instanceId is required' })
}
const socket = baileysManager.getSocket(instanceId)
if (!socket) {
throw createError({ statusCode: 400, message: 'Instance not connected' })
}
try {
const result = await socket.fetchPrivacySettings(true)
return { success: true, data: result }
} catch (error) {
throw createError({
statusCode: 500,
message: `Failed to fetch privacy settings: ${(error as Error).message}`
})
}
})

View File

@@ -0,0 +1,72 @@
/**
* POST /api/debug/privacy/update
* Update a privacy setting
*/
import { baileysManager } from '../../../services/baileys/manager'
type PrivacySetting = 'lastSeen' | 'online' | 'profilePicture' | 'status' | 'groupsAdd' | 'readReceipts'
export default defineEventHandler(async (event) => {
const username = getHeader(event, 'x-authentik-username')
if (!username) {
throw createError({ statusCode: 401, message: 'Unauthorized' })
}
const body = await readBody(event)
const { instanceId, setting, value } = body as { instanceId: string; setting: PrivacySetting; value: string }
if (!instanceId) {
throw createError({ statusCode: 400, message: 'instanceId is required' })
}
if (!setting) {
throw createError({ statusCode: 400, message: 'setting is required' })
}
if (!value) {
throw createError({ statusCode: 400, message: 'value is required' })
}
const validSettings: PrivacySetting[] = ['lastSeen', 'online', 'profilePicture', 'status', 'groupsAdd', 'readReceipts']
if (!validSettings.includes(setting)) {
throw createError({
statusCode: 400,
message: `Invalid setting. Must be one of: ${validSettings.join(', ')}`
})
}
const socket = baileysManager.getSocket(instanceId)
if (!socket) {
throw createError({ statusCode: 400, message: 'Instance not connected' })
}
try {
switch (setting) {
case 'lastSeen':
await socket.updateLastSeenPrivacy(value as any)
break
case 'online':
await socket.updateOnlinePrivacy(value as any)
break
case 'profilePicture':
await socket.updateProfilePicturePrivacy(value as any)
break
case 'status':
await socket.updateStatusPrivacy(value as any)
break
case 'groupsAdd':
await socket.updateGroupsAddPrivacy(value as any)
break
case 'readReceipts':
await socket.updateReadReceiptsPrivacy(value as any)
break
}
return { success: true, message: `Privacy setting "${setting}" updated to "${value}"` }
} catch (error) {
throw createError({
statusCode: 500,
message: `Failed to update privacy setting: ${(error as Error).message}`
})
}
})

View File

@@ -465,6 +465,18 @@ class BaileysManager extends EventEmitter {
return Array.from(this.instances.values())
}
/**
* Get the raw socket for an instance (for debug purposes)
* Returns null if instance is not connected
*/
getSocket(instanceId: string): WASocket | null {
const managed = this.instances.get(instanceId)
if (!managed || managed.status !== 'connected') {
return null
}
return managed.socket
}
/**
* Update instance status in database
*/