@aitne-sh/aitne 0.1.8 → 0.1.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +218 -161
- package/agent-assets/agent-profiles/_safety.md +3 -3
- package/agent-assets/agent-profiles/browser-task.md +108 -0
- package/agent-assets/agent-profiles/conversational.md +3 -3
- package/agent-assets/agent-profiles/profile-importer.md +2 -2
- package/agent-assets/agent-profiles/routine-fetch-window.md +30 -19
- package/agent-assets/agents/context-index-reconcile/agent.md +52 -0
- package/agent-assets/agents/evening-review/agent.md +53 -0
- package/agent-assets/agents/hourly-check/agent.md +62 -0
- package/agent-assets/agents/monthly-review/agent.md +55 -0
- package/agent-assets/agents/morning-routine/agent.md +78 -0
- package/agent-assets/agents/roadmap-maintenance/agent.md +52 -0
- package/agent-assets/agents/skill-curation/agent.md +52 -0
- package/agent-assets/agents/user-profile-sweep-evening/agent.md +48 -0
- package/agent-assets/agents/user-profile-sweep-morning/agent.md +53 -0
- package/agent-assets/agents/weekly-review/agent.md +51 -0
- package/agent-assets/docs/concepts/agent-day.md +13 -11
- package/agent-assets/docs/concepts/auth-health.md +47 -10
- package/agent-assets/docs/concepts/backends-and-tiers.md +66 -31
- package/agent-assets/docs/concepts/costs-and-quotas.md +50 -15
- package/agent-assets/docs/concepts/delegated-mode.md +52 -13
- package/agent-assets/docs/concepts/memory-model.md +72 -32
- package/agent-assets/docs/concepts/observations.md +49 -11
- package/agent-assets/docs/concepts/process-keys.md +56 -22
- package/agent-assets/docs/concepts/routines.md +60 -33
- package/agent-assets/docs/concepts/safety-and-execution.md +50 -21
- package/agent-assets/docs/concepts/safety-model.md +42 -34
- package/agent-assets/docs/concepts/skills.md +33 -17
- package/agent-assets/docs/features/integrations/browser-history.md +195 -0
- package/agent-assets/docs/features/integrations/calendar.md +39 -29
- package/agent-assets/docs/features/integrations/git.md +18 -7
- package/agent-assets/docs/features/integrations/github.md +84 -33
- package/agent-assets/docs/features/integrations/mail.md +59 -16
- package/agent-assets/docs/features/integrations/notion.md +18 -6
- package/agent-assets/docs/features/integrations/obsidian.md +28 -5
- package/agent-assets/docs/features/lifestyle/git.md +42 -38
- package/agent-assets/docs/features/lifestyle/reading.md +50 -22
- package/agent-assets/docs/features/lifestyle/receipts.md +51 -21
- package/agent-assets/docs/features/lifestyle/travel-bookings.md +76 -14
- package/agent-assets/docs/features/memory-files/agent-journal.md +111 -50
- package/agent-assets/docs/features/memory-files/projects.md +71 -17
- package/agent-assets/docs/features/memory-files/roadmap.md +50 -10
- package/agent-assets/docs/features/memory-files/schedule.md +113 -70
- package/agent-assets/docs/features/memory-files/today.md +46 -21
- package/agent-assets/docs/features/memory-files/user-profile.md +63 -33
- package/agent-assets/docs/features/messaging/bang-commands.md +113 -36
- package/agent-assets/docs/features/messaging/dashboard-chat.md +43 -21
- package/agent-assets/docs/features/messaging/discord.md +35 -4
- package/agent-assets/docs/features/messaging/overview.md +37 -19
- package/agent-assets/docs/features/messaging/pairing-and-magic-phrase.md +94 -27
- package/agent-assets/docs/features/messaging/slack.md +67 -14
- package/agent-assets/docs/features/messaging/telegram.md +18 -5
- package/agent-assets/docs/features/messaging/whatsapp.md +71 -17
- package/agent-assets/docs/features/operations/activity-and-conversations.md +44 -15
- package/agent-assets/docs/features/operations/approvals.md +48 -16
- package/agent-assets/docs/features/operations/backend-routing.md +68 -16
- package/agent-assets/docs/features/operations/cost-tracking.md +84 -17
- package/agent-assets/docs/features/operations/managed-chromium.md +221 -0
- package/agent-assets/docs/features/operations/notifications.md +52 -11
- package/agent-assets/docs/features/operations/quiet-hours.md +63 -40
- package/agent-assets/docs/features/operations/schedule-approaching.md +54 -24
- package/agent-assets/docs/features/routines/custom-routines.md +88 -20
- package/agent-assets/docs/features/routines/evening-review.md +74 -21
- package/agent-assets/docs/features/routines/hourly-check.md +149 -29
- package/agent-assets/docs/features/routines/morning-routine.md +53 -35
- package/agent-assets/docs/features/routines/weekly-review.md +40 -21
- package/agent-assets/docs/features/wiki/commands.md +26 -16
- package/agent-assets/docs/features/wiki/cost-and-approval.md +240 -0
- package/agent-assets/docs/features/wiki/dashboard.md +255 -0
- package/agent-assets/docs/features/wiki/overview.md +68 -10
- package/agent-assets/docs/features/wiki/search.md +248 -0
- package/agent-assets/docs/features/wiki/workspaces.md +254 -0
- package/agent-assets/docs/getting-started/01-what-is-this.md +34 -23
- package/agent-assets/docs/getting-started/02-first-steps.md +13 -8
- package/agent-assets/docs/getting-started/03-what-can-this-do.md +25 -14
- package/agent-assets/docs/getting-started/04-first-day.md +38 -20
- package/agent-assets/docs/glossary.md +235 -24
- package/agent-assets/docs/guides/add-a-custom-routine.md +63 -23
- package/agent-assets/docs/guides/backup-and-restore.md +80 -16
- package/agent-assets/docs/guides/budget-and-cost-for-wiki.md +56 -25
- package/agent-assets/docs/guides/build-your-wiki.md +22 -9
- package/agent-assets/docs/guides/change-which-model-handles-x.md +64 -10
- package/agent-assets/docs/guides/connect-a-new-mail-account.md +64 -15
- package/agent-assets/docs/guides/explore-with-trace-and-connect.md +28 -11
- package/agent-assets/docs/guides/import-knowledge-file.md +50 -40
- package/agent-assets/docs/guides/install-and-run.md +48 -19
- package/agent-assets/docs/guides/maintain-wiki-health.md +35 -10
- package/agent-assets/docs/guides/migrate-machines.md +74 -18
- package/agent-assets/docs/guides/multiple-wikis-for-multiple-domains.md +111 -60
- package/agent-assets/docs/guides/pause-the-agent.md +65 -24
- package/agent-assets/docs/guides/reinstall-cleanly.md +88 -18
- package/agent-assets/docs/guides/setup-wizard.md +113 -54
- package/agent-assets/docs/guides/switch-default-backend.md +62 -16
- package/agent-assets/docs/guides/use-an-existing-obsidian-vault.md +26 -10
- package/agent-assets/docs/reference/api.md +143 -32
- package/agent-assets/docs/reference/cli-commands.md +38 -17
- package/agent-assets/docs/reference/config.md +224 -49
- package/agent-assets/docs/reference/disallowed-tools.md +29 -10
- package/agent-assets/docs/reference/keyboard-shortcuts.md +34 -10
- package/agent-assets/docs/reference/knowledge-layout.md +620 -0
- package/agent-assets/docs/reference/process-keys.md +61 -5
- package/agent-assets/docs/reference/skills.md +38 -12
- package/agent-assets/docs/troubleshooting/auth-failed.md +48 -19
- package/agent-assets/docs/troubleshooting/dashboard-shows-degraded.md +90 -28
- package/agent-assets/docs/troubleshooting/fallback-keeps-firing.md +86 -22
- package/agent-assets/docs/troubleshooting/messaging-not-pairing.md +68 -24
- package/agent-assets/docs/troubleshooting/morning-routine-didnt-run.md +80 -20
- package/agent-assets/docs/troubleshooting/observation-not-detected.md +73 -21
- package/agent-assets/docs/troubleshooting/quota-exhausted.md +29 -5
- package/agent-assets/docs/troubleshooting/wiki-ingest-full-blocked.md +126 -54
- package/agent-assets/docs/troubleshooting/wiki-write-failed.md +29 -12
- package/agent-assets/optimizer-skills/drift-analysis/SKILL.md +1 -1
- package/agent-assets/optimizer-skills/knowledge-map/SKILL.md +1 -1
- package/agent-assets/optimizer-skills/skill-curation/SKILL.md +1 -1
- package/agent-assets/sandbox/linux/aitne-chromium.apparmor +91 -0
- package/agent-assets/sandbox/macos/aitne-chromium.sb +156 -0
- package/agent-assets/skills/agent-actions/SKILL.md +2 -2
- package/agent-assets/skills/agent-create/SKILL.md +149 -0
- package/agent-assets/skills/attach/SKILL.md +2 -2
- package/agent-assets/skills/browser-history/SKILL.md +198 -0
- package/agent-assets/skills/browser-history-respond/SKILL.md +106 -0
- package/agent-assets/skills/browser-task/SKILL.md +169 -0
- package/agent-assets/skills/context/SKILL.md +12 -12
- package/agent-assets/skills/context/curation.json +2 -2
- package/agent-assets/skills/context/references/api.md +43 -31
- package/agent-assets/skills/context/references/required-frontmatter.md +3 -3
- package/agent-assets/skills/context/references/snapshot-files.md +6 -6
- package/agent-assets/skills/context/seeds/file-responsibilities.seed.json +3 -3
- package/agent-assets/skills/docs-search/SKILL.md +4 -3
- package/agent-assets/skills/external-services/SKILL.delegated.claude.md +11 -21
- package/agent-assets/skills/external-services/SKILL.delegated.codex.md +11 -21
- package/agent-assets/skills/external-services/SKILL.delegated.gemini.md +11 -21
- package/agent-assets/skills/external-services/SKILL.md +3 -3
- package/agent-assets/skills/external-services/SKILL.native.claude.md +5 -5
- package/agent-assets/skills/external-services/SKILL.native.codex.md +7 -7
- package/agent-assets/skills/external-services/SKILL.native.gemini.md +4 -4
- package/agent-assets/skills/external-services/references/calendar-apple.md +2 -2
- package/agent-assets/skills/external-services/references/calendar-outlook.md +1 -1
- package/agent-assets/skills/external-services/references/obsidian.md +2 -2
- package/agent-assets/skills/gmail-lifestyle/SKILL.md +9 -82
- package/agent-assets/skills/mail/SKILL.delegated.claude.md +14 -5
- package/agent-assets/skills/mail/SKILL.delegated.codex.md +8 -4
- package/agent-assets/skills/mail/SKILL.delegated.gemini.md +8 -4
- package/agent-assets/skills/mail/references/api.md +4 -2
- package/agent-assets/skills/mail/references/providers.md +1 -1
- package/agent-assets/skills/managed-tasks/SKILL.md +9 -9
- package/agent-assets/skills/managed-tasks/references/errors.md +9 -6
- package/agent-assets/skills/managed-tasks/references/recurrence-rule.md +1 -1
- package/agent-assets/skills/management-policy/SKILL.md +32 -31
- package/agent-assets/skills/management-policy/curation.json +1 -1
- package/agent-assets/skills/management-policy/references/policy-workflow.md +9 -9
- package/agent-assets/skills/management-policy/seeds/policy-file-shape.seed.json +1 -1
- package/agent-assets/skills/notify/SKILL.md +4 -4
- package/agent-assets/skills/notify/references/priority.md +9 -4
- package/agent-assets/skills/notion/SKILL.delegated.claude.md +1 -1
- package/agent-assets/skills/notion/SKILL.delegated.codex.md +1 -1
- package/agent-assets/skills/notion/SKILL.delegated.gemini.md +1 -1
- package/agent-assets/skills/notion/SKILL.native.claude.md +10 -6
- package/agent-assets/skills/notion/SKILL.native.codex.md +9 -4
- package/agent-assets/skills/notion/SKILL.native.gemini.md +9 -4
- package/agent-assets/skills/observations/SKILL.md +24 -8
- package/agent-assets/skills/project-doc/SKILL.md +1 -1
- package/agent-assets/skills/project-doc/curation.json +3 -3
- package/agent-assets/skills/project-doc/seeds/project-shape.seed.json +7 -4
- package/agent-assets/skills/project-doc/seeds/slug-grammar.seed.json +3 -3
- package/agent-assets/skills/reading/SKILL.md +10 -0
- package/agent-assets/skills/reading/references/reading-taste.md +2 -2
- package/agent-assets/skills/roadmap/SKILL.md +5 -5
- package/agent-assets/skills/roadmap/curation.json +1 -1
- package/agent-assets/skills/roadmap/references/api.md +7 -7
- package/agent-assets/skills/roadmap/references/cross-check.md +15 -8
- package/agent-assets/skills/roadmap/references/migration.md +4 -4
- package/agent-assets/skills/roadmap/seeds/entry-types.seed.json +1 -1
- package/agent-assets/skills/schedule/SKILL.md +42 -34
- package/agent-assets/skills/schedule/references/batch.md +2 -2
- package/agent-assets/skills/schedule/references/errors.md +7 -4
- package/agent-assets/skills/schedule/references/model-selection.md +3 -3
- package/agent-assets/skills/schedule/references/recurrence-rule.md +1 -1
- package/agent-assets/skills/scheduled-managed-task/SKILL.md +46 -36
- package/agent-assets/skills/today/SKILL.md +9 -9
- package/agent-assets/skills/today/curation.json +3 -3
- package/agent-assets/skills/today/references/agent-plan-lifecycle.md +6 -5
- package/agent-assets/skills/today/seeds/section-shape.seed.json +1 -1
- package/agent-assets/skills/user-interview/SKILL.md +12 -9
- package/agent-assets/skills/user-interview/references/op-briefing.md +2 -2
- package/agent-assets/skills/user-interview/references/sweep-and-fallback.md +8 -0
- package/agent-assets/skills/user-profile/SKILL.md +17 -17
- package/agent-assets/skills/user-profile/curation.json +2 -2
- package/agent-assets/skills/user-profile/references/character-preferences.md +2 -2
- package/agent-assets/skills/user-profile/seeds/routing-table.seed.json +8 -8
- package/agent-assets/skills/user-profile/seeds/topic-files.seed.json +6 -6
- package/agent-assets/skills/wiki/wiki-compile/SKILL.md +4 -4
- package/agent-assets/system-prompts/routine-fetch-window.md +22 -12
- package/agent-assets/task-flows/_partials/calendar-acquire.google_calendar.md +4 -2
- package/agent-assets/task-flows/_partials/calendar-acquire.outlook_calendar.md +4 -2
- package/agent-assets/task-flows/_partials/capture-user-info.md +2 -2
- package/agent-assets/task-flows/_partials/dm-intent.long-horizon.md +1 -1
- package/agent-assets/task-flows/_partials/dm-intent.project.md +9 -9
- package/agent-assets/task-flows/_partials/mail-acquire.outlook_mail.md +3 -2
- package/agent-assets/task-flows/_partials/notion-acquire.notion.md +10 -5
- package/agent-assets/task-flows/browser_task.md +84 -0
- package/agent-assets/task-flows/github.assigned.md +1 -1
- package/agent-assets/task-flows/github.pull_request.review_requested.md +2 -2
- package/agent-assets/task-flows/github.workflow_run.failed.md +2 -2
- package/agent-assets/task-flows/knowledge.import.md +14 -14
- package/agent-assets/task-flows/message.received.dm.md +9 -4
- package/agent-assets/task-flows/message.received.dm_first.md +3 -3
- package/agent-assets/task-flows/routine.custom.md +3 -3
- package/agent-assets/task-flows/routine.evening_review.md +8 -8
- package/agent-assets/task-flows/routine.fetch_window.md +2 -2
- package/agent-assets/task-flows/routine.hourly_check.md +16 -12
- package/agent-assets/task-flows/routine.monthly_review.md +21 -21
- package/agent-assets/task-flows/routine.morning_routine_journal.md +119 -97
- package/agent-assets/task-flows/routine.morning_routine_today.md +43 -43
- package/agent-assets/task-flows/routine.research_cluster_update.md +35 -0
- package/agent-assets/task-flows/routine.research_dispatch.md +38 -0
- package/agent-assets/task-flows/routine.research_offer_dm.md +125 -0
- package/agent-assets/task-flows/routine.research_wiki_summary.md +53 -0
- package/agent-assets/task-flows/routine.roadmap_refresh.md +10 -10
- package/agent-assets/task-flows/routine.today_refresh.md +4 -4
- package/agent-assets/task-flows/routine.user_profile_sweep.md +10 -10
- package/agent-assets/task-flows/routine.weekly_review.md +93 -24
- package/agent-assets/task-flows/schedule.approaching.md +0 -1
- package/agent-assets/task-flows/scheduled.dm.md +5 -5
- package/agent-assets/task-flows/scheduled.task.md +4 -4
- package/agent-assets/task-flows/setup.initial.md +21 -21
- package/agent-assets/task-flows/setup.update.md +2 -2
- package/agent-assets/templates/README.md +27 -20
- package/agent-assets/templates/_index.md +42 -26
- package/agent-assets/templates/_manifest.json +34 -99
- package/agent-assets/templates/{user → identity}/_index.md +1 -1
- package/agent-assets/templates/{user → identity}/profile.md +2 -2
- package/agent-assets/templates/{dossiers → knowledge/dossiers}/_index.md +1 -1
- package/agent-assets/templates/{projects → plans/projects}/_active.base +1 -1
- package/agent-assets/templates/policies/_index.md +21 -0
- package/agent-assets/templates/{rules → policies}/journal-export.md +1 -1
- package/agent-assets/templates/{rules → policies}/journal-format.md +5 -5
- package/agent-assets/templates/{rules/policies → policies/management-captures}/_index.md +2 -2
- package/agent-assets/templates/{rules → policies}/management.md +3 -3
- package/agent-assets/templates/{rules → policies}/mcp.md +1 -1
- package/agent-assets/templates/{rules → policies}/redaction.md +1 -1
- package/agent-assets/templates/{routines → policies/routines}/_index.md +1 -1
- package/agent-assets/templates/{routines → policies/routines}/evening.md +2 -2
- package/agent-assets/templates/{routines → policies/routines}/hourly.md +1 -1
- package/agent-assets/templates/{routines → policies/routines}/monthly.md +2 -2
- package/bin/aitne.mjs +13 -4
- package/package.json +5 -4
- package/scripts/commands/doctor.mjs +14 -8
- package/scripts/commands/run-now.mjs +6 -21
- package/scripts/lib/ports.d.mts +27 -0
- package/scripts/lib/ports.mjs +36 -0
- package/scripts/lib/read-api-token.mjs +176 -0
- package/scripts/start.mjs +2 -1
- package/agent-assets/docs/features/lifestyle/travel-time.md +0 -58
- package/agent-assets/skills/gmail-lifestyle/references/travel-time-api.md +0 -59
- package/agent-assets/skills/schedule/references/recurring.md +0 -185
- package/agent-assets/templates/context-index.md +0 -42
- package/agent-assets/templates/rules/_index.md +0 -19
- /package/agent-assets/templates/{user → identity}/expertise.md +0 -0
- /package/agent-assets/templates/{user → identity}/goals.md +0 -0
- /package/agent-assets/templates/{user → identity}/people.md +0 -0
- /package/agent-assets/templates/{user → identity}/personal.md +0 -0
- /package/agent-assets/templates/{user → identity}/work.md +0 -0
- /package/agent-assets/templates/{agent/journal.md → journal/agent.md} +0 -0
- /package/agent-assets/templates/{dossiers → knowledge/dossiers}/evening.md +0 -0
- /package/agent-assets/templates/{dossiers → knowledge/dossiers}/hourly.md +0 -0
- /package/agent-assets/templates/{dossiers → knowledge/dossiers}/monthly.md +0 -0
- /package/agent-assets/templates/{dossiers → knowledge/dossiers}/morning.md +0 -0
- /package/agent-assets/templates/{dossiers → knowledge/dossiers}/roadmap.md +0 -0
- /package/agent-assets/templates/{dossiers → knowledge/dossiers}/weekly.md +0 -0
- /package/agent-assets/templates/{projects → plans/projects}/_index.md +0 -0
- /package/agent-assets/templates/{roadmap.md → plans/roadmap.md} +0 -0
- /package/agent-assets/templates/{routines → policies/routines}/morning.md +0 -0
- /package/agent-assets/templates/{routines → policies/routines}/weekly.md +0 -0
- /package/agent-assets/templates/{agent → state}/profile-questions.md +0 -0
- /package/agent-assets/templates/{today.md → state/today.md} +0 -0
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
kind: reference
|
|
3
|
-
name: recurring
|
|
4
|
-
description: /api/recurring-schedules — hourly / daily / weekly / monthly cadences auto-regenerating one-shot rows. Includes hourly anchor semantics, monthly missing-day recipes, and the tier ↔ model swap on PATCH.
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Recurring schedules
|
|
8
|
-
|
|
9
|
-
For tasks that repeat on a fixed pattern. The daemon auto-regenerates
|
|
10
|
-
the next one-shot occurrence after each execution; you never have to
|
|
11
|
-
re-POST a daily reminder.
|
|
12
|
-
|
|
13
|
-
Use a recurring schedule when the cadence is all that matters and
|
|
14
|
-
there is no need to record *why* the rule exists. If the user wants
|
|
15
|
-
the WHY captured alongside the cadence (so the rule survives a
|
|
16
|
-
context reset), use the `management-policy` skill — it produces a
|
|
17
|
-
`rules/policies/<slug>.md` linked to a `routines/custom/<slug>.md`
|
|
18
|
-
custom routine.
|
|
19
|
-
|
|
20
|
-
## POST /api/recurring-schedules — Create
|
|
21
|
-
|
|
22
|
-
```bash
|
|
23
|
-
# Hourly at :00 (every hour)
|
|
24
|
-
curl -s -X POST http://localhost:8321/api/recurring-schedules \
|
|
25
|
-
-H 'Content-Type: application/json' \
|
|
26
|
-
-d '{"taskType":"wake","description":"Hourly docker container health check.","recurrenceRule":{"frequency":"hourly"},"tier":"lite"}'
|
|
27
|
-
|
|
28
|
-
# Every 2 hours at :30 (00:30, 02:30, …, 22:30 local)
|
|
29
|
-
curl -s -X POST http://localhost:8321/api/recurring-schedules \
|
|
30
|
-
-H 'Content-Type: application/json' \
|
|
31
|
-
-d '{"taskType":"wake","description":"Sync inbox triage signals.","recurrenceRule":{"frequency":"hourly","intervalHours":2,"minuteOfHour":30},"tier":"lite"}'
|
|
32
|
-
|
|
33
|
-
# Daily at 09:00
|
|
34
|
-
curl -s -X POST http://localhost:8321/api/recurring-schedules \
|
|
35
|
-
-H 'Content-Type: application/json' \
|
|
36
|
-
-d '{"taskType":"wake","description":"Morning inbox triage — check pending observations and update today.md.","recurrenceRule":{"frequency":"daily","time":"09:00"}}'
|
|
37
|
-
|
|
38
|
-
# Weekly Mon/Wed/Fri at 10:00
|
|
39
|
-
curl -s -X POST http://localhost:8321/api/recurring-schedules \
|
|
40
|
-
-H 'Content-Type: application/json' \
|
|
41
|
-
-d '{"taskType":"wake","description":"Standup prep — review PRs, calendar, and blockers.","recurrenceRule":{"frequency":"weekly","time":"10:00","daysOfWeek":[1,3,5]}}'
|
|
42
|
-
|
|
43
|
-
# Monthly on the 25th at 21:00 (billing reconciliation)
|
|
44
|
-
curl -s -X POST http://localhost:8321/api/recurring-schedules \
|
|
45
|
-
-H 'Content-Type: application/json' \
|
|
46
|
-
-d '{"taskType":"wake","description":"Monthly card reconciliation — pull statement, log balance to finance dossier.","recurrenceRule":{"frequency":"monthly","time":"21:00","daysOfMonth":[25]},"tier":"medium"}'
|
|
47
|
-
```
|
|
48
|
-
|
|
49
|
-
| Field | Required | Description |
|
|
50
|
-
|---|---|---|
|
|
51
|
-
| `taskType` | Yes | Task type for dispatch (e.g. `wake`) |
|
|
52
|
-
| `description` | Yes | Self-contained (min 20 chars). Same rules as one-shot. Doubles as the agent body unless `prompt` overrides it. |
|
|
53
|
-
| `prompt` | No | Optional override for the agent body (min 20 chars when set). Each materialized one-shot row inherits this from the recurring parent. |
|
|
54
|
-
| `recurrenceRule` | Yes | `{ frequency, time?, timezone?, intervalHours?, minuteOfHour?, daysOfWeek?, daysOfMonth?, onMissingDay? }` — fields gated by `frequency`; see grammar below. |
|
|
55
|
-
| `tier` | No | `lite` / `medium` / `high`. Mutually exclusive with `model`. |
|
|
56
|
-
| `model` | No | Registered model id (`claude-opus-4-7`, `gpt-5.4`, `gemini-3.1-pro-preview`, …), legacy alias (`sonnet` / `opus` — auto-rewritten to `tier`), or composite `<backendId>/<modelId>` for future disambiguation. Mutually exclusive with `tier`. The row stores `(model, backend_id)` together so the dispatcher honors the pin at fire time. |
|
|
57
|
-
| `taskContext` | No | Structured metadata object |
|
|
58
|
-
|
|
59
|
-
### Recurrence rule grammar (engine)
|
|
60
|
-
|
|
61
|
-
The recurrence engine accepts four frequencies. Each frequency
|
|
62
|
-
requires its own set of fields and rejects fields that don't apply.
|
|
63
|
-
|
|
64
|
-
| `frequency` | Required | Allowed | Forbidden |
|
|
65
|
-
|---|---|---|---|
|
|
66
|
-
| `"hourly"` | — | `intervalHours` (1..23, default 1), `minuteOfHour` (0..59, default 0), `timezone` | `time`, `daysOfWeek`, `daysOfMonth`, `onMissingDay` |
|
|
67
|
-
| `"daily"` | `time` | `timezone` | `intervalHours`, `minuteOfHour`, `daysOfWeek`, `daysOfMonth`, `onMissingDay` |
|
|
68
|
-
| `"weekly"` | `time`, `daysOfWeek` (1..7 distinct entries, 0=Sun..6=Sat) | `timezone` | `intervalHours`, `minuteOfHour`, `daysOfMonth`, `onMissingDay` |
|
|
69
|
-
| `"monthly"` | `time`, `daysOfMonth` (1..31 distinct entries) | `timezone`, `onMissingDay` (default `"lastDayOfMonth"`) | `intervalHours`, `minuteOfHour`, `daysOfWeek` |
|
|
70
|
-
|
|
71
|
-
`time` is `HH:MM` 24-hour local. `timezone` is an IANA zone
|
|
72
|
-
(`Asia/Tokyo`, `America/New_York`, `UTC`); auto-filled from daemon
|
|
73
|
-
config when omitted, but explicit is safer so a roaming laptop does
|
|
74
|
-
not surprise the user. The error envelope cites `validValues` on
|
|
75
|
-
every range / format failure — read it and resubmit instead of
|
|
76
|
-
guessing.
|
|
77
|
-
|
|
78
|
-
### Hourly anchor semantics
|
|
79
|
-
|
|
80
|
-
`intervalHours=N` fires when `(localHour % N) == 0` at
|
|
81
|
-
`minuteOfHour` local. The anchor is **local midnight** in the rule's
|
|
82
|
-
`timezone`, so `intervalHours:2, minuteOfHour:30` fires at 00:30,
|
|
83
|
-
02:30, …, 22:30 local — predictable for the user's mental model.
|
|
84
|
-
|
|
85
|
-
| Intent | `recurrenceRule` |
|
|
86
|
-
|---|---|
|
|
87
|
-
| Every hour at :00 | `{frequency:"hourly"}` |
|
|
88
|
-
| Every hour at :15 | `{frequency:"hourly", minuteOfHour:15}` |
|
|
89
|
-
| Every 2 hours at :30 | `{frequency:"hourly", intervalHours:2, minuteOfHour:30}` |
|
|
90
|
-
| Every 6 hours at :00 (Asia/Tokyo) | `{frequency:"hourly", intervalHours:6, timezone:"Asia/Tokyo"}` |
|
|
91
|
-
|
|
92
|
-
DST: in zones that observe it, a skipped local hour drops one fire;
|
|
93
|
-
a doubled local hour fires once. Accepted edge case — do not try to
|
|
94
|
-
compensate from the caller.
|
|
95
|
-
|
|
96
|
-
Use hourly sparingly. Sub-hour cadences are not representable (the
|
|
97
|
-
minimum is 1 hour); pick a coarser cadence or move the work into a
|
|
98
|
-
daemon-internal poller instead.
|
|
99
|
-
|
|
100
|
-
### Monthly missing-day semantics
|
|
101
|
-
|
|
102
|
-
Some months don't contain the day the user asked for (Feb 30, Apr
|
|
103
|
-
31). `onMissingDay` controls what happens that month:
|
|
104
|
-
|
|
105
|
-
- `"skip"` — don't fire that month for the missing day.
|
|
106
|
-
- `"lastDayOfMonth"` (default) — fire on the actual last day of the
|
|
107
|
-
month. Preserves the pre-redesign clamp behavior, so existing
|
|
108
|
-
recurring rules created before this redesign keep firing
|
|
109
|
-
bit-identically.
|
|
110
|
-
|
|
111
|
-
The engine de-duplicates calendar dates that collapse to the same
|
|
112
|
-
fire (e.g. `daysOfMonth:[28,31]` in non-leap Feb with
|
|
113
|
-
`"lastDayOfMonth"` lands on Feb 28 once, not twice).
|
|
114
|
-
|
|
115
|
-
| Recipe | `recurrenceRule` |
|
|
116
|
-
|---|---|
|
|
117
|
-
| 25th of every month at 21:00 | `{frequency:"monthly", time:"21:00", daysOfMonth:[25]}` |
|
|
118
|
-
| 31st at 21:00, skip Feb/Apr/Jun/Sep/Nov | `{frequency:"monthly", time:"21:00", daysOfMonth:[31], onMissingDay:"skip"}` |
|
|
119
|
-
| 31st at 21:00, fall back to last day | `{frequency:"monthly", time:"21:00", daysOfMonth:[31], onMissingDay:"lastDayOfMonth"}` |
|
|
120
|
-
| **Last day of every month at 21:00** | same as above — `daysOfMonth:[31] + onMissingDay:"lastDayOfMonth"` clamps Feb/Apr/Jun/Sep/Nov to their last day; the 31st of every other month is already that month's last day |
|
|
121
|
-
| 29th at 21:00, skip non-leap Feb | `{frequency:"monthly", time:"21:00", daysOfMonth:[29], onMissingDay:"skip"}` |
|
|
122
|
-
| 1st AND 15th at 10:00 | `{frequency:"monthly", time:"10:00", daysOfMonth:[1,15]}` |
|
|
123
|
-
|
|
124
|
-
When `daysOfMonth` contains 29/30/31 and `onMissingDay` is omitted,
|
|
125
|
-
the daemon returns a `warnings[]` entry nudging you to be explicit.
|
|
126
|
-
Persistence still happens — the warning is advisory.
|
|
127
|
-
|
|
128
|
-
Response: `{ "status":"created", "item":{ "id","recurrenceRule","recurrenceLabel","nextRunAt",...}, "warnings":[] }`. `nextRunAt` is the UTC timestamp the engine has materialized as the first one-shot row's `scheduled_for`. `recurrenceLabel` is the human-readable form rendered into `rules/management.md` §B (e.g. `"Every 2 hours at :30 (UTC)"`, `"Monthly on the 31st at 21:00 (Asia/Tokyo); falls back to last day of month"`).
|
|
129
|
-
|
|
130
|
-
## GET /api/recurring-schedules — List
|
|
131
|
-
|
|
132
|
-
```bash
|
|
133
|
-
curl -s "http://localhost:8321/api/recurring-schedules?enabled=true"
|
|
134
|
-
```
|
|
135
|
-
|
|
136
|
-
Response: `{ "items":[{ "id","taskType","description","recurrenceRule","enabled","nextRunAt","recurrenceLabel","model","backendId","tier","taskContext" }] }`. `model` / `backendId` are populated together when the row pins a registered id; otherwise `model:null, backendId:null` and `tier` carries the pin (or all three are null and the row inherits the dispatcher's process-key default).
|
|
137
|
-
|
|
138
|
-
## PATCH /api/recurring-schedules/:id — Update
|
|
139
|
-
|
|
140
|
-
```bash
|
|
141
|
-
# Swap a daily rule to hourly + change model to Opus in one PATCH
|
|
142
|
-
curl -s -X PATCH http://localhost:8321/api/recurring-schedules/1 \
|
|
143
|
-
-H 'Content-Type: application/json' \
|
|
144
|
-
-d '{"recurrenceRule":{"frequency":"hourly","intervalHours":2,"minuteOfHour":0},"tier":null,"model":"claude-opus-4-7"}'
|
|
145
|
-
```
|
|
146
|
-
|
|
147
|
-
Updatable: `recurrenceRule`, `description`, `prompt` (string sets an
|
|
148
|
-
override, `null` clears), `tier` (set / `null` to clear), `model`
|
|
149
|
-
(set / `null` to clear), `taskContext`, `enabled`. Changing
|
|
150
|
-
`recurrenceRule` / `enabled` auto-reschedules — the pending one-shot
|
|
151
|
-
row tied to the old rule is cancelled and a fresh row is materialized
|
|
152
|
-
from the new `recurrenceRule` value, preserving the parent's
|
|
153
|
-
`(model, backend_id)` or `tier` pin.
|
|
154
|
-
|
|
155
|
-
**Tier ↔ model swap.** Pass `null` to clear one and a concrete value
|
|
156
|
-
to set the other in the same request — the row carries at most one
|
|
157
|
-
pin at rest. Setting a registered `model` token also clears any
|
|
158
|
-
prior `tier_override`. Setting a legacy alias (`sonnet` / `opus`) on
|
|
159
|
-
PATCH is rewritten to `tier:"medium"` / `tier:"high"`; the alias is
|
|
160
|
-
never stored verbatim.
|
|
161
|
-
|
|
162
|
-
**Re-materialization scope.** Changing `model` / `tier` alone does
|
|
163
|
-
**not** re-point the already-materialized pending one-shot row — only
|
|
164
|
-
`recurrenceRule` / `enabled` re-materialize. Delete the pending row
|
|
165
|
-
(`DELETE /api/schedule/:id`) and let the next reconcile pass pick up
|
|
166
|
-
the new pin, or PATCH `/api/schedule/:id` directly if you need the
|
|
167
|
-
pending row repointed now.
|
|
168
|
-
|
|
169
|
-
Set `{"enabled":false}` to pause without deleting. Surface
|
|
170
|
-
`warnings[]` (e.g. `schedule.model_deprecated`,
|
|
171
|
-
`schedule.on_missing_day_unused`) to the next turn — the PATCH still
|
|
172
|
-
succeeds but the warning carries replacement guidance.
|
|
173
|
-
|
|
174
|
-
## DELETE /api/recurring-schedules/:id — Delete
|
|
175
|
-
|
|
176
|
-
```bash
|
|
177
|
-
curl -s -X DELETE http://localhost:8321/api/recurring-schedules/1
|
|
178
|
-
```
|
|
179
|
-
|
|
180
|
-
Deletes the rule and cancels every materialized pending instance.
|
|
181
|
-
Response: `{ "status":"deleted", "id":1 }`.
|
|
182
|
-
|
|
183
|
-
Use pause (`PATCH ... {"enabled":false}`) instead when the user might
|
|
184
|
-
want to resume the same cadence later — DELETE loses the
|
|
185
|
-
`recurrenceRule` shape and the `taskContext` payload.
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
type: index
|
|
3
|
-
owner: agent
|
|
4
|
-
updated: 2026-04-17
|
|
5
|
-
template_version: 1
|
|
6
|
-
---
|
|
7
|
-
# Context Index
|
|
8
|
-
|
|
9
|
-
Prompt-injection hub for dossier-backed flows (B-004). This file stays in
|
|
10
|
-
English so review / routine prompts read a stable, backend-neutral summary.
|
|
11
|
-
|
|
12
|
-
## Files
|
|
13
|
-
|
|
14
|
-
| Path | Purpose | Review flows | Last touched |
|
|
15
|
-
|---|---|---|---|
|
|
16
|
-
| `_index.md` | Human-readable vault navigation | - | 2026-04-17 |
|
|
17
|
-
| `user/profile.md` | User identity, preferences, communication style | all | 2026-04-17 |
|
|
18
|
-
| `today.md` | Current-day schedule, tasks, agent plan, handoff | hourly, morning, evening | 2026-04-17 |
|
|
19
|
-
| `roadmap.md` | Long-horizon commitments and recurring plans | evening, weekly, monthly, roadmap | 2026-04-17 |
|
|
20
|
-
| `projects/_index.md` | Project area index | weekly, monthly, roadmap | 2026-04-17 |
|
|
21
|
-
| `agent/journal.md` | Agent-internal reflection log | weekly, monthly | 2026-04-17 |
|
|
22
|
-
| `rules/management.md` | Source-of-truth bindings and behavioral policy | all | 2026-04-17 |
|
|
23
|
-
| `rules/redaction.md` | Secret and private-data handling rules | all | 2026-04-17 |
|
|
24
|
-
| `routines/hourly.md` | Hourly check rulebook | hourly | 2026-04-17 |
|
|
25
|
-
| `routines/morning.md` | Morning routine extension rulebook | morning | 2026-04-17 |
|
|
26
|
-
| `routines/evening.md` | Evening review extension rulebook | evening | 2026-04-17 |
|
|
27
|
-
| `routines/weekly.md` | Weekly review extension rulebook | weekly | 2026-04-17 |
|
|
28
|
-
| `routines/monthly.md` | Monthly review and roadmap planning rulebook | monthly, roadmap | 2026-04-17 |
|
|
29
|
-
| `dossiers/hourly.md` | Hourly carry-forward state | hourly | 2026-04-17 |
|
|
30
|
-
| `dossiers/morning.md` | Morning carry-forward state | morning | 2026-04-17 |
|
|
31
|
-
| `dossiers/evening.md` | Evening carry-forward state | evening | 2026-04-17 |
|
|
32
|
-
| `dossiers/weekly.md` | Weekly carry-forward state | weekly | 2026-04-17 |
|
|
33
|
-
| `dossiers/monthly.md` | Monthly carry-forward state | monthly | 2026-04-17 |
|
|
34
|
-
| `dossiers/roadmap.md` | Roadmap refresh carry-forward state | roadmap | 2026-04-17 |
|
|
35
|
-
|
|
36
|
-
## Notes
|
|
37
|
-
|
|
38
|
-
- Keep `Review flows` short: `all`, `hourly`, `morning`, `evening`,
|
|
39
|
-
`weekly`, `monthly`, and `roadmap` are the flow tags the prompt loader
|
|
40
|
-
understands.
|
|
41
|
-
- When a new context file should be reviewed routinely, add one row here
|
|
42
|
-
with the narrowest matching flow tag.
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
type: index
|
|
3
|
-
owner: shared
|
|
4
|
-
updated: 2026-04-24
|
|
5
|
-
template_version: 2
|
|
6
|
-
---
|
|
7
|
-
# Rules
|
|
8
|
-
|
|
9
|
-
Natural-language policy files the agent reads to decide HOW to act. Each
|
|
10
|
-
is user-editable; changes take effect at the next task-flow assembly.
|
|
11
|
-
|
|
12
|
-
| File | Purpose |
|
|
13
|
-
|---|---|
|
|
14
|
-
| `management.md` | Source-of-truth bindings (where each category lives) |
|
|
15
|
-
| `policies/_index.md` | Active management policies captured from conversation |
|
|
16
|
-
| `mcp.md` | MCP usage rules (B-003) |
|
|
17
|
-
| `journal-format.md` | Format spec for the daily synthesized journal |
|
|
18
|
-
| `journal-export.md` | User-defined redaction / inclusion rules for B-005 |
|
|
19
|
-
| `redaction.md` | Built-in secret patterns (English, informational) |
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|