New wakeup flow: 1. Create private Discord channel for the agent 2. Send wakeup message with slot context + workflow reference 3. If Dirigent detected (globalThis.__dirigent), create work-type channel 4. Fallback to api.spawn if Discord not configured New config fields: discordBotToken, discordGuildId New file: plugin/calendar/discord-wakeup.ts Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
36 lines
1.3 KiB
TypeScript
36 lines
1.3 KiB
TypeScript
/**
|
|
* HarborForge Calendar — Plugin Module
|
|
*
|
|
* PLG-CAL-001: Calendar heartbeat request/response format definition.
|
|
* PLG-CAL-002: Plugin-side slot execution scheduler and agent wakeup.
|
|
*
|
|
* Exports:
|
|
* • Types for heartbeat request/response and slot update
|
|
* • CalendarBridgeClient — HTTP client for backend communication
|
|
* • createCalendarBridgeClient — factory from plugin API context
|
|
* • CalendarScheduler — manages periodic heartbeat and slot execution
|
|
* • createCalendarScheduler — factory for scheduler
|
|
* • AgentWakeContext — context passed to agent when waking
|
|
*
|
|
* Usage in plugin/index.ts:
|
|
* import { createCalendarBridgeClient, createCalendarScheduler } from './calendar';
|
|
*
|
|
* const agentId = process.env.AGENT_ID || 'unknown';
|
|
* const calendar = createCalendarBridgeClient(api, 'https://monitor.hangman-lab.top', agentId);
|
|
*
|
|
* const scheduler = createCalendarScheduler({
|
|
* bridge: calendar,
|
|
* getAgentStatus: async () => { ... },
|
|
* wakeAgent: async (context) => { ... },
|
|
* logger: api.logger,
|
|
* });
|
|
*
|
|
* scheduler.start();
|
|
*/
|
|
|
|
export * from './types';
|
|
export * from './calendar-bridge';
|
|
export * from './scheduler';
|
|
export * from './schedule-cache';
|
|
export * from './discord-wakeup';
|