47#include <unordered_map>
92 const std::string& constitution_text);
102 HookInterface* hook_iface,
103 InferenceInterface* inference);
110 void detach(HookInterface* hook_iface);
131 const std::string& identity_name,
bool enabled);
140 const std::string& identity_name,
141 const std::vector<std::string>& rules);
173 const std::string& content,
174 const std::string& tier,
175 const char* messages_json);
245 void (*cb)(
int attempt_n,
void* user_data),
void* user_data);
272 void (*start_cb)(
void* user_data),
273 void (*end_cb)(
void* user_data),
301 const char* context_json,
302 char** modified_json,
338 std::string build_critique_messages(
const std::string& content)
const;
346 std::string build_critique_params()
const;
358 const std::string& original,
360 const char* messages_json);
388 const std::string& content,
389 const std::string& tier,
390 const char* messages_json);
404 const char* messages_json);
415 std::string attempt_revision(
416 const std::string& content,
418 const char* messages_json);
427 std::string build_single_turn_json(
428 const std::string& prompt)
const;
439 std::string build_revision_messages(
440 const std::string& original,
442 const char* messages_json)
const;
451 std::string build_feedback_text(
463 std::string inject_feedback_into_messages(
464 const std::string& original,
465 const std::string& feedback,
466 const char* messages_json)
const;
476 int handle_hook(
const char* context_json,
char** modified_json);
485 static void write_modified_json(
486 const std::string& content,
char** modified_json);
496 static std::string extract_json_string(
497 const char* json,
const char* key);
506 static std::string extract_string_after_colon(
const char* pos);
516 static bool extract_compliant_field(
526 static void extract_violations(
537 static std::optional<Violation> extract_next_violation(
538 const std::string& json,
size_t& pos);
547 static void extract_revised_field(
551 std::string constitution_text_;
552 InferenceInterface* inference_ =
nullptr;
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_;
564 std::string current_tier_;
569 std::string current_tool_context_;
580 std::string current_tool_evidence_;
584 std::string current_system_prompt_;
588 mutable std::mutex result_mutex_;
594 std::atomic<bool> auto_retry_enabled_{
true};
601 struct PendingValidationState {
602 ValidationResult result;
603 CritiqueResult critique;
604 std::string messages_json;
609 std::optional<PendingValidationState> pending_state_;
610 mutable std::mutex pending_mutex_;
622 struct AttemptBoundaryCb {
623 void (*cb)(int,
void*) =
nullptr;
624 void* user_data =
nullptr;
626 AttemptBoundaryCb attempt_boundary_;
627 mutable std::mutex attempt_boundary_mutex_;
638 struct CritiqueCallbacks {
639 void (*start_cb)(
void*) =
nullptr;
640 void (*end_cb)(
void*) =
nullptr;
641 void* user_data =
nullptr;
643 CritiqueCallbacks critique_cbs_;
644 mutable std::mutex critique_cbs_mutex_;
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.
Hook point enum and callback types for engine lifecycle hooks.
entropic_hook_point_t
Hook points in the engine lifecycle.
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.
Structured result from a single critique generation pass.
Context passed through hook user_data.
class ConstitutionalValidator * validator
Validator instance.
InferenceInterface * inference
For critique generation.
Constitutional validation types — critique results and violations.