Commit graph

798 commits

Author SHA1 Message Date
Virgil
71cde24842 Merge pull request 'fix(tray): replace placeholder icons with actual bug and diamond icons' (#40) from fix/tray-icons into new 2026-02-09 10:40:09 +00:00
Snider
3b155ae7bf fix(tray): replace placeholder icons with actual bug and diamond icons
BugSETI: bug with antennae and legs (black template, white dark, green app)
Core IDE: diamond shape (black template, white dark, blue app)

Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-09 10:39:50 +00:00
Claude
6ae525d54f
feat(agentci): package dispatch system for multi-agent deployment
Config-driven agent targets replace hardcoded map so new agents
can be added via CLI instead of recompiling. Includes setup script
for bootstrapping agent machines and CLI commands for management.

- Add pkg/agentci with config types and CRUD (LoadAgents, SaveAgent, etc.)
- Add CLI: core ai agent {add,list,status,logs,setup,remove}
- Add scripts/agent-setup.sh (SSH bootstrap: dirs, cron, prereq check)
- Headless loads agents from ~/.core/config.yaml
- Dispatch ticket includes forgejo_user for dynamic clone URLs
- agent-runner.sh reads username from ticket JSON, not hardcoded

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 10:36:23 +00:00
Virgil
ab7e7d7b3c Merge pull request 'feat(bugseti): wire BugSETI into root build system and ship v0.1.0' (#38) from feat/bugseti-launch into new 2026-02-09 10:28:37 +00:00
Snider
ff934fa0d3 Merge branch 'new' of https://forge.lthn.ai/host-uk/core into new 2026-02-09 10:24:27 +00:00
Snider
367bd35778 chore(bugseti): disable Angular CLI analytics
Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-09 10:24:22 +00:00
Claude
b8b0a2e5b8
feat(jobrunner): add agent dispatch handler and queue runner
Dispatch handler matches child issues that need coding (no PR yet,
assigned to a known agent) and SCPs ticket JSON to the agent's
queue directory via SSH. Includes dedup across queue/active/done
and posts dispatch comments on issues.

- Extend PipelineSignal with NeedsCoding, Assignee, IssueTitle, IssueBody
- Extend ForgejoSource to emit signals for unstarted children
- Add DispatchHandler with Match/Execute (SCP ticket delivery)
- Add agent-runner.sh cron-based queue runner for agent machines
- Wire dispatch handler into headless mode

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 10:10:08 +00:00
Snider
d1b1341407 feat(bugseti): wire BugSETI into root build system and make functional
- Add bugseti:dev, bugseti:build, bugseti:frontend tasks to root Taskfile
- Update Wails v3 config to current dev_mode format (root_path, executes)
- Raise Angular component CSS budget to 6KB (inline styles by design)
- Fix vanity-import Dockerfile typo (---FROM → FROM)
- Verify: Go compiles, tests pass, frontend builds clean, binary runs

Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-09 02:49:01 +00:00
Snider
e8119a49eb fix(core-ide): use path-based routing for multi-window SPA, clean up formatting
Switch Angular from hash-based to path-based routing so each Wails window
(/tray, /main, /settings) loads its correct route. Archive GitHub Actions
workflows to .gh-actions/, update Forgejo deploy registry to dappco.re/osi,
and apply gofmt/alignment fixes across packages.

Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-09 01:50:57 +00:00
Snider
b32858d135 updates 2026-02-09 01:27:40 +00:00
Claude
ccead55c0e
feat(jobrunner): port from GitHub to Forgejo using pkg/forge
Replace all GitHub API and gh CLI dependencies with Forgejo SDK via
pkg/forge. The bash dispatcher burned a week of credit in a day due to
bugs — the jobrunner now talks directly to Forgejo.

- Add forge client methods: CreateIssueComment, CloseIssue, MergePullRequest,
  SetPRDraft, ListPRReviews, GetCombinedStatus, DismissReview
- Create ForgejoSource implementing JobSource (epic polling, checklist
  parsing, commit status via combined status API)
- Rewrite all 5 handlers to accept *forge.Client instead of shelling out
- Replace ResolveThreadsHandler with DismissReviewsHandler (Forgejo has
  no thread resolution API — dismiss stale REQUEST_CHANGES reviews instead)
- Delete pkg/jobrunner/github/ and handlers/exec.go entirely
- Update internal/core-ide/headless.go to wire Forgejo source and handlers
- All 33 tests pass with mock Forgejo HTTP servers

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 00:40:49 +00:00
12974f472a Merge pull request 'codex/bugseti-mcp' (#36) from codex/bugseti-mcp into new
Reviewed-on: host-uk/core#36
2026-02-08 23:16:41 +00:00
58a052bd17 Merge branch 'new' into codex/bugseti-mcp 2026-02-08 23:15:35 +00:00
Snider
6ded35887b feat(core-ide): add MCP bridge (SERVER) and Claude bridge (CLIENT)
SERVER bridge (mcp_bridge.go):
- HTTP server on :9877 exposing 24 MCP tools
- Window management: list, get, position, size, bounds, maximize,
  minimize, restore, focus, visibility, title, fullscreen, create, close
- Webview: eval JS, navigate, list
- System: clipboard read/write, tray control
- Endpoints: /mcp, /mcp/tools, /mcp/call, /health, /ws, /claude

CLIENT bridge (claude_bridge.go):
- WebSocket relay between GUI clients and MCP core on :9876
- Auto-reconnect with backoff
- Bidirectional message forwarding (claude_message type)

Moved HTTP server from IDEService to MCPBridge for unified endpoint.

Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-08 23:12:51 +00:00
Snider
f85aecb073 fix(tray-apps): SPA routing, TypeScript fixes, and deferred onboarding
- Add spaHandler() to both BugSETI and Core IDE for Angular client-side
  routing (AssetFileServerFS doesn't fallback to index.html)
- Fix jellyfin.component.ts sanitizer initialization order (both apps)
- Fix chat.component.ts Event/KeyboardEvent type mismatch
- Defer onboarding window to ApplicationStarted event hook

Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-08 23:03:49 +00:00
Snider
4127509ccd fix: resolve conflict markers and remove legacy code after branch consolidation
- Remove conflict markers from 19 files that were accidentally committed
  during merge resolutions (keeping HEAD versions)
- Remove legacy root-level code (core.go, main.go, config/, crypt/,
  display/, filesystem/, workspace/, docs/*.go, cmd/app/) from old
  architecture predating pkg/ restructure
- Remove duplicate pkg/config/loader.go (Load/Save already in config.go)
- Fix import alias in cmd_apply.go (errors -> core)

Co-Authored-By: Virgil <virgil@lethean.io>
2026-02-08 22:08:35 +00:00
Snider
3b1eb2fbfc Merge branch 'refactor/core-decomposition' into new 2026-02-08 22:00:38 +00:00
Snider
8d937b09eb Merge branch 'audit/dependencies-185' into new 2026-02-08 22:00:38 +00:00
Snider
ec83baee46 Merge branch 'ci/use-build-action' into new 2026-02-08 22:00:38 +00:00
Snider
0d764297e2 Merge branch 'ci/org-wide-workflows' into new 2026-02-08 22:00:38 +00:00
Snider
b2c1950bc2 Merge branch 'fix/windows-zip' into new 2026-02-08 22:00:30 +00:00
Snider
2e4656c5b3 Merge branch 'fix/ssh-security-13442055821003769195' into new 2026-02-08 22:00:30 +00:00
Snider
e09574e9cc Merge branch 'fix/release-windows-shell' into new 2026-02-08 22:00:30 +00:00
Snider
3ff2dbe129 Merge branch 'fix/release-go-build' into new 2026-02-08 22:00:30 +00:00
Snider
82229c2ac2 Merge branch 'fix/release-build-path' into new 2026-02-08 22:00:30 +00:00
Snider
f21ab1aaaa Merge branch 'fix/rag-formatting' into new 2026-02-08 22:00:29 +00:00
Snider
052040046b Merge branch 'fix/pr-263-reviews' into new 2026-02-08 22:00:29 +00:00
Snider
179b2bb0e6 Merge branch 'fix/linker-flags-226' into new 2026-02-08 22:00:29 +00:00
Snider
965498a9f4 Merge branch 'fix/homebrew-tap-auth' into new 2026-02-08 22:00:29 +00:00
Snider
1ee32dbec9 Merge branch 'fix/gofmt-client' into new 2026-02-08 22:00:29 +00:00
Snider
0bf47aa155 Merge branch 'fix/gemini-batch' into new 2026-02-08 22:00:29 +00:00
Snider
b8aa8dd8fd Merge branch 'fix/docstrings-exec-logger' into new 2026-02-08 22:00:29 +00:00
Snider
1c61d35a26 Merge branch 'fix/disable-dev-release' into new 2026-02-08 22:00:29 +00:00
Snider
b84a1ec29e Merge branch 'fix/consolidate-workflows' into new 2026-02-08 22:00:21 +00:00
Snider
b1e703fea3 Merge branch 'feature-core-integration' into new 2026-02-08 22:00:01 +00:00
Snider
bee2679714 Merge branch 'feat/job-runner' into new 2026-02-08 21:59:51 +00:00
Snider
cf0011c508 Merge branch 'feat/prod-infra' into new 2026-02-08 21:59:43 +00:00
Snider
3f9840b2ea Merge branch 'codex/bugseti-mcp' into new 2026-02-08 21:59:29 +00:00
Snider
5558642d5a Merge branch 'feat/unifi-sdk' into new 2026-02-08 21:59:25 +00:00
Snider
084807975a Merge branch 'feat/release-and-installers' into new 2026-02-08 21:59:18 +00:00
Snider
fd02adac50 Merge branch 'feat/release-archives' into new 2026-02-08 21:58:59 +00:00
Snider
af0a31ddd3 Merge branch 'feature/log-batch' into new 2026-02-08 21:58:52 +00:00
Snider
6e74356481 Merge branch 'feature/mcp-batch' into new 2026-02-08 21:58:46 +00:00
Snider
ebf165bd51 Merge branch 'feature/help-batch' into new 2026-02-08 21:58:39 +00:00
Snider
afeadf46de Merge branch 'feature/errors-batch' into new 2026-02-08 21:58:32 +00:00
Snider
b5680bc9fe Merge branch 'feature/issue-139-help-search' into new 2026-02-08 21:58:01 +00:00
Snider
5c6d166842 Merge branch 'feature/issue-90-process-logger' into new 2026-02-08 21:57:14 +00:00
Snider
3d9048e888 Merge branch 'feature/issue-87-no-color-support' into new 2026-02-08 21:56:44 +00:00
Snider
550bd4d6c1 Merge branch 'feature/issue-84-core-thread-safety' into new 2026-02-08 21:56:41 +00:00
Snider
af8e6a657b Merge branch 'feature/issue-81-apply-confirmation' into new 2026-02-08 21:55:37 +00:00