Docs: Script para scrapear documentacion de Baileys API
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 1m3s
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 1m3s
- Script en scripts/scrape-baileys-docs.ts - Genera docs/baileys-api-reference.md con 6433 lineas - 79 secciones: interfaces, types, functions, variables, enums - Referencia completa para desarrollo de mensajes
This commit is contained in:
42
server/api/debug/groups/create.post.ts
Normal file
42
server/api/debug/groups/create.post.ts
Normal file
@@ -0,0 +1,42 @@
|
||||
/**
|
||||
* POST /api/debug/groups/create
|
||||
* Create a new group
|
||||
*/
|
||||
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, name, participants } = body
|
||||
|
||||
if (!instanceId) {
|
||||
throw createError({ statusCode: 400, message: 'instanceId is required' })
|
||||
}
|
||||
|
||||
if (!name) {
|
||||
throw createError({ statusCode: 400, message: 'name is required' })
|
||||
}
|
||||
|
||||
if (!participants || !Array.isArray(participants) || participants.length === 0) {
|
||||
throw createError({ statusCode: 400, message: 'participants array is required' })
|
||||
}
|
||||
|
||||
const socket = baileysManager.getSocket(instanceId)
|
||||
if (!socket) {
|
||||
throw createError({ statusCode: 400, message: 'Instance not connected' })
|
||||
}
|
||||
|
||||
try {
|
||||
const result = await socket.groupCreate(name, participants)
|
||||
return { success: true, data: result }
|
||||
} catch (error) {
|
||||
throw createError({
|
||||
statusCode: 500,
|
||||
message: `Failed to create group: ${(error as Error).message}`
|
||||
})
|
||||
}
|
||||
})
|
||||
42
server/api/debug/groups/description.post.ts
Normal file
42
server/api/debug/groups/description.post.ts
Normal file
@@ -0,0 +1,42 @@
|
||||
/**
|
||||
* POST /api/debug/groups/description
|
||||
* Update group description
|
||||
*/
|
||||
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, description } = body
|
||||
|
||||
if (!instanceId) {
|
||||
throw createError({ statusCode: 400, message: 'instanceId is required' })
|
||||
}
|
||||
|
||||
if (!jid) {
|
||||
throw createError({ statusCode: 400, message: 'jid is required' })
|
||||
}
|
||||
|
||||
if (description === undefined) {
|
||||
throw createError({ statusCode: 400, message: 'description is required' })
|
||||
}
|
||||
|
||||
const socket = baileysManager.getSocket(instanceId)
|
||||
if (!socket) {
|
||||
throw createError({ statusCode: 400, message: 'Instance not connected' })
|
||||
}
|
||||
|
||||
try {
|
||||
await socket.groupUpdateDescription(jid, description)
|
||||
return { success: true, message: 'Group description updated successfully' }
|
||||
} catch (error) {
|
||||
throw createError({
|
||||
statusCode: 500,
|
||||
message: `Failed to update group description: ${(error as Error).message}`
|
||||
})
|
||||
}
|
||||
})
|
||||
44
server/api/debug/groups/invite-code.post.ts
Normal file
44
server/api/debug/groups/invite-code.post.ts
Normal file
@@ -0,0 +1,44 @@
|
||||
/**
|
||||
* POST /api/debug/groups/invite-code
|
||||
* Get group invite code
|
||||
*/
|
||||
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 } = body
|
||||
|
||||
if (!instanceId) {
|
||||
throw createError({ statusCode: 400, message: 'instanceId is required' })
|
||||
}
|
||||
|
||||
if (!jid) {
|
||||
throw createError({ statusCode: 400, message: 'jid is required' })
|
||||
}
|
||||
|
||||
const socket = baileysManager.getSocket(instanceId)
|
||||
if (!socket) {
|
||||
throw createError({ statusCode: 400, message: 'Instance not connected' })
|
||||
}
|
||||
|
||||
try {
|
||||
const code = await socket.groupInviteCode(jid)
|
||||
return {
|
||||
success: true,
|
||||
data: {
|
||||
code,
|
||||
link: `https://chat.whatsapp.com/${code}`
|
||||
}
|
||||
}
|
||||
} catch (error) {
|
||||
throw createError({
|
||||
statusCode: 500,
|
||||
message: `Failed to get invite code: ${(error as Error).message}`
|
||||
})
|
||||
}
|
||||
})
|
||||
38
server/api/debug/groups/metadata.post.ts
Normal file
38
server/api/debug/groups/metadata.post.ts
Normal file
@@ -0,0 +1,38 @@
|
||||
/**
|
||||
* POST /api/debug/groups/metadata
|
||||
* Get group metadata
|
||||
*/
|
||||
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 } = body
|
||||
|
||||
if (!instanceId) {
|
||||
throw createError({ statusCode: 400, message: 'instanceId is required' })
|
||||
}
|
||||
|
||||
if (!jid) {
|
||||
throw createError({ statusCode: 400, message: 'jid is required' })
|
||||
}
|
||||
|
||||
const socket = baileysManager.getSocket(instanceId)
|
||||
if (!socket) {
|
||||
throw createError({ statusCode: 400, message: 'Instance not connected' })
|
||||
}
|
||||
|
||||
try {
|
||||
const result = await socket.groupMetadata(jid)
|
||||
return { success: true, data: result }
|
||||
} catch (error) {
|
||||
throw createError({
|
||||
statusCode: 500,
|
||||
message: `Failed to get group metadata: ${(error as Error).message}`
|
||||
})
|
||||
}
|
||||
})
|
||||
57
server/api/debug/groups/participants.post.ts
Normal file
57
server/api/debug/groups/participants.post.ts
Normal file
@@ -0,0 +1,57 @@
|
||||
/**
|
||||
* POST /api/debug/groups/participants
|
||||
* Update group participants (add, remove, promote, demote)
|
||||
*/
|
||||
import { baileysManager } from '../../../services/baileys/manager'
|
||||
|
||||
type ParticipantAction = 'add' | 'remove' | 'promote' | 'demote'
|
||||
|
||||
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, participants, action } = body as {
|
||||
instanceId: string
|
||||
jid: string
|
||||
participants: string[]
|
||||
action: ParticipantAction
|
||||
}
|
||||
|
||||
if (!instanceId) {
|
||||
throw createError({ statusCode: 400, message: 'instanceId is required' })
|
||||
}
|
||||
|
||||
if (!jid) {
|
||||
throw createError({ statusCode: 400, message: 'jid is required' })
|
||||
}
|
||||
|
||||
if (!participants || !Array.isArray(participants) || participants.length === 0) {
|
||||
throw createError({ statusCode: 400, message: 'participants array is required' })
|
||||
}
|
||||
|
||||
const validActions: ParticipantAction[] = ['add', 'remove', 'promote', 'demote']
|
||||
if (!action || !validActions.includes(action)) {
|
||||
throw createError({
|
||||
statusCode: 400,
|
||||
message: `action must be one of: ${validActions.join(', ')}`
|
||||
})
|
||||
}
|
||||
|
||||
const socket = baileysManager.getSocket(instanceId)
|
||||
if (!socket) {
|
||||
throw createError({ statusCode: 400, message: 'Instance not connected' })
|
||||
}
|
||||
|
||||
try {
|
||||
const result = await socket.groupParticipantsUpdate(jid, participants, action)
|
||||
return { success: true, data: result }
|
||||
} catch (error) {
|
||||
throw createError({
|
||||
statusCode: 500,
|
||||
message: `Failed to update participants: ${(error as Error).message}`
|
||||
})
|
||||
}
|
||||
})
|
||||
42
server/api/debug/groups/subject.post.ts
Normal file
42
server/api/debug/groups/subject.post.ts
Normal file
@@ -0,0 +1,42 @@
|
||||
/**
|
||||
* POST /api/debug/groups/subject
|
||||
* Update group subject (name)
|
||||
*/
|
||||
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, subject } = body
|
||||
|
||||
if (!instanceId) {
|
||||
throw createError({ statusCode: 400, message: 'instanceId is required' })
|
||||
}
|
||||
|
||||
if (!jid) {
|
||||
throw createError({ statusCode: 400, message: 'jid is required' })
|
||||
}
|
||||
|
||||
if (!subject) {
|
||||
throw createError({ statusCode: 400, message: 'subject is required' })
|
||||
}
|
||||
|
||||
const socket = baileysManager.getSocket(instanceId)
|
||||
if (!socket) {
|
||||
throw createError({ statusCode: 400, message: 'Instance not connected' })
|
||||
}
|
||||
|
||||
try {
|
||||
await socket.groupUpdateSubject(jid, subject)
|
||||
return { success: true, message: 'Group subject updated successfully' }
|
||||
} catch (error) {
|
||||
throw createError({
|
||||
statusCode: 500,
|
||||
message: `Failed to update group subject: ${(error as Error).message}`
|
||||
})
|
||||
}
|
||||
})
|
||||
Reference in New Issue
Block a user