molecule-core/workspace-template
Molecule AI Backend Engineer f9973fda77 fix(hitl): emit log_event() on approval grant and denial — Art. 14 audit gap (closes #893)
The @requires_approval decorator and request_approval() call executed the
approval gate correctly but never wrote the outcome to the activity log.
EU AI Act Article 14 requires documented evidence that HITL measures were
exercised — the missing log_event() calls meant GET /workspaces/:id/activity
could not surface HITL gate outcomes.

Add log_event() at both resolution points in the requires_approval wrapper:
- Denial: event_type="hitl", action="approve", outcome="denied", actor=decided_by
- Grant:  event_type="hitl", action="approve", outcome="granted", actor=decided_by

Both calls follow the existing try/except pattern used for audit calls elsewhere
in hitl.py so a missing audit module never blocks the approval flow.

Tests: TestRequiresApproval.test_logs_hitl_denied_event and
test_logs_hitl_approved_event verify log_event is called with the correct
outcome on each resolution path.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-18 03:10:26 +00:00
..
adapters feat(adapters): add Google ADK runtime adapter (#542) 2026-04-17 00:08:17 +00:00
builtin_tools fix(hitl): emit log_event() on approval grant and denial — Art. 14 audit gap (closes #893) 2026-04-18 03:10:26 +00:00
molecule_audit fix(security): address Security Auditor findings on audit-ledger (#651) 2026-04-17 07:30:10 +00:00
plugins_registry fix(plugins_registry): deduplicate handlers in _deep_merge_hooks() 2026-04-17 05:22:00 +00:00
policies
scripts fix(github): refresh installation token when TTL < 10 min (#547) (#567) 2026-04-17 00:47:03 +00:00
skill_loader fix(security): hitl task-id ownership + wire fail_open_if_no_scanner in loader (closes #265, #268) 2026-04-15 21:18:52 -07:00
tests fix(hitl): emit log_event() on approval grant and denial — Art. 14 audit gap (closes #893) 2026-04-18 03:10:26 +00:00
a2a_cli.py
a2a_client.py fix(a2a): add missing Authorization header to delegation and message calls (#401) 2026-04-16 00:53:18 -07:00
a2a_executor.py fix: properly remove adapter subdirectories + move shared code to root 2026-04-16 04:59:13 -07:00
a2a_mcp_server.py
a2a_tools.py fix(a2a): add missing Authorization header to delegation and message calls (#401) 2026-04-16 00:53:18 -07:00
adapter_base.py fix: properly remove adapter subdirectories + move shared code to root 2026-04-16 04:59:13 -07:00
agent.py
agents_md.py feat(#733): implement AGENTS.md auto-generation 2026-04-17 16:20:39 +00:00
build-all.sh chore: extract workspace runtime to PyPI + move adapter Dockerfiles to template repos 2026-04-16 04:33:10 -07:00
claude_sdk_executor.py feat(issue-652): wire effort and task_budget to claude sdk output_config 2026-04-17 07:33:07 +00:00
cli_executor.py feat(adapters): add gemini-cli runtime adapter (closes #332) (#379) 2026-04-15 23:30:00 -07:00
config.py fix(gate-6): restore claude-opus-4-7 default — reverted by pre-#743 branch 2026-04-17 16:21:04 +00:00
consolidation.py fix(security): N1 — add auth headers to all platform calls in Python callers 2026-04-14 08:37:50 +00:00
coordinator.py fix: properly remove adapter subdirectories + move shared code to root 2026-04-16 04:59:13 -07:00
Dockerfile fix(template): copy molecule-git-token-helper.sh into image and fix path 2026-04-17 06:27:08 +00:00
entrypoint.sh fix(template): copy molecule-git-token-helper.sh into image and fix path 2026-04-17 06:27:08 +00:00
events.py
executor_helpers.py
heartbeat.py fix(security): N1 — add auth headers to all platform calls in Python callers 2026-04-14 08:37:50 +00:00
hermes_executor.py feat(hermes): stacked system messages — persona + tools + reasoning policy (#499) 2026-04-17 23:53:12 +00:00
initial_prompt.py
main.py feat(#733): implement AGENTS.md auto-generation 2026-04-17 16:20:39 +00:00
molecule_ai_status.py
platform_auth.py fix(security): H3 github_pat_ redaction + M4 atomic token write (audit cycle 10) 2026-04-14 09:34:27 +00:00
plugins.py
preflight.py
prompt.py fix: properly remove adapter subdirectories + move shared code to root 2026-04-16 04:59:13 -07:00
pytest.ini
rebuild-runtime-images.sh fix(security): allowlist-validate runtime arg in rebuild-runtime-images.sh 2026-04-17 10:27:11 +00:00
requirements.txt feat: molecule-audit-ledger — HMAC-SHA256 immutable agent event log (#594) 2026-04-17 06:55:36 +00:00
shared_runtime.py fix: properly remove adapter subdirectories + move shared code to root 2026-04-16 04:59:13 -07:00
transcript_auth.py fix(security): /transcript endpoint fails closed when auth token missing (#328) 2026-04-15 21:17:37 -07:00
watcher.py