(in-package :opencortex) (defun validate-communication-protocol-schema (msg) "Strict structural validation for incoming communication protocol messages." (unless (listp msg) (error "Communication Protocol Schema Error: Message must be a property list (got ~s)" (type-of msg))) (let ((type (getf msg :type))) (unless (member type '(:REQUEST :EVENT :RESPONSE :LOG)) (error "Communication Protocol Schema Error: Invalid message type '~a'" type)) (case type (:REQUEST (unless (getf msg :target) (error "Communication Protocol Schema Error: REQUEST missing mandatory :target")) (unless (getf msg :payload) (error "Communication Protocol Schema Error: REQUEST missing mandatory :payload"))) (:EVENT (let ((payload (getf msg :payload))) (unless (and payload (listp payload)) (error "Communication Protocol Schema Error: EVENT missing or invalid :payload")) (unless (or (getf payload :action) (getf payload :sensor)) (error "Communication Protocol Schema Error: EVENT payload must contain :action or :sensor")))) (:RESPONSE (unless (getf msg :payload) (error "Communication Protocol Schema Error: RESPONSE missing mandatory :payload")))) t)) (defskill :skill-communication-protocol-validator :priority 95 :trigger (lambda (ctx) (member (getf (getf ctx :payload) :sensor) '(:protocol-received))) :probabilistic nil :deterministic (lambda (action ctx) (declare (ignore ctx)) (validate-communication-protocol-schema action) action))