connectonion 0.6.3__tar.gz → 0.6.5__tar.gz
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.
- {connectonion-0.6.3 → connectonion-0.6.5}/PKG-INFO +1 -1
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/__init__.py +1 -1
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/agent.py +3 -3
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/main.py +2 -2
- connectonion-0.6.5/connectonion/cli/co_ai/plugins/__init__.py +5 -0
- connectonion-0.6.5/connectonion/cli/co_ai/plugins/system_reminder.py +154 -0
- connectonion-0.6.5/connectonion/cli/co_ai/prompts/connectonion/concepts/trust.md +249 -0
- connectonion-0.6.5/connectonion/cli/co_ai/prompts/system-reminders/agent.md +23 -0
- connectonion-0.6.5/connectonion/cli/co_ai/prompts/system-reminders/plan_mode.md +13 -0
- connectonion-0.6.5/connectonion/cli/co_ai/prompts/system-reminders/security.md +14 -0
- connectonion-0.6.5/connectonion/cli/co_ai/prompts/system-reminders/simplicity.md +14 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/plan_mode.py +1 -4
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/read.py +0 -6
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/copy_commands.py +21 -0
- connectonion-0.6.5/connectonion/cli/commands/trust_commands.py +152 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/main.py +82 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/llm.py +2 -2
- connectonion-0.6.5/connectonion/docs/concepts/fast_rules.md +237 -0
- connectonion-0.6.5/connectonion/docs/concepts/onboarding.md +465 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/plugins.md +2 -1
- connectonion-0.6.5/connectonion/docs/concepts/trust.md +1032 -0
- connectonion-0.6.5/connectonion/docs/design-decisions/023-trust-policy-system-design.md +323 -0
- connectonion-0.6.5/connectonion/docs/network/README.md +36 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/network/connect.md +135 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/network/host.md +73 -4
- connectonion-0.6.5/connectonion/docs/useful_plugins/tool_approval.md +139 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/__init__.py +7 -6
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/asgi/__init__.py +3 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/asgi/http.py +125 -19
- connectonion-0.6.5/connectonion/network/asgi/websocket.py +478 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/connect.py +145 -29
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/host/auth.py +70 -67
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/host/routes.py +88 -3
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/host/server.py +100 -17
- connectonion-0.6.5/connectonion/network/trust/__init__.py +38 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/trust/factory.py +51 -24
- connectonion-0.6.5/connectonion/network/trust/fast_rules.py +100 -0
- connectonion-0.6.5/connectonion/network/trust/tools.py +372 -0
- connectonion-0.6.5/connectonion/network/trust/trust_agent.py +403 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/transcribe.py +1 -1
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/__init__.py +2 -1
- connectonion-0.6.5/connectonion/useful_plugins/tool_approval.py +233 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/pyproject.toml +1 -1
- connectonion-0.6.3/connectonion/cli/co_ai/plugins/__init__.py +0 -6
- connectonion-0.6.3/connectonion/cli/co_ai/plugins/reminder.py +0 -76
- connectonion-0.6.3/connectonion/cli/co_ai/plugins/shell_approval.py +0 -105
- connectonion-0.6.3/connectonion/cli/co_ai/prompts/connectonion/concepts/trust.md +0 -291
- connectonion-0.6.3/connectonion/cli/co_ai/prompts/reminders/plan_mode.md +0 -34
- connectonion-0.6.3/connectonion/cli/co_ai/reminders.py +0 -159
- connectonion-0.6.3/connectonion/docs/concepts/trust.md +0 -291
- connectonion-0.6.3/connectonion/docs/network/README.md +0 -14
- connectonion-0.6.3/connectonion/network/asgi/websocket.py +0 -217
- connectonion-0.6.3/connectonion/network/trust/__init__.py +0 -30
- connectonion-0.6.3/connectonion/network/trust/prompts.py +0 -71
- connectonion-0.6.3/connectonion/network/trust/tools.py +0 -88
- {connectonion-0.6.3 → connectonion-0.6.5}/.gitignore +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/address.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/browser.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/element_finder.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/highlight_screenshot.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/prompts/element_matcher.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/prompts/form_filler.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/prompts/scroll_strategy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/scripts/extract_elements.js +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/browser_agent/scroll.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/agents/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/agents/registry.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/compact.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/cost.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/export.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/help.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/init.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/sessions.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/tasks.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/commands/undo.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/context.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/agents/explore.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/agents/plan.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/assembler.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/api.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/cli/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/cli/auth.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/cli/browser.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/cli/copy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/cli/create.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/cli/init.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/co-directory-structure.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/agent.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/events.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/llm_do.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/max_iterations.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/models.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/plugins.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/prompts.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/tools.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/concepts/transcribe.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/connectonion.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/auto_debug.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/console.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/eval-format.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/eval.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/exceptions.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/log.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/debug/xray.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/001-choosing-input-method.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/002-choosing-llm-function-name.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/003-choosing-trust-keyword.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/004-cli-create-flow.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/005-designing-agent-network-protocol.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/006-agent-address-format.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/007-authentication-backend-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/008-naming-is-hard.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/009-why-connect-function.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/010-cli-ux-progressive-disclosure.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/011-global-config-identity-management.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/012-tool-execution-separation.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/013-debug-and-logging-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/014-hook-system-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/015-interactive-auto-debug-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/016-why-no-zero-knowledge-proofs.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/017-session-logging-and-eval-format.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/018-event-api-naming.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/019-agent-lifecycle-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/020-trust-system-and-network-architecture.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/021-task-storage-jsonl-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/design-decisions/022-raw-asgi-implementation.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/examples/agent_reasoning.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/examples/atomic_tools.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/examples/load_guide.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/examples.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/hook-system-options.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/index.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/integrations/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/integrations/auth.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/integrations/google.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/integrations/microsoft.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/network/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/network/connect.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/network/connection.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/network/deploy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/network/host.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/network/protocol/agent-relay-protocol.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/network/protocol/announce-message.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/principles.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/quickstart.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/roadmap.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/templates/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/templates/meta-agent.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/templates/minimal.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/templates/playwright.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/templates/web-research.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/chat.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/divider.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/dropdown.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/footer.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/fuzzy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/input.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/keys.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/pick.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/providers.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/tui/status_bar.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_plugins/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_plugins/calendar_plugin.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_plugins/eval.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_plugins/gmail_plugin.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_plugins/image_result_formatter.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_plugins/re_act.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_plugins/shell_approval.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/diff_writer.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/get_emails.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/gmail.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/google_calendar.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/memory.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/microsoft_calendar.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/outlook.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/send_email.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/shell.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/slash_command.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/terminal.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/todo_list.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/useful_tools/web_fetch.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/vibe-coding-guide.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/connectonion/windows-support.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/main.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/summarization.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/ask_user.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/background.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/edit.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/glob.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/grep.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/plan_mode.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/read.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/shell.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/task.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/todo.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/tools/write.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/prompts/workflow.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/sessions.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/skills/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/skills/builtin/commit/SKILL.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/skills/builtin/review-pr/SKILL.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/skills/loader.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/skills/tool.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/ask_user.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/background.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/diff_writer.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/edit.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/glob.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/grep.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/load_guide.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/multi_edit.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/task.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/todo_list.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/co_ai/tools/write.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/ai_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/auth_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/browser_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/create.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/deploy_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/doctor_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/eval_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/init.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/project_cmd_lib.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/reset_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/commands/status_commands.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/docs.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/meta-agent/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/meta-agent/agent.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/meta-agent/prompts/answer_prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/meta-agent/prompts/docs_retrieve_prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/meta-agent/prompts/metagent.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/meta-agent/prompts/think_prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/minimal/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/minimal/agent.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/playwright/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/playwright/agent.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/playwright/prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/playwright/requirements.txt +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/cli/templates/web-research/agent.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/console.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/agent.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/events.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/exceptions.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/tool_executor.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/tool_factory.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/tool_registry.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/core/usage.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/auto_debug.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/auto_debug_exception.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/auto_debug_ui.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/debug_explainer/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/debug_explainer/explain_agent.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/debug_explainer/explain_context.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/debug_explainer/explainer_prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/debug_explainer/root_cause_analysis_prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/decorators.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/execution_analyzer/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/execution_analyzer/execution_analysis.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/execution_analyzer/execution_analysis_prompt.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/runtime_inspector/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/runtime_inspector/agent.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/runtime_inspector/prompts/debug_assistant.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/runtime_inspector/runtime_inspector.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/debug/xray.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/.package-ignore +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/api.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/001-ai-agent-is-just-prompt-plus-function.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/archive/consolidation-plan.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/archive/core-principles-extracted.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/archive/master-principles.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/archive/principles.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/archive/simplicity-principles.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/attack-defense-insights.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/business-model.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/core-principles-unified.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/discussion-journey.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/economic-analysis.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/features/01-share-and-find.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/features/02-agent-authentication.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/features/03-test-before-trust.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/features/06-reliability-and-offline.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/features/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/features-roadmap.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/mcp-comparison-insights.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/migration-strategy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/mini-whitepaper.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/network-protocol.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/semantic-revolution.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/technical-architecture.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/the-semantic-insight.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/archive/threat-model.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/cli/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/cli/auth.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/cli/browser.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/cli/copy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/cli/create.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/cli/init.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/co-directory-structure.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/agent.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/events.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/llm_do.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/max_iterations.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/models.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/prompts.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/session.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/tools.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/concepts/transcribe.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/connectonion.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/auto_debug.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/console.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/eval-format.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/eval.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/exceptions.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/log.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/debug/xray.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/001-choosing-input-method.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/002-choosing-llm-function-name.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/003-choosing-trust-keyword.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/004-cli-create-flow.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/005-designing-agent-network-protocol.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/006-agent-address-format.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/007-authentication-backend-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/008-naming-is-hard.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/009-why-connect-function.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/010-cli-ux-progressive-disclosure.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/011-global-config-identity-management.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/012-tool-execution-separation.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/013-debug-and-logging-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/014-hook-system-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/015-interactive-auto-debug-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/016-why-no-zero-knowledge-proofs.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/017-session-logging-and-eval-format.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/018-event-api-naming.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/019-agent-lifecycle-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/020-trust-system-and-network-architecture.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/021-task-storage-jsonl-design.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/design-decisions/022-raw-asgi-implementation.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/examples.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/hook-system-options.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/integrations/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/integrations/auth.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/integrations/google.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/integrations/microsoft.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/network/deploy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/network/io.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/network/protocol/agent-relay-protocol.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/network/protocol/announce-message.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/principles.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/quickstart.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/roadmap.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/templates/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/templates/meta-agent.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/templates/minimal.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/templates/playwright.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/templates/web-research.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/chat.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/divider.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/dropdown.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/footer.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/fuzzy.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/input.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/keys.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/pick.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/providers.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/tui/status_bar.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/calendar_plugin.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/eval.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/gmail_plugin.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/image_result_formatter.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/re_act.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/shell_approval.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_plugins/system_reminder.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_prompts/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_prompts/coding_agent.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/ask_user.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/diff_writer.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/get_emails.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/gmail.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/google_calendar.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/memory.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/microsoft_calendar.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/outlook.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/send_email.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/shell.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/slash_command.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/terminal.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/todo_list.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/useful_tools/web_fetch.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/vibe-coding-guide.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/docs/windows-support.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/llm_do.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/logger.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/announce.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/host/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/host/session.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/io/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/io/base.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/io/websocket.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/relay.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/network/static/docs.html +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompt_files/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompt_files/analyze_contact.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompt_files/eval_expected.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompt_files/react_acknowledge.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompt_files/react_evaluate.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompt_files/react_plan.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompt_files/reflect.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/prompts.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/chat.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/divider.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/dropdown.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/footer.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/fuzzy.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/input.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/keys.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/pick.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/providers.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/tui/status_bar.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_events_handlers/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_events_handlers/reflect.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/calendar_plugin.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/eval.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/gmail_plugin.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/image_result_formatter.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/re_act.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/shell_approval.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/system_reminder.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_plugins/ui_stream.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/assembler.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/main.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/ask_user.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/background.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/edit.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/glob.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/grep.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/plan_mode.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/read.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/shell.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/task.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/todo.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/coding_agent/prompts/tools/write.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/system-reminders/security-warning.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_prompts/system-reminders/test-reminder.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/__init__.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/ask_user.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/bash.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/diff_writer.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/edit.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/get_emails.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/glob_files.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/gmail.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/google_calendar.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/grep_files.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/memory.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/microsoft_calendar.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/multi_edit.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/outlook.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/read_file.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/send_email.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/shell.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/slash_command.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/terminal.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/todo_list.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/web_fetch.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/connectonion/useful_tools/write_file.py +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/examples/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/examples/email-agent/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/examples/simple-agent/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/prompts/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/prompts/formats/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/tests/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/tests/cli/README.md +0 -0
- {connectonion-0.6.3 → connectonion-0.6.5}/tests/cli/aws/README.md +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: connectonion
|
|
3
|
-
Version: 0.6.
|
|
3
|
+
Version: 0.6.5
|
|
4
4
|
Summary: A simple Python framework for creating AI agents with behavior tracking
|
|
5
5
|
Project-URL: Homepage, https://github.com/openonion/connectonion
|
|
6
6
|
Project-URL: Documentation, https://docs.connectonion.com
|
|
@@ -12,9 +12,9 @@ from .tools import (
|
|
|
12
12
|
load_guide,
|
|
13
13
|
)
|
|
14
14
|
from .skills import skill
|
|
15
|
-
from .plugins import
|
|
15
|
+
from .plugins import system_reminder
|
|
16
16
|
from connectonion import Agent, bash, after_user_input, FileWriter, MODE_AUTO, MODE_NORMAL, TodoList
|
|
17
|
-
from connectonion.useful_plugins import
|
|
17
|
+
from connectonion.useful_plugins import eval, tool_approval
|
|
18
18
|
|
|
19
19
|
|
|
20
20
|
PROMPTS_DIR = Path(__file__).parent / "prompts"
|
|
@@ -71,7 +71,7 @@ def create_coding_agent(
|
|
|
71
71
|
if project_context:
|
|
72
72
|
system_prompt += f"\n\n---\n\n{project_context}"
|
|
73
73
|
|
|
74
|
-
plugins = [
|
|
74
|
+
plugins = [eval, system_reminder, tool_approval]
|
|
75
75
|
|
|
76
76
|
agent = Agent(
|
|
77
77
|
name="oo",
|
|
@@ -47,6 +47,6 @@ def start_server(
|
|
|
47
47
|
web_mode=True,
|
|
48
48
|
)
|
|
49
49
|
|
|
50
|
-
# Start server with
|
|
50
|
+
# Start server with careful trust (requires invite code or payment for strangers)
|
|
51
51
|
# relay_url=None disables P2P discovery
|
|
52
|
-
host(agent_factory, port=port, trust="
|
|
52
|
+
host(agent_factory, port=port, trust="careful", relay_url=None)
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"""
|
|
2
|
+
System Reminder Plugin - Injects contextual guidance based on intent and tool usage.
|
|
3
|
+
|
|
4
|
+
Two triggers:
|
|
5
|
+
1. after_user_input: Detect intent (coding, agent creation) and inject relevant reminder
|
|
6
|
+
2. after_each_tool: Inject reminder based on tool usage
|
|
7
|
+
|
|
8
|
+
Usage:
|
|
9
|
+
from connectonion.cli.co_ai.plugins.system_reminder import system_reminder
|
|
10
|
+
|
|
11
|
+
agent = Agent("coder", plugins=[system_reminder])
|
|
12
|
+
"""
|
|
13
|
+
|
|
14
|
+
from pathlib import Path
|
|
15
|
+
import fnmatch
|
|
16
|
+
from typing import TYPE_CHECKING
|
|
17
|
+
|
|
18
|
+
from connectonion.core.events import after_each_tool, after_user_input
|
|
19
|
+
from connectonion.llm_do import llm_do
|
|
20
|
+
|
|
21
|
+
if TYPE_CHECKING:
|
|
22
|
+
from connectonion.core.agent import Agent
|
|
23
|
+
|
|
24
|
+
# Default reminders directory
|
|
25
|
+
REMINDERS_DIR = Path(__file__).parent.parent / "prompts" / "system-reminders"
|
|
26
|
+
|
|
27
|
+
# Intent detection prompt
|
|
28
|
+
INTENT_PROMPT = """Analyze the user's request.
|
|
29
|
+
|
|
30
|
+
User request: {user_prompt}
|
|
31
|
+
|
|
32
|
+
Is this about building software, creating agents, writing code, or automation?
|
|
33
|
+
Respond with ONE word only: "build" or "other"
|
|
34
|
+
|
|
35
|
+
One word only:"""
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
def _parse_frontmatter(text):
|
|
39
|
+
"""Parse YAML frontmatter from markdown."""
|
|
40
|
+
if not text.startswith('---'):
|
|
41
|
+
return {}, text
|
|
42
|
+
parts = text.split('---', 2)
|
|
43
|
+
if len(parts) < 3:
|
|
44
|
+
return {}, text
|
|
45
|
+
import yaml
|
|
46
|
+
return yaml.safe_load(parts[1]) or {}, parts[2].strip()
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
def _load_reminders(reminders_dir):
|
|
50
|
+
"""Load all .md reminder files from directory."""
|
|
51
|
+
reminders_dir = Path(reminders_dir)
|
|
52
|
+
if not reminders_dir.exists():
|
|
53
|
+
return {}
|
|
54
|
+
reminders = {}
|
|
55
|
+
for f in reminders_dir.glob("*.md"):
|
|
56
|
+
meta, body = _parse_frontmatter(f.read_text())
|
|
57
|
+
if meta.get('name'):
|
|
58
|
+
reminders[meta['name']] = {
|
|
59
|
+
'content': body,
|
|
60
|
+
'triggers': meta.get('triggers', []),
|
|
61
|
+
'intent': meta.get('intent'), # New: intent-based trigger
|
|
62
|
+
}
|
|
63
|
+
return reminders
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
def _matches_pattern(pattern, value):
|
|
67
|
+
"""Check if value matches glob pattern(s)."""
|
|
68
|
+
if not pattern or not value:
|
|
69
|
+
return False
|
|
70
|
+
patterns = [pattern] if isinstance(pattern, str) else pattern
|
|
71
|
+
return any(fnmatch.fnmatch(value, p) for p in patterns)
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
def _find_tool_reminder(reminders, tool_name, args):
|
|
75
|
+
"""Find matching reminder for tool usage."""
|
|
76
|
+
for reminder in reminders.values():
|
|
77
|
+
for trigger in reminder['triggers']:
|
|
78
|
+
if trigger.get('tool') and trigger['tool'] != tool_name:
|
|
79
|
+
continue
|
|
80
|
+
if trigger.get('path_pattern'):
|
|
81
|
+
path = args.get('path') or args.get('file_path', '')
|
|
82
|
+
if not _matches_pattern(trigger['path_pattern'], path):
|
|
83
|
+
continue
|
|
84
|
+
if trigger.get('command_pattern'):
|
|
85
|
+
cmd = args.get('command') or args.get('cmd', '')
|
|
86
|
+
if not _matches_pattern(trigger['command_pattern'], cmd):
|
|
87
|
+
continue
|
|
88
|
+
# All conditions matched
|
|
89
|
+
content = reminder['content']
|
|
90
|
+
path = args.get('path') or args.get('file_path', '')
|
|
91
|
+
return content.replace('${file_path}', path).replace('${tool_name}', tool_name)
|
|
92
|
+
return None
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
def _find_intent_reminder(reminders, intent):
|
|
96
|
+
"""Find matching reminder for detected intent."""
|
|
97
|
+
for reminder in reminders.values():
|
|
98
|
+
if reminder.get('intent') == intent:
|
|
99
|
+
return reminder['content']
|
|
100
|
+
return None
|
|
101
|
+
|
|
102
|
+
|
|
103
|
+
# Load reminders once at import
|
|
104
|
+
_REMINDERS = _load_reminders(REMINDERS_DIR)
|
|
105
|
+
|
|
106
|
+
|
|
107
|
+
@after_user_input
|
|
108
|
+
def detect_intent(agent: 'Agent') -> None:
|
|
109
|
+
"""Detect user intent and inject relevant system reminder."""
|
|
110
|
+
user_prompt = agent.current_session.get('user_prompt', '')
|
|
111
|
+
if not user_prompt:
|
|
112
|
+
return
|
|
113
|
+
|
|
114
|
+
# Use llm_do to detect intent
|
|
115
|
+
intent = llm_do(
|
|
116
|
+
INTENT_PROMPT.format(user_prompt=user_prompt),
|
|
117
|
+
model="co/gemini-2.5-flash",
|
|
118
|
+
temperature=0,
|
|
119
|
+
).strip().lower()
|
|
120
|
+
|
|
121
|
+
# Store intent in session
|
|
122
|
+
agent.current_session['intent'] = intent
|
|
123
|
+
|
|
124
|
+
# Find and inject intent-based reminder
|
|
125
|
+
content = _find_intent_reminder(_REMINDERS, intent)
|
|
126
|
+
if content:
|
|
127
|
+
agent.current_session['messages'].append({
|
|
128
|
+
'role': 'user',
|
|
129
|
+
'content': f"\n\n{content}"
|
|
130
|
+
})
|
|
131
|
+
|
|
132
|
+
|
|
133
|
+
@after_each_tool
|
|
134
|
+
def inject_tool_reminder(agent: 'Agent') -> None:
|
|
135
|
+
"""Inject matching system reminder into tool result."""
|
|
136
|
+
trace = agent.current_session.get('trace', [])
|
|
137
|
+
messages = agent.current_session.get('messages', [])
|
|
138
|
+
if not trace or not messages:
|
|
139
|
+
return
|
|
140
|
+
|
|
141
|
+
last = trace[-1]
|
|
142
|
+
if last.get('type') != 'tool_result':
|
|
143
|
+
return
|
|
144
|
+
|
|
145
|
+
content = _find_tool_reminder(_REMINDERS, last.get('name', ''), last.get('args', {}))
|
|
146
|
+
if content:
|
|
147
|
+
for msg in reversed(messages):
|
|
148
|
+
if msg.get('role') == 'tool':
|
|
149
|
+
msg['content'] = msg.get('content', '') + '\n\n' + content
|
|
150
|
+
break
|
|
151
|
+
|
|
152
|
+
|
|
153
|
+
# Export plugin
|
|
154
|
+
system_reminder = [detect_intent, inject_tool_reminder]
|
|
@@ -0,0 +1,249 @@
|
|
|
1
|
+
# Trust in ConnectOnion
|
|
2
|
+
|
|
3
|
+
Trust is a **host layer** concern that controls who can access your agent. It manages onboarding, access control, and client state transitions.
|
|
4
|
+
|
|
5
|
+
## Quick Start
|
|
6
|
+
|
|
7
|
+
```python
|
|
8
|
+
from connectonion import Agent
|
|
9
|
+
from connectonion.network import host
|
|
10
|
+
|
|
11
|
+
# Create your agent (no trust here - agent only cares about its job)
|
|
12
|
+
agent = Agent("my_service", tools=[process_data])
|
|
13
|
+
|
|
14
|
+
# Host it with trust (trust is a host concern)
|
|
15
|
+
host(agent, trust="careful") # Default: verify before allowing access
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## Core Concepts
|
|
19
|
+
|
|
20
|
+
### Separation of Concerns
|
|
21
|
+
|
|
22
|
+
| Layer | Responsibility |
|
|
23
|
+
|-------|----------------|
|
|
24
|
+
| **Agent** | What it does (skills, tools, reasoning) |
|
|
25
|
+
| **Host** | How it's accessed (network, trust, security) |
|
|
26
|
+
|
|
27
|
+
```python
|
|
28
|
+
# Agent is pure - only cares about its job
|
|
29
|
+
agent = Agent("translator", tools=[translate])
|
|
30
|
+
|
|
31
|
+
# Trust is configured at host level
|
|
32
|
+
host(agent, trust="open") # Dev: trust everyone
|
|
33
|
+
host(agent, trust="careful") # Staging: verify first
|
|
34
|
+
host(agent, trust="strict") # Prod: whitelist only
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
### Two-Tier Verification
|
|
38
|
+
|
|
39
|
+
| Type | Tokens | When to Use |
|
|
40
|
+
|------|--------|-------------|
|
|
41
|
+
| **Fast Rules** | Zero | Simple checks (invite code, payment, whitelist) |
|
|
42
|
+
| **Trust Agent** | Burns tokens | Complex decisions (behavior analysis, edge cases) |
|
|
43
|
+
|
|
44
|
+
90% of requests use fast rules (instant, free). 10% use trust agent (LLM reasoning, rare).
|
|
45
|
+
|
|
46
|
+
## Trust Levels
|
|
47
|
+
|
|
48
|
+
### Open (Development)
|
|
49
|
+
|
|
50
|
+
Trust everyone. No verification.
|
|
51
|
+
|
|
52
|
+
```python
|
|
53
|
+
host(agent, trust="open")
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
Use for: Local development, Jupyter notebooks, testing.
|
|
57
|
+
|
|
58
|
+
### Careful (Default)
|
|
59
|
+
|
|
60
|
+
Verify strangers before granting access. Fast rules first, then trust agent for complex cases.
|
|
61
|
+
|
|
62
|
+
```python
|
|
63
|
+
host(agent, trust="careful")
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
Use for: Staging, testing, pre-production.
|
|
67
|
+
|
|
68
|
+
### Strict (Production)
|
|
69
|
+
|
|
70
|
+
Whitelist only. No exceptions.
|
|
71
|
+
|
|
72
|
+
```python
|
|
73
|
+
host(agent, trust="strict")
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
Use for: Production, sensitive data, payments.
|
|
77
|
+
|
|
78
|
+
## Client States
|
|
79
|
+
|
|
80
|
+
```
|
|
81
|
+
Promotion Chain (earned trust):
|
|
82
|
+
|
|
83
|
+
┌─────────────┐ verify ┌─────────────┐ earn trust ┌─────────────┐
|
|
84
|
+
│ Stranger │ ──────────► │ Contact │ ───────────► │ Whitelist │
|
|
85
|
+
└─────────────┘ └─────────────┘ └─────────────┘
|
|
86
|
+
│ │ │
|
|
87
|
+
│ block │ demote │ demote
|
|
88
|
+
▼ ▼ ▼
|
|
89
|
+
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
|
|
90
|
+
│ Blocklist │ │ Stranger │ │ Contact │
|
|
91
|
+
└─────────────┘ └─────────────┘ └─────────────┘
|
|
92
|
+
|
|
93
|
+
|
|
94
|
+
Admin (separate, manual only):
|
|
95
|
+
|
|
96
|
+
┌─────────────┐ set_admin() ┌─────────────┐
|
|
97
|
+
│ Any Level │ ─────────────► │ Admin │
|
|
98
|
+
└─────────────┘ └─────────────┘
|
|
99
|
+
│
|
|
100
|
+
remove_admin()
|
|
101
|
+
│
|
|
102
|
+
▼
|
|
103
|
+
┌─────────────┐
|
|
104
|
+
│ Previous │
|
|
105
|
+
└─────────────┘
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
### Client Levels
|
|
109
|
+
|
|
110
|
+
| Level | Description | Access |
|
|
111
|
+
|-------|-------------|--------|
|
|
112
|
+
| **Stranger** | Unknown client, not verified | Limited or none |
|
|
113
|
+
| **Contact** | Verified via invite/payment | Standard access |
|
|
114
|
+
| **Whitelist** | Trusted, pre-approved | Full access |
|
|
115
|
+
| **Admin** | Can manage other clients | Full access + management |
|
|
116
|
+
| **Blocklist** | Blocked, denied access | No access |
|
|
117
|
+
|
|
118
|
+
## Trust Policy Files
|
|
119
|
+
|
|
120
|
+
Trust policies are markdown files with YAML frontmatter. YAML defines fast rules (no tokens), markdown body defines trust agent behavior (for complex decisions).
|
|
121
|
+
|
|
122
|
+
```yaml
|
|
123
|
+
# prompts/trust/careful.md
|
|
124
|
+
---
|
|
125
|
+
fast_rules:
|
|
126
|
+
- if: has_invite_code
|
|
127
|
+
action: verify_invite
|
|
128
|
+
on_success: promote_to_contact
|
|
129
|
+
|
|
130
|
+
- if: is_blocked
|
|
131
|
+
action: deny
|
|
132
|
+
|
|
133
|
+
- if: is_whitelist
|
|
134
|
+
action: allow
|
|
135
|
+
|
|
136
|
+
- if: is_stranger
|
|
137
|
+
action: deny
|
|
138
|
+
|
|
139
|
+
use_agent:
|
|
140
|
+
- when: requests > 10
|
|
141
|
+
reason: "Evaluate for promotion"
|
|
142
|
+
|
|
143
|
+
cache: 24h
|
|
144
|
+
---
|
|
145
|
+
|
|
146
|
+
# Trust Agent Policy
|
|
147
|
+
|
|
148
|
+
You handle complex trust decisions.
|
|
149
|
+
|
|
150
|
+
## Available Tools
|
|
151
|
+
- promote_to_contact(client_id)
|
|
152
|
+
- block(client_id, reason)
|
|
153
|
+
|
|
154
|
+
## When to Promote
|
|
155
|
+
Promote stranger to contact when:
|
|
156
|
+
- 10+ requests with good behavior
|
|
157
|
+
- No suspicious patterns
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
## Atomic Functions
|
|
161
|
+
|
|
162
|
+
Trust manager provides simple atomic functions as tools:
|
|
163
|
+
|
|
164
|
+
```python
|
|
165
|
+
# Promotion (earned)
|
|
166
|
+
promote_to_contact(client_id) # Stranger → Contact
|
|
167
|
+
promote_to_whitelist(client_id) # Contact → Whitelist
|
|
168
|
+
|
|
169
|
+
# Demotion
|
|
170
|
+
demote_to_contact(client_id) # Whitelist → Contact
|
|
171
|
+
demote_to_stranger(client_id) # Contact → Stranger
|
|
172
|
+
|
|
173
|
+
# Blocking
|
|
174
|
+
block(client_id, reason)
|
|
175
|
+
unblock(client_id)
|
|
176
|
+
|
|
177
|
+
# Admin (manual only)
|
|
178
|
+
set_admin(client_id, by_admin)
|
|
179
|
+
remove_admin(client_id, by_admin)
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
## Custom Trust Policies
|
|
183
|
+
|
|
184
|
+
### Option 1: Use Preset
|
|
185
|
+
|
|
186
|
+
```python
|
|
187
|
+
host(agent, trust="careful") # Uses prompts/trust/careful.md
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
### Option 2: Custom Markdown File
|
|
191
|
+
|
|
192
|
+
```python
|
|
193
|
+
host(agent, trust="./my_policy.md")
|
|
194
|
+
```
|
|
195
|
+
|
|
196
|
+
### Option 3: Custom TrustAgent
|
|
197
|
+
|
|
198
|
+
```python
|
|
199
|
+
from connectonion.network.trust import TrustAgent
|
|
200
|
+
|
|
201
|
+
trust = TrustAgent(
|
|
202
|
+
system_prompt="./my_policy.md",
|
|
203
|
+
tools=[my_custom_verifier]
|
|
204
|
+
)
|
|
205
|
+
host(agent, trust=trust)
|
|
206
|
+
```
|
|
207
|
+
|
|
208
|
+
## Environment-Based Defaults
|
|
209
|
+
|
|
210
|
+
```python
|
|
211
|
+
# No trust specified - auto-detected from environment
|
|
212
|
+
host(agent)
|
|
213
|
+
|
|
214
|
+
# CONNECTONION_ENV=development → trust="open"
|
|
215
|
+
# CONNECTONION_ENV=staging → trust="careful"
|
|
216
|
+
# CONNECTONION_ENV=production → trust="strict"
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
## List Management
|
|
220
|
+
|
|
221
|
+
Trust manager maintains lists at `~/.co/`:
|
|
222
|
+
|
|
223
|
+
```
|
|
224
|
+
~/.co/
|
|
225
|
+
├── contacts.txt # Verified contacts
|
|
226
|
+
├── whitelist.txt # Trusted, pre-approved
|
|
227
|
+
├── admins.txt # Can manage other clients
|
|
228
|
+
└── blocklist.txt # Blocked clients
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
## FAQ
|
|
232
|
+
|
|
233
|
+
**Q: What's the default trust level?**
|
|
234
|
+
A: `"careful"` - verify strangers, allow contacts.
|
|
235
|
+
|
|
236
|
+
**Q: Do fast rules burn tokens?**
|
|
237
|
+
A: No. Fast rules are simple if/then executed by host. Zero tokens.
|
|
238
|
+
|
|
239
|
+
**Q: When does trust agent run?**
|
|
240
|
+
A: Only when `use_agent` triggers fire (e.g., after 10 requests). Rare.
|
|
241
|
+
|
|
242
|
+
**Q: Can I use the same agent with different trust levels?**
|
|
243
|
+
A: Yes. Trust is host config, not agent config.
|
|
244
|
+
|
|
245
|
+
```python
|
|
246
|
+
# Same agent, different trust
|
|
247
|
+
host(agent, trust="open") # Dev
|
|
248
|
+
host(agent, trust="strict") # Prod
|
|
249
|
+
```
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: build
|
|
3
|
+
intent: build
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
<system-reminder>
|
|
7
|
+
Agent creation detected. Use ConnectOnion framework:
|
|
8
|
+
|
|
9
|
+
**ConnectOnion agents are Python files (.py), NOT markdown files.**
|
|
10
|
+
|
|
11
|
+
```python
|
|
12
|
+
from connectonion import Agent
|
|
13
|
+
|
|
14
|
+
def list_files(dir: str) -> list[str]: ...
|
|
15
|
+
def get_hash(path: str) -> str: ...
|
|
16
|
+
def delete(path: str) -> str: ...
|
|
17
|
+
|
|
18
|
+
agent = Agent("cleaner", tools=[list_files, get_hash, delete])
|
|
19
|
+
agent.input("Remove duplicate files")
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
**Give tools, not logic. Let the agent decide strategy. NEVER create standalone scripts with hardcoded logic.**
|
|
23
|
+
</system-reminder>
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: plan-mode
|
|
3
|
+
triggers:
|
|
4
|
+
- tool: enter_plan_mode
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
<system-reminder>
|
|
8
|
+
Plan mode is active. You MUST NOT make any edits or run non-readonly tools.
|
|
9
|
+
|
|
10
|
+
Only allowed: glob, grep, read_file, write_plan, exit_plan_mode
|
|
11
|
+
|
|
12
|
+
Write your plan to the plan file, then call exit_plan_mode when done.
|
|
13
|
+
</system-reminder>
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: security
|
|
3
|
+
triggers:
|
|
4
|
+
- tool: read_file
|
|
5
|
+
path_pattern: ["*.env*", "*credentials*", "*secrets*", "*password*", "*token*", "*.pem", "*.key"]
|
|
6
|
+
- tool: read
|
|
7
|
+
path_pattern: ["*.env*", "*credentials*", "*secrets*", "*password*", "*token*", "*.pem", "*.key"]
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
<system-reminder>
|
|
11
|
+
This file may contain sensitive information.
|
|
12
|
+
- Never expose secrets in output
|
|
13
|
+
- Never commit real credentials
|
|
14
|
+
</system-reminder>
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: simplicity
|
|
3
|
+
triggers:
|
|
4
|
+
- tool: edit
|
|
5
|
+
- tool: multi_edit
|
|
6
|
+
- tool: write
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
<system-reminder>
|
|
10
|
+
Keep it simple:
|
|
11
|
+
- Only change what's directly needed
|
|
12
|
+
- Don't add error handling for scenarios that can't happen
|
|
13
|
+
- Three similar lines > premature abstraction
|
|
14
|
+
</system-reminder>
|
|
@@ -6,8 +6,6 @@ from rich.console import Console
|
|
|
6
6
|
from rich.panel import Panel
|
|
7
7
|
from rich.markdown import Markdown
|
|
8
8
|
|
|
9
|
-
from connectonion.cli.co_ai.reminders import REMINDERS
|
|
10
|
-
|
|
11
9
|
console = Console()
|
|
12
10
|
|
|
13
11
|
# Plan mode state (module-level for simplicity)
|
|
@@ -101,8 +99,7 @@ def enter_plan_mode() -> str:
|
|
|
101
99
|
border_style="green"
|
|
102
100
|
))
|
|
103
101
|
|
|
104
|
-
|
|
105
|
-
return f"Entered plan mode. Write your plan to {_plan_file_path}, then call exit_plan_mode() when ready for user approval.\n\n{plan_mode_reminder}"
|
|
102
|
+
return f"Entered plan mode. Write your plan to {_plan_file_path}, then call exit_plan_mode() when ready for user approval."
|
|
106
103
|
|
|
107
104
|
|
|
108
105
|
def exit_plan_mode() -> str:
|
|
@@ -3,8 +3,6 @@
|
|
|
3
3
|
from pathlib import Path
|
|
4
4
|
from typing import Optional
|
|
5
5
|
|
|
6
|
-
from connectonion.cli.co_ai.reminders import inject_reminder, should_show_security_reminder
|
|
7
|
-
|
|
8
6
|
|
|
9
7
|
def read_file(
|
|
10
8
|
path: str,
|
|
@@ -60,8 +58,4 @@ def read_file(
|
|
|
60
58
|
if end < total_lines:
|
|
61
59
|
result += f"\n\n... ({total_lines - end} more lines)"
|
|
62
60
|
|
|
63
|
-
# Inject security reminder for sensitive files
|
|
64
|
-
if should_show_security_reminder(path):
|
|
65
|
-
result = inject_reminder(result, "security")
|
|
66
|
-
|
|
67
61
|
return result
|
|
@@ -63,6 +63,13 @@ PROMPTS = {
|
|
|
63
63
|
"coding_agent": "coding_agent",
|
|
64
64
|
}
|
|
65
65
|
|
|
66
|
+
# Registry of copyable trust policies
|
|
67
|
+
TRUST = {
|
|
68
|
+
"open": "open.md",
|
|
69
|
+
"careful": "careful.md",
|
|
70
|
+
"strict": "strict.md",
|
|
71
|
+
}
|
|
72
|
+
|
|
66
73
|
|
|
67
74
|
def handle_copy(
|
|
68
75
|
names: List[str],
|
|
@@ -82,11 +89,14 @@ def handle_copy(
|
|
|
82
89
|
import connectonion.useful_plugins as plugins_module
|
|
83
90
|
import connectonion.tui as tui_module
|
|
84
91
|
import connectonion.useful_prompts as prompts_module
|
|
92
|
+
import connectonion
|
|
85
93
|
|
|
86
94
|
useful_tools_dir = Path(tools_module.__file__).parent
|
|
87
95
|
useful_plugins_dir = Path(plugins_module.__file__).parent
|
|
88
96
|
tui_dir = Path(tui_module.__file__).parent
|
|
89
97
|
useful_prompts_dir = Path(prompts_module.__file__).parent
|
|
98
|
+
# Trust policies are in the main package's prompts/trust/ directory
|
|
99
|
+
trust_dir = Path(connectonion.__file__).parent.parent / "prompts" / "trust"
|
|
90
100
|
|
|
91
101
|
current_dir = Path.cwd()
|
|
92
102
|
|
|
@@ -123,6 +133,13 @@ def handle_copy(
|
|
|
123
133
|
dest_dir = Path(path) if path else current_dir / "prompts"
|
|
124
134
|
copy_directory(source, dest_dir, force)
|
|
125
135
|
|
|
136
|
+
# Check if it's a trust policy (support both "careful" and "trust/careful")
|
|
137
|
+
elif name_lower in TRUST or (name_lower.startswith("trust/") and name_lower[6:] in TRUST):
|
|
138
|
+
policy_name = name_lower[6:] if name_lower.startswith("trust/") else name_lower
|
|
139
|
+
source = trust_dir / TRUST[policy_name]
|
|
140
|
+
dest_dir = Path(path) if path else current_dir / "prompts" / "trust"
|
|
141
|
+
copy_file(source, dest_dir, force)
|
|
142
|
+
|
|
126
143
|
else:
|
|
127
144
|
console.print(f"[red]Unknown: {name}[/red]")
|
|
128
145
|
console.print("Use [cyan]co copy --list[/cyan] to see available items")
|
|
@@ -180,9 +197,13 @@ def show_available_items():
|
|
|
180
197
|
for name, dir_name in sorted(PROMPTS.items()):
|
|
181
198
|
table.add_row(name, "prompt", f"{dir_name}/")
|
|
182
199
|
|
|
200
|
+
for name, file in sorted(TRUST.items()):
|
|
201
|
+
table.add_row(f"trust/{name}", "trust", file)
|
|
202
|
+
|
|
183
203
|
for name, file in sorted(TUI.items()):
|
|
184
204
|
table.add_row(name, "tui", file)
|
|
185
205
|
|
|
186
206
|
console.print(table)
|
|
187
207
|
console.print("\n[dim]Usage: co copy <name> [--path ./custom/][/dim]")
|
|
188
208
|
console.print("[dim]Prompts are copied as directories to ./prompts/<name>/[/dim]")
|
|
209
|
+
console.print("[dim]Trust policies are copied to ./prompts/trust/<name>.md[/dim]")
|