Entropic 2.3.8
Local-first agentic inference engine
Loading...
Searching...
No Matches
constitutional_validator.h
Go to the documentation of this file.
1// SPDX-License-Identifier: Apache-2.0
34#pragma once
35
42
43#include <atomic>
44#include <mutex>
45#include <optional>
46#include <string>
47#include <unordered_map>
48
49namespace entropic {
50
61 InferenceInterface* inference;
62};
63
83public:
92 const std::string& constitution_text);
93
102 HookInterface* hook_iface,
103 InferenceInterface* inference);
104
110 void detach(HookInterface* hook_iface);
111
122 bool should_validate(const std::string& identity_name) const;
123
131 const std::string& identity_name, bool enabled);
132
139 void set_tier_rules(
140 const std::string& identity_name,
141 const std::vector<std::string>& rules);
142
154 void set_global_enabled(bool enabled);
155
173 const std::string& content,
174 const std::string& tier,
175 const char* messages_json);
176
183
184 // ── gh#30 (v2.1.5): consumer-driven retry controls ──────
185
198 void set_auto_retry(bool enabled);
199
206 bool auto_retry_enabled() const;
207
220
233
245 void (*cb)(int attempt_n, void* user_data), void* user_data);
246
272 void (*start_cb)(void* user_data),
273 void (*end_cb)(void* user_data),
274 void* user_data);
275
282 const ConstitutionalValidationConfig& config() const { return config_; }
283
299 static int hook_callback(
300 entropic_hook_point_t hook_point,
301 const char* context_json,
302 char** modified_json,
303 void* user_data);
304
311 std::string build_critique_prompt(const std::string& content) const;
312
319 static CritiqueResult parse_critique(const std::string& json_str);
320
321private:
329 CritiqueResult run_critique(const std::string& content);
330
338 std::string build_critique_messages(const std::string& content) const;
339
346 std::string build_critique_params() const;
347
357 std::string revise(
358 const std::string& original,
359 const CritiqueResult& critique,
360 const char* messages_json);
361
368 void store_result(const ValidationResult& result);
369
376 void log_verdict(const ValidationResult& result) const;
377
387 ValidationResult run_validation_loop(
388 const std::string& content,
389 const std::string& tier,
390 const char* messages_json);
391
401 ValidationResult apply_revisions(
402 ValidationResult result,
403 const CritiqueResult& initial_critique,
404 const char* messages_json);
405
415 std::string attempt_revision(
416 const std::string& content,
417 const CritiqueResult& critique,
418 const char* messages_json);
419
427 std::string build_single_turn_json(
428 const std::string& prompt) const;
429
439 std::string build_revision_messages(
440 const std::string& original,
441 const CritiqueResult& critique,
442 const char* messages_json) const;
443
451 std::string build_feedback_text(
452 const CritiqueResult& critique) const;
453
463 std::string inject_feedback_into_messages(
464 const std::string& original,
465 const std::string& feedback,
466 const char* messages_json) const;
467
476 int handle_hook(const char* context_json, char** modified_json);
477
485 static void write_modified_json(
486 const std::string& content, char** modified_json);
487
496 static std::string extract_json_string(
497 const char* json, const char* key);
498
506 static std::string extract_string_after_colon(const char* pos);
507
516 static bool extract_compliant_field(
517 const std::string& json, CritiqueResult& result);
518
526 static void extract_violations(
527 const std::string& json, CritiqueResult& result);
528
537 static std::optional<Violation> extract_next_violation(
538 const std::string& json, size_t& pos);
539
547 static void extract_revised_field(
548 const std::string& json, CritiqueResult& result);
549
551 std::string constitution_text_;
552 InferenceInterface* inference_ = nullptr;
553 ValidationContext context_;
554
556 bool global_enabled_;
558 std::unordered_map<std::string, bool> identity_overrides_;
560 std::unordered_map<std::string, std::vector<std::string>> tier_rules_;
561 mutable std::mutex overrides_mutex_;
562
564 std::string current_tier_;
569 std::string current_tool_context_;
570
580 std::string current_tool_evidence_;
584 std::string current_system_prompt_;
585
587 ValidationResult last_result_;
588 mutable std::mutex result_mutex_;
589
590 // ── gh#30 (v2.1.5): consumer-driven retry controls ─────
594 std::atomic<bool> auto_retry_enabled_{true};
595
601 struct PendingValidationState {
602 ValidationResult result;
603 CritiqueResult critique;
604 std::string messages_json;
605 std::string tier;
606 };
609 std::optional<PendingValidationState> pending_state_;
610 mutable std::mutex pending_mutex_;
611
622 struct AttemptBoundaryCb {
623 void (*cb)(int, void*) = nullptr;
624 void* user_data = nullptr;
625 };
626 AttemptBoundaryCb attempt_boundary_;
627 mutable std::mutex attempt_boundary_mutex_;
628
638 struct CritiqueCallbacks {
639 void (*start_cb)(void*) = nullptr;
640 void (*end_cb)(void*) = nullptr;
641 void* user_data = nullptr;
642 };
643 CritiqueCallbacks critique_cbs_;
644 mutable std::mutex critique_cbs_mutex_;
645};
646
647} // namespace entropic
Post-generation constitutional compliance validator.
bool auto_retry_enabled() const
Whether auto-revision is currently enabled.
void set_global_enabled(bool enabled)
Toggle the global validation gate at runtime.
entropic_error_t attach(HookInterface *hook_iface, InferenceInterface *inference)
Register this validator as a POST_GENERATE hook.
static int hook_callback(entropic_hook_point_t hook_point, const char *context_json, char **modified_json, void *user_data)
POST_GENERATE hook callback for constitutional validation.
void set_tier_rules(const std::string &identity_name, const std::vector< std::string > &rules)
Set per-identity validation rules from frontmatter.
entropic_error_t accept_last()
Finalize the cached attempt as the validation result.
entropic_error_t resume_retry()
Resume the revision pass after a paused validation.
const ConstitutionalValidationConfig & config() const
Get the config (read-only after construction).
bool should_validate(const std::string &identity_name) const
Check if validation is enabled for a given identity.
void set_critique_callbacks(void(*start_cb)(void *user_data), void(*end_cb)(void *user_data), void *user_data)
Register the critique start/end callback pair (gh#50).
static CritiqueResult parse_critique(const std::string &json_str)
Parse critique JSON into structured result (exposed for testing).
ValidationResult validate(const std::string &content, const std::string &tier, const char *messages_json)
Run the validation pipeline on generated content.
ValidationResult last_result() const
Get the last validation result.
void set_attempt_boundary_cb(void(*cb)(int attempt_n, void *user_data), void *user_data)
Register the attempt-boundary callback.
void set_auto_retry(bool enabled)
Enable or disable automatic revision after rejection.
std::string build_critique_prompt(const std::string &content) const
Build the critique prompt (exposed for testing).
void detach(HookInterface *hook_iface)
Deregister the POST_GENERATE hook.
void set_identity_validation(const std::string &identity_name, bool enabled)
Set per-identity validation override.
Configuration structs with defaults.
Error types for cross-.so error reporting.
entropic_error_t
Error codes returned by all C API functions.
Definition error.h:35
Hook point enum and callback types for engine lifecycle hooks.
entropic_hook_point_t
Hook points in the engine lifecycle.
Definition hooks.h:34
Hook dispatch interface injected into engine subsystems.
Function pointer types for core-to-inference communication.
Activate model on GPU (WARM → ACTIVE).
Constitutional validation pipeline configuration.
Definition config.h:565
Structured result from a single critique generation pass.
Definition validation.h:44
Context passed through hook user_data.
class ConstitutionalValidator * validator
Validator instance.
InferenceInterface * inference
For critique generation.
Constitutional validation types — critique results and violations.