- Create new @link-stack/logger package wrapping Pino for structured logging - Replace all console.log/error/warn statements across the monorepo - Configure environment-aware logging (pretty-print in dev, JSON in prod) - Add automatic redaction of sensitive fields (passwords, tokens, etc.) - Remove dead commented-out logger file from bridge-worker - Follow Pino's standard argument order (context object first, message second) - Support log levels via LOG_LEVEL environment variable - Export TypeScript types for better IDE support This provides consistent, structured logging across all applications and packages, making debugging easier and production logs more parseable.
37 lines
954 B
TypeScript
37 lines
954 B
TypeScript
import { db } from "@link-stack/bridge-common";
|
|
import { createLogger } from "@link-stack/logger";
|
|
|
|
const logger = createLogger('bridge-worker-send-whatsapp-message');
|
|
|
|
interface SendWhatsappMessageTaskOptions {
|
|
token: string;
|
|
to: string;
|
|
message: any;
|
|
}
|
|
|
|
const sendWhatsappMessageTask = async ({
|
|
message,
|
|
to,
|
|
token,
|
|
}: SendWhatsappMessageTaskOptions): Promise<void> => {
|
|
const bot = await db
|
|
.selectFrom("WhatsappBot")
|
|
.selectAll()
|
|
.where("token", "=", token)
|
|
.executeTakeFirstOrThrow();
|
|
|
|
const url = `${process.env.BRIDGE_WHATSAPP_URL}/api/bots/${bot.id}/send`;
|
|
const params = { message, phoneNumber: to };
|
|
try {
|
|
const result = await fetch(url, {
|
|
method: "POST",
|
|
headers: { "Content-Type": "application/json" },
|
|
body: JSON.stringify(params),
|
|
});
|
|
} catch (error) {
|
|
logger.error({ error });
|
|
throw new Error("Failed to send message");
|
|
}
|
|
};
|
|
|
|
export default sendWhatsappMessageTask;
|