Implements FED-010: Agent Spawn via Federation feature that enables spawning and managing Claude agents on remote federated Mosaic Stack instances via COMMAND message type. Features: - Federation agent command types (spawn, status, kill) - FederationAgentService for handling agent operations - Integration with orchestrator's agent spawner/lifecycle services - API endpoints for spawning, querying status, and killing agents - Full command routing through federation COMMAND infrastructure - Comprehensive test coverage (12/12 tests passing) Architecture: - Hub → Spoke: Spawn agents on remote instances - Command flow: FederationController → FederationAgentService → CommandService → Remote Orchestrator - Response handling: Remote orchestrator returns agent status/results - Security: Connection validation, signature verification Files created: - apps/api/src/federation/types/federation-agent.types.ts - apps/api/src/federation/federation-agent.service.ts - apps/api/src/federation/federation-agent.service.spec.ts Files modified: - apps/api/src/federation/command.service.ts (agent command routing) - apps/api/src/federation/federation.controller.ts (agent endpoints) - apps/api/src/federation/federation.module.ts (service registration) - apps/orchestrator/src/api/agents/agents.controller.ts (status endpoint) - apps/orchestrator/src/api/agents/agents.module.ts (lifecycle integration) Testing: - 12/12 tests passing for FederationAgentService - All command service tests passing - TypeScript compilation successful - Linting passed Refs #93 Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
62 lines
1.6 KiB
Markdown
62 lines
1.6 KiB
Markdown
---
|
|
name: mosaic-plugin-cron
|
|
description: Schedule recurring commands and reminders with cron expressions
|
|
version: 0.0.1
|
|
triggers:
|
|
- "schedule a reminder"
|
|
- "create cron job"
|
|
- "list my schedules"
|
|
- "delete schedule"
|
|
- "enable schedule"
|
|
- "disable schedule"
|
|
tools:
|
|
- mosaic_cron_api
|
|
---
|
|
|
|
# Mosaic Cron Plugin
|
|
|
|
Schedule recurring commands and reminders for your workspace using cron expressions.
|
|
|
|
## Usage Examples
|
|
|
|
- "Schedule a reminder at 9am every day: morning briefing"
|
|
- "Create a cron job: 0 17 \* \* 1-5 for daily standup"
|
|
- "Show all my schedules"
|
|
- "Delete the 9am daily reminder"
|
|
|
|
## Cron Expression Format
|
|
|
|
Standard cron format: `minute hour day-of-month month day-of-week`
|
|
|
|
| Field | Values | Example |
|
|
| ------------ | ------ | ----------------- |
|
|
| Minute | 0-59 | `0` = top of hour |
|
|
| Hour | 0-23 | `9` = 9am |
|
|
| Day of Month | 1-31 | `*` = every day |
|
|
| Month | 1-12 | `*` = every month |
|
|
| Day of Week | 0-6 | `1-5` = Mon-Fri |
|
|
|
|
### Common Examples
|
|
|
|
- `0 9 * * *` - Every day at 9am
|
|
- `0 8 * * 1` - Every Monday at 8am
|
|
- `0 17 * * 1-5` - Mon-Fri at 5pm
|
|
- `0 0 1 * *` - First day of every month at midnight
|
|
- `*/15 * * * *` - Every 15 minutes
|
|
|
|
## API Endpoints
|
|
|
|
All cron operations are available via the Mosaic API:
|
|
|
|
- `POST /api/cron` - Create schedule
|
|
- `GET /api/cron` - List schedules
|
|
- `GET /api/cron/:id` - Get schedule
|
|
- `PATCH /api/cron/:id` - Update schedule
|
|
- `DELETE /api/cron/:id` - Delete schedule
|
|
|
|
## Permissions
|
|
|
|
- **Create/Update schedules**: Workspace MEMBER or higher
|
|
- **Delete schedules**: Workspace ADMIN or higher
|
|
- **View schedules**: Any workspace member
|