log-processor.ts 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. import { Resource } from "@opencode-ai/console-resource"
  2. import type { TraceItem } from "@cloudflare/workers-types"
  3. export default {
  4. async tail(events: TraceItem[]) {
  5. for (const event of events) {
  6. if (!event.event) continue
  7. if (!("request" in event.event)) continue
  8. if (event.event.request.method !== "POST") continue
  9. const url = new URL(event.event.request.url)
  10. if (
  11. url.pathname !== "/zen/v1/chat/completions" &&
  12. url.pathname !== "/zen/v1/messages" &&
  13. url.pathname !== "/zen/v1/responses"
  14. )
  15. return
  16. let metrics = {
  17. event_type: "completions",
  18. "cf.continent": event.event.request.cf?.continent,
  19. "cf.country": event.event.request.cf?.country,
  20. "cf.city": event.event.request.cf?.city,
  21. "cf.region": event.event.request.cf?.region,
  22. "cf.latitude": event.event.request.cf?.latitude,
  23. "cf.longitude": event.event.request.cf?.longitude,
  24. "cf.timezone": event.event.request.cf?.timezone,
  25. duration: event.wallTime,
  26. request_length: parseInt(event.event.request.headers["content-length"] ?? "0"),
  27. status: event.event.response?.status ?? 0,
  28. ip: event.event.request.headers["x-real-ip"],
  29. }
  30. for (const log of event.logs) {
  31. for (const message of log.message) {
  32. if (!message.startsWith("_metric:")) continue
  33. metrics = { ...metrics, ...JSON.parse(message.slice(8)) }
  34. }
  35. }
  36. console.log(JSON.stringify(metrics, null, 2))
  37. const ret = await fetch("https://api.honeycomb.io/1/events/zen", {
  38. method: "POST",
  39. headers: {
  40. "Content-Type": "application/json",
  41. "X-Honeycomb-Event-Time": (event.eventTimestamp ?? Date.now()).toString(),
  42. "X-Honeycomb-Team": Resource.HONEYCOMB_API_KEY.value,
  43. },
  44. body: JSON.stringify(metrics),
  45. })
  46. console.log(ret.status)
  47. console.log(await ret.text())
  48. }
  49. },
  50. }