kynetic-agents 0.2.0__py3-none-any.whl
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.
- kynetic_agents/__init__.py +3 -0
- kynetic_agents/api.py +55 -0
- kynetic_agents/app.py +1103 -0
- kynetic_agents/builtin_skills/__init__.py +105 -0
- kynetic_agents/builtin_skills/five-whys/CHAINLINK_SETUP.md +117 -0
- kynetic_agents/builtin_skills/five-whys/CHAINLINK_USAGE.md +167 -0
- kynetic_agents/builtin_skills/five-whys/SKILL.md +247 -0
- kynetic_agents/builtin_skills/introspection/SKILL.md +175 -0
- kynetic_agents/builtin_skills/introspection/debugging-communication.md +222 -0
- kynetic_agents/builtin_skills/introspection/debugging-drift.md +164 -0
- kynetic_agents/builtin_skills/introspection/debugging-jobs.md +144 -0
- kynetic_agents/builtin_skills/long-running-jobs/SKILL.md +281 -0
- kynetic_agents/builtin_skills/memory/SKILL.md +58 -0
- kynetic_agents/builtin_skills/memory/maintenance.md +25 -0
- kynetic_agents/builtin_skills/mountaineering/SKILL.md +101 -0
- kynetic_agents/builtin_skills/mountaineering/climb-design.md +152 -0
- kynetic_agents/builtin_skills/mountaineering/climber.py +500 -0
- kynetic_agents/builtin_skills/mountaineering/harness.md +209 -0
- kynetic_agents/builtin_skills/mountaineering/laws.md +132 -0
- kynetic_agents/builtin_skills/mountaineering/philosophy.md +122 -0
- kynetic_agents/builtin_skills/mountaineering/preflight.md +115 -0
- kynetic_agents/builtin_skills/onboarding/SKILL.md +150 -0
- kynetic_agents/builtin_skills/onboarding/establishing-goals.md +109 -0
- kynetic_agents/builtin_skills/onboarding/establishing-identity.md +106 -0
- kynetic_agents/builtin_skills/onboarding/establishing-schedules.md +262 -0
- kynetic_agents/builtin_skills/onboarding/establishing-skills.md +76 -0
- kynetic_agents/builtin_skills/pollers/SKILL.md +163 -0
- kynetic_agents/builtin_skills/pollers/design-patterns.md +333 -0
- kynetic_agents/builtin_skills/pollers/security.md +111 -0
- kynetic_agents/builtin_skills/prediction-review/SKILL.md +186 -0
- kynetic_agents/builtin_skills/scripts/file_frequency_report.py +424 -0
- kynetic_agents/builtin_skills/scripts/memory_dashboard.py +266 -0
- kynetic_agents/builtin_skills/scripts/prediction_review_log.py +102 -0
- kynetic_agents/builtin_skills/skill-acquisition/SKILL.md +198 -0
- kynetic_agents/builtin_skills/skill-acquisition/clawhub-reference.md +198 -0
- kynetic_agents/builtin_skills/skill-acquisition/skillflag-reference.md +217 -0
- kynetic_agents/builtin_skills/skill-creator/SKILL.md +45 -0
- kynetic_agents/builtin_skills/view-attachment/SKILL.md +90 -0
- kynetic_agents/cli.py +854 -0
- kynetic_agents/config.py +490 -0
- kynetic_agents/discord.py +684 -0
- kynetic_agents/mcp_client.py +211 -0
- kynetic_agents/models.py +20 -0
- kynetic_agents/phone_book.py +427 -0
- kynetic_agents/prompts.py +337 -0
- kynetic_agents/readonly_backend.py +307 -0
- kynetic_agents/release.py +102 -0
- kynetic_agents/scheduler.py +362 -0
- kynetic_agents/supervisor.py +466 -0
- kynetic_agents/tools.py +1463 -0
- kynetic_agents-0.2.0.dist-info/METADATA +211 -0
- kynetic_agents-0.2.0.dist-info/RECORD +55 -0
- kynetic_agents-0.2.0.dist-info/WHEEL +4 -0
- kynetic_agents-0.2.0.dist-info/entry_points.txt +2 -0
- kynetic_agents-0.2.0.dist-info/licenses/LICENSE +22 -0
kynetic_agents/api.py
ADDED
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"""Loopback REST API for injecting events into the agent."""
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
|
|
5
|
+
from typing import TYPE_CHECKING
|
|
6
|
+
|
|
7
|
+
from aiohttp import web
|
|
8
|
+
|
|
9
|
+
from .models import AgentEvent
|
|
10
|
+
|
|
11
|
+
if TYPE_CHECKING:
|
|
12
|
+
from .app import OpenStrixApp
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
def _build_app(strix: OpenStrixApp) -> web.Application:
|
|
16
|
+
app = web.Application()
|
|
17
|
+
|
|
18
|
+
async def post_event(request: web.Request) -> web.Response:
|
|
19
|
+
try:
|
|
20
|
+
body = await request.json()
|
|
21
|
+
except Exception:
|
|
22
|
+
return web.json_response({"error": "invalid JSON"}, status=400)
|
|
23
|
+
|
|
24
|
+
source = body.get("source", "")
|
|
25
|
+
prompt = body.get("prompt", "")
|
|
26
|
+
if not prompt:
|
|
27
|
+
return web.json_response({"error": "prompt is required"}, status=400)
|
|
28
|
+
|
|
29
|
+
source_label = source or "api"
|
|
30
|
+
event = AgentEvent(
|
|
31
|
+
event_type="api_event",
|
|
32
|
+
prompt=prompt,
|
|
33
|
+
channel_id=body.get("channel_id"),
|
|
34
|
+
source_id=f"api:{source_label}",
|
|
35
|
+
)
|
|
36
|
+
await strix.enqueue_event(event)
|
|
37
|
+
return web.json_response({"status": "queued", "source": source_label})
|
|
38
|
+
|
|
39
|
+
async def health(request: web.Request) -> web.Response:
|
|
40
|
+
return web.json_response({"status": "ok"})
|
|
41
|
+
|
|
42
|
+
app.router.add_post("/api/event", post_event)
|
|
43
|
+
app.router.add_get("/api/health", health)
|
|
44
|
+
return app
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
async def start_api(strix: OpenStrixApp, port: int) -> web.AppRunner:
|
|
48
|
+
"""Start the loopback API server. Returns the runner for cleanup."""
|
|
49
|
+
app = _build_app(strix)
|
|
50
|
+
runner = web.AppRunner(app)
|
|
51
|
+
await runner.setup()
|
|
52
|
+
site = web.TCPSite(runner, "127.0.0.1", port)
|
|
53
|
+
await site.start()
|
|
54
|
+
strix.log_event("api_started", port=port)
|
|
55
|
+
return runner
|