{"id":483479,"date":"2026-06-13T07:41:33","date_gmt":"2026-06-13T07:41:33","guid":{"rendered":"https:\/\/savepearlharbor.com\/?p=483479"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=483479","title":{"rendered":"\u041a\u0430\u043a \u044f \u043f\u043e\u0441\u0442\u0440\u043e\u0438\u043b guardrails, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u0434\u0430\u043b\u0438 \u043c\u043e\u0435\u043c\u0443 AI-\u0430\u0433\u0435\u043d\u0442\u0443 \u043f\u043e\u0439\u0442\u0438 \u0432\u0440\u0430\u0437\u043d\u043e\u0441"},"content":{"rendered":"<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041d\u0430 \u0442\u0440\u0435\u0442\u0438\u0439 \u0434\u0435\u043d\u044c \u043c\u043e\u0439 \u0430\u0433\u0435\u043d\u0442 \u0441\u043b\u0438\u043b email \u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043b\u0438\u0435\u043d\u0442\u0430 \u0432 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u043a\u0443 \u0441 \u0434\u0440\u0443\u0433\u0438\u043c \u043a\u043b\u0438\u0435\u043d\u0442\u043e\u043c. \u042d\u0442\u043e \u0431\u044b\u043b\u0430 \u043d\u0435 \u0433\u0438\u043f\u043e\u0442\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u0438\u0437 \u0434\u043e\u043a\u043b\u0430\u0434\u0430 \u043d\u0430 \u043a\u043e\u043d\u0444\u0435\u0440\u0435\u043d\u0446\u0438\u0438. \u042d\u0442\u043e \u0431\u044b\u043b \u043c\u043e\u0439 \u043a\u043e\u0434, \u0432 \u043f\u0440\u043e\u0434\u0435, \u0434\u0435\u043b\u0430\u044e\u0449\u0438\u0439 \u0442\u043e, \u0447\u0442\u043e \u044f \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043b.<\/p>\n<p>\u042f \u0441\u043e\u0431\u0440\u0430\u043b support-\u0430\u0433\u0435\u043d\u0442\u0430 \u043d\u0430 LangGraph \u0438 GPT-4o. \u041e\u043d \u0443\u043c\u0435\u043b \u0438\u0441\u043a\u0430\u0442\u044c \u043f\u043e \u0431\u0430\u0437\u0435 \u0437\u043d\u0430\u043d\u0438\u0439, \u043f\u043e\u0434\u0442\u044f\u0433\u0438\u0432\u0430\u0442\u044c \u0434\u0435\u0442\u0430\u043b\u0438 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u0430 \u0438 \u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043e\u0442\u0432\u0435\u0442\u044b. \u0412 staging \u043e\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e. \u0412 \u043f\u0440\u043e\u0434\u0435 \u0435\u043c\u0443 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u043b\u043e\u0441\u044c \u0440\u043e\u0432\u043d\u043e 72 \u0447\u0430\u0441\u0430, \u0447\u0442\u043e\u0431\u044b \u0432\u044b\u0442\u0430\u0449\u0438\u0442\u044c PII \u043e\u0434\u043d\u043e\u0433\u043e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f \u0432 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440 \u0441 \u0434\u0440\u0443\u0433\u0438\u043c. \u041f\u0440\u0438\u0447\u0438\u043d\u0430 \u043e\u043a\u0430\u0437\u0430\u043b\u0430\u0441\u044c \u0434\u043e \u043d\u0435\u043b\u043e\u0432\u043a\u043e\u0433\u043e \u043f\u0440\u043e\u0441\u0442\u043e\u0439: \u043c\u043e\u0434\u0435\u043b\u044c \u0432\u043a\u043b\u044e\u0447\u0438\u043b\u0430 \u0441\u044b\u0440\u043e\u0439 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0438\u0437 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u0440\u044f\u043c\u043e \u0432 \u043e\u0442\u0432\u0435\u0442, \u0438 \u043d\u0438\u0447\u0442\u043e \u0432 \u043c\u043e\u0451\u043c \u043f\u0430\u0439\u043f\u043b\u0430\u0439\u043d\u0435 \u044d\u0442\u043e \u043d\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u043b\u043e.<\/p>\n<p>\u041f\u043e\u0441\u0442\u0444\u0430\u043a\u0442\u0443\u043c \u0444\u0438\u043a\u0441 \u0431\u044b\u043b \u043e\u0447\u0435\u0432\u0438\u0434\u0435\u043d. \u0424\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0438 \u0434\u043b\u044f AI-\u0430\u0433\u0435\u043d\u0442\u043e\u0432 \u0434\u0430\u044e\u0442 \u0432\u0430\u043c \u043e\u0440\u043a\u0435\u0441\u0442\u0440\u0430\u0446\u0438\u044e, \u0432\u044b\u0437\u043e\u0432 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0438 \u043f\u0430\u043c\u044f\u0442\u044c. \u041e\u043d\u0438 \u043d\u0435 \u0434\u0430\u044e\u0442 \u0432\u0430\u043c \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u044c. \u042d\u0442\u043e \u0443\u0436\u0435 \u043d\u0430 \u0432\u0430\u0441.<\/p>\n<h3>\u041f\u043e\u0447\u0435\u043c\u0443 \u0432\u0430\u0448 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a \u043d\u0435 \u0432\u043a\u043b\u044e\u0447\u0430\u0435\u0442 guardrails<\/h3>\n<p>LangChain, CrewAI, LangGraph, Agents SDK \u043e\u0442 OpenAI. \u0412\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u043b\u044e\u0431\u043e\u0439. \u041d\u0438 \u043e\u0434\u0438\u043d \u0438\u0437 \u043d\u0438\u0445 \u043d\u0435 \u0438\u0434\u0451\u0442 \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0441 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0435\u0439 \u0432\u0445\u043e\u0434\u0430, \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0446\u0438\u0435\u0439 \u0432\u044b\u0445\u043e\u0434\u0430 \u0438\u043b\u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u043c \u0440\u0430\u0441\u0445\u043e\u0434\u043e\u0432. \u041e\u043d\u0438 \u0438\u0441\u0445\u043e\u0434\u044f\u0442 \u0438\u0437 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0432\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u0435 \u044d\u0442\u043e \u0441\u0430\u043c\u0438.<\/p>\n<p>\u0411\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u043a\u043e\u043c\u0430\u043d\u0434 \u0442\u0430\u043a \u0438 \u043d\u0435 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442.<\/p>\n<p>\u041f\u043e\u0447\u0435\u043c\u0443 \u044d\u0442\u043e \u0432\u0430\u0436\u043d\u043e \u2014 \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0435\u0442 \u043f\u0440\u043e\u0441\u0442\u0430\u044f \u0430\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u043a\u0430. \u041f\u0440\u0438 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u0438 90% \u043d\u0430 \u0448\u0430\u0433, \u0430\u0433\u0435\u043d\u0442\u043d\u044b\u0439 workflow \u0438\u0437 5 \u0448\u0430\u0433\u043e\u0432 \u0443\u0441\u043f\u0435\u0448\u0435\u043d \u0432 59% \u0441\u043b\u0443\u0447\u0430\u0435\u0432. Workflow \u0438\u0437 10 \u0448\u0430\u0433\u043e\u0432 \u043f\u0430\u0434\u0430\u0435\u0442 \u0434\u043e 35%. \u041d\u0430 20 \u0448\u0430\u0433\u0430\u0445 \u0432\u044b \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 12%. \u041a\u0430\u0436\u0434\u044b\u0439 \u043d\u0435\u0437\u0430\u0449\u0438\u0449\u0451\u043d\u043d\u044b\u0439 \u0448\u0430\u0433 \u2014 \u044d\u0442\u043e \u0443\u043c\u043d\u043e\u0436\u0435\u043d\u0438\u0435 \u0432\u0430\u0448\u0435\u0439 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u0438 \u043e\u0442\u043a\u0430\u0437\u0430.<\/p>\n<p>Guardrails \u043d\u0435 \u0447\u0438\u043d\u044f\u0442 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c. \u041e\u043d\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044e\u0442 \u0440\u0430\u0434\u0438\u0443\u0441 \u043f\u043e\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u043a\u043e\u0433\u0434\u0430 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c \u043e\u0442\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442. \u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 \u00ab\u0430\u0433\u0435\u043d\u0442 \u0434\u0430\u043b \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u043e\u0442\u0432\u0435\u0442\u00bb \u0438 \u00ab\u0430\u0433\u0435\u043d\u0442 \u0434\u0430\u043b \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u043e\u0442\u0432\u0435\u0442, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u043f\u0430\u043b \u0447\u0435\u0439-\u0442\u043e \u043d\u043e\u043c\u0435\u0440 \u0441\u043e\u0446\u0441\u0442\u0440\u0430\u0445\u043e\u0432\u0430\u043d\u0438\u044f\u00bb \u2014 \u044d\u0442\u043e \u043e\u0434\u0438\u043d output-\u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440.<\/p>\n<p>\u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u0434\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 \u044f \u0441\u0442\u0440\u043e\u0438\u043b \u0441\u0442\u0435\u043a guardrails. \u041a\u043e\u0434 \u043d\u0438\u0436\u0435 \u2014 \u0442\u043e, \u043a \u0447\u0435\u043c\u0443 \u044f \u0432 \u0438\u0442\u043e\u0433\u0435 \u043f\u0440\u0438\u0448\u0451\u043b.<\/p>\n<h3>\u0427\u0435\u0442\u044b\u0440\u0435 guardrail, \u043d\u0443\u0436\u043d\u044b\u0435 \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0430\u0433\u0435\u043d\u0442\u0443<\/h3>\n<p>\u041a\u0430\u0436\u0434\u043e\u043c\u0443 \u0430\u0433\u0435\u043d\u0442\u0443 \u043d\u0443\u0436\u043d\u0430 \u0437\u0430\u0449\u0438\u0442\u0430 \u0432 \u0447\u0435\u0442\u044b\u0440\u0451\u0445 \u0442\u043e\u0447\u043a\u0430\u0445:<\/p>\n<ol>\n<li>\n<p><strong>Input guardrails<\/strong> \u043b\u043e\u0432\u044f\u0442 prompt injection \u0438 \u0432\u044b\u0447\u0438\u0449\u0430\u044e\u0442 \u0447\u0443\u0432\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0438\u0445 \u0443\u0432\u0438\u0434\u0438\u0442 LLM.<\/p>\n<\/li>\n<li>\n<p><strong>Output guardrails<\/strong> \u0432\u0430\u043b\u0438\u0434\u0438\u0440\u0443\u044e\u0442 \u043e\u0442\u0432\u0435\u0442\u044b \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0438\u0445 \u0443\u0432\u0438\u0434\u044f\u0442 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438, \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044f \u0433\u0430\u043b\u043b\u044e\u0446\u0438\u043d\u0430\u0446\u0438\u0438 \u0438 \u0443\u0442\u0451\u043a\u0448\u0438\u0439 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442.<\/p>\n<\/li>\n<li>\n<p><strong>Cost circuit breakers<\/strong> \u043d\u0435 \u0434\u0430\u044e\u0442 \u0441\u0447\u0451\u0442\u0443 \u0437\u0430 API \u0443\u043b\u0435\u0442\u0435\u0442\u044c \u0432 \u043a\u043e\u0441\u043c\u043e\u0441 \u0438\u0437-\u0437\u0430 \u0437\u0430\u0446\u0438\u043a\u043b\u0438\u0432\u0430\u043d\u0438\u044f \u0438\u043b\u0438 \u043d\u0435\u043e\u0436\u0438\u0434\u0430\u043d\u043d\u043e \u0434\u043b\u0438\u043d\u043d\u044b\u0445 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p><strong>Tool call validators<\/strong> \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0430\u044e\u0442, \u0447\u0442\u043e \u0430\u0433\u0435\u043d\u0442 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437\u0440\u0435\u0448\u0451\u043d\u043d\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438, \u043f\u0440\u043e\u0445\u043e\u0434\u044f\u0449\u0438\u043c\u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u0441\u0445\u0435\u043c\u044b.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412\u0441\u0435 \u0447\u0435\u0442\u044b\u0440\u0435 \u0443\u043c\u0435\u0449\u0430\u044e\u0442\u0441\u044f \u043c\u0435\u043d\u0435\u0435 \u0447\u0435\u043c \u0432 200 \u0441\u0442\u0440\u043e\u043a Python. \u041d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043f\u043e latency \u2014 10\u201350 \u043c\u0441 \u043d\u0430 \u0441\u043b\u043e\u0439. \u0410\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u0430 \u2014 \u0443\u0437\u043d\u0430\u0432\u0430\u0442\u044c \u043e \u0441\u0431\u043e\u044f\u0445 \u043e\u0442 \u0441\u0432\u043e\u0438\u0445 \u043a\u043b\u0438\u0435\u043d\u0442\u043e\u0432.<\/p>\n<h3>Input guardrails: \u043b\u043e\u0432\u0438\u043c \u043f\u043b\u043e\u0445\u0438\u0435 \u043f\u0440\u043e\u043c\u043f\u0442\u044b \u0434\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f<\/h3>\n<p>\u0412\u0430\u0448 input-\u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a LLM \u0432\u043e\u043e\u0431\u0449\u0435 \u0443\u0432\u0438\u0434\u0438\u0442 \u043f\u0440\u043e\u043c\u043f\u0442. \u041e\u043d \u0434\u0435\u043b\u0430\u0435\u0442 \u0434\u0432\u0435 \u0432\u0435\u0449\u0438: \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u0442 \u043f\u043e\u043f\u044b\u0442\u043a\u0438 \u0438\u043d\u044a\u0435\u043a\u0446\u0438\u0438 \u0438 \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0435\u0442 PII.<\/p>\n<pre><code class=\"python\">import refrom dataclasses import dataclass@dataclassclass ValidationResult:    is_valid: bool    reason: str = \"\"    sanitized_input: str = \"\"class InputGuardrail:    INJECTION_PATTERNS = [        r\"ignore\\s+(all\\s+)?previous\\s+instructions\",        r\"you\\s+are\\s+now\\s+a\",        r\"disregard\\s+(your|all)\\s+(rules|instructions)\",        r\"system\\s*prompt\\s*:\",        r\"&lt;&lt;\\s*SYS\\s*&gt;&gt;\",    ]    PII_PATTERNS = {        \"ssn\": r\"\\b\\d{3}-\\d{2}-\\d{4}\\b\",        \"credit_card\": r\"\\b\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}\\b\",        \"email\": r\"\\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Z|a-z]{2,}\\b\",    }    def validate(self, user_input: str) -&gt; ValidationResult:        # Check for prompt injection        for pattern in self.INJECTION_PATTERNS:            if re.search(pattern, user_input, re.IGNORECASE):                return ValidationResult(                    is_valid=False,                    reason=f\"Prompt injection detected: {pattern}\"                )        # Scrub PII from input        sanitized = user_input        for pii_type, pattern in self.PII_PATTERNS.items():            sanitized = re.sub(pattern, f\"[REDACTED_{pii_type.upper()}]\", sanitized)        return ValidationResult(            is_valid=True,            sanitized_input=sanitized        )<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:87px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u042d\u0442\u043e \u043d\u0435 \u043f\u0443\u043b\u0435\u043d\u0435\u043f\u0440\u043e\u0431\u0438\u0432\u0430\u0435\u043c\u043e. \u041d\u0430\u0441\u0442\u043e\u0439\u0447\u0438\u0432\u044b\u0439 \u0430\u0442\u0430\u043a\u0443\u044e\u0449\u0438\u0439 \u043e\u0431\u043e\u0439\u0434\u0451\u0442 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u043d\u043e\u0435 \u043d\u0430 regex \u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0438\u043d\u044a\u0435\u043a\u0446\u0438\u0439. \u041d\u043e \u043e\u043d\u043e \u043b\u043e\u0432\u0438\u0442 \u0447\u0430\u0441\u0442\u044b\u0435 \u043f\u043e\u043f\u044b\u0442\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e \u043c\u043e\u0435\u043c\u0443 \u043e\u043f\u044b\u0442\u0443 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 \u043e\u043a\u043e\u043b\u043e 80% \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0430\u0442\u0430\u043a. \u0414\u043b\u044f \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d\u0430 \u0441 \u0447\u0443\u0432\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0434\u043e\u0431\u0430\u0432\u044c\u0442\u0435 \u043f\u043e\u0432\u0435\u0440\u0445 regex-\u043f\u0440\u043e\u0445\u043e\u0434\u0430 \u043c\u043e\u0434\u0435\u043b\u044c-\u043a\u043b\u0430\u0441\u0441\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 (\u0432\u0440\u043e\u0434\u0435 Lakera Guard \u0438\u043b\u0438 \u0434\u043e\u043e\u0431\u0443\u0447\u0435\u043d\u043d\u043e\u0433\u043e DistilBERT).<\/p>\n<p>\u0412\u044b\u0447\u0438\u0441\u0442\u043a\u0430 PII \u2014 \u0438\u043c\u0435\u043d\u043d\u043e \u0442\u0430 \u0447\u0430\u0441\u0442\u044c, \u0447\u0442\u043e \u0441\u043f\u0430\u0441\u043b\u0430 \u0431\u044b \u043c\u0435\u043d\u044f \u043d\u0430 \u0442\u0440\u0435\u0442\u0438\u0439 \u0434\u0435\u043d\u044c. \u0415\u0441\u043b\u0438 \u0431\u044b \u043c\u043e\u0439 input guardrail \u0432\u044b\u0440\u0435\u0437\u0430\u043b email \u0438\u0437 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043e\u043d \u043f\u043e\u043f\u0430\u043b \u0432 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440, \u0443\u0442\u0435\u0447\u043a\u0438 \u0431\u044b \u043d\u0435 \u0441\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c.<\/p>\n<h3>Output guardrails: \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u0433\u0430\u043b\u043b\u044e\u0446\u0438\u043d\u0430\u0446\u0438\u0438 \u0434\u043e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f<\/h3>\n<p>\u0412\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0432\u044b\u0445\u043e\u0434\u0430 \u2014 \u0442\u043e \u043c\u0435\u0441\u0442\u043e, \u0433\u0434\u0435 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u043a\u043e\u043c\u0430\u043d\u0434 \u043f\u0440\u043e\u043f\u0443\u0441\u043a\u0430\u044e\u0442 guardrails \u0432\u043e\u0432\u0441\u0435. \u041c\u043e\u0434\u0435\u043b\u044c \u0434\u0430\u043b\u0430 \u043e\u0442\u0432\u0435\u0442, \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0440\u0430\u0437\u0443\u043c\u043d\u043e, \u043e\u0442\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c. \u041d\u043e \u00ab\u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0440\u0430\u0437\u0443\u043c\u043d\u043e\u00bb \u2014 \u044d\u0442\u043e \u043d\u0435 \u0442\u043e\u0442 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0430\u0433\u0430\u0442\u044c\u0441\u044f.<\/p>\n<pre><code class=\"python\">from pydantic import BaseModel, field_validatorfrom typing import Optionalimport jsonclass AgentResponse(BaseModel):    answer: str    confidence: float    sources: list[str]    @field_validator(\"confidence\")    @classmethod    def check_confidence(cls, v):        if not 0.0 &lt;= v &lt;= 1.0:            raise ValueError(\"Confidence must be between 0 and 1\")        return v    @field_validator(\"answer\")    @classmethod    def check_no_pii_leak(cls, v):        pii_patterns = [            r\"\\b\\d{3}-\\d{2}-\\d{4}\\b\",  # SSN            r\"\\b\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}\\b\",  # Credit card        ]        for pattern in pii_patterns:            if re.search(pattern, v):                raise ValueError(\"Response contains potential PII\")        return vclass OutputGuardrail:    def __init__(self, confidence_threshold: float = 0.7):        self.confidence_threshold = confidence_threshold    def validate(self, raw_response: dict) -&gt; ValidationResult:        try:            response = AgentResponse(**raw_response)        except Exception as e:            return ValidationResult(                is_valid=False,                reason=f\"Response failed schema validation: {e}\"            )        if response.confidence &lt; self.confidence_threshold:            return ValidationResult(                is_valid=False,                reason=f\"Confidence {response.confidence} below threshold\"            )        if not response.sources:            return ValidationResult(                is_valid=False,                reason=\"No sources provided for claim\"            )        return ValidationResult(is_valid=True, sanitized_input=response.answer)<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>Pydantic-\u043c\u043e\u0434\u0435\u043b\u044c \u0434\u0435\u043b\u0430\u0435\u0442 \u0434\u0432\u043e\u0439\u043d\u0443\u044e \u0440\u0430\u0431\u043e\u0442\u0443. \u041e\u043d\u0430 \u043d\u0430\u0432\u044f\u0437\u044b\u0432\u0430\u0435\u0442 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 (LLM \u043e\u0431\u044f\u0437\u0430\u043d\u0430 \u0432\u0435\u0440\u043d\u0443\u0442\u044c JSON \u0441 answer, confidence \u0438 sources) \u0438 \u043f\u0440\u043e\u0433\u043e\u043d\u044f\u0435\u0442 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043d\u044b\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 (\u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e PII \u0432 \u0432\u044b\u0445\u043e\u0434\u0435). \u041a\u043e\u0433\u0434\u0430 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u043f\u0430\u0434\u0430\u0435\u0442, \u043c\u043e\u0439 \u0430\u0433\u0435\u043d\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u0442 \u0437\u0430\u043f\u0440\u043e\u0441 \u0441 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043e\u043c: \u00ab\u0412\u0430\u0448 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0439 \u043e\u0442\u0432\u0435\u0442 \u043e\u0442\u043a\u043b\u043e\u043d\u0451\u043d, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e [\u043f\u0440\u0438\u0447\u0438\u043d\u0430]. \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u0441\u043d\u043e\u0432\u0430\u00bb.<\/p>\n<p>\u0414\u0432\u0430 \u043f\u043e\u0432\u0442\u043e\u0440\u0430 \u0441\u043e \u0432\u0441\u0451 \u0431\u043e\u043b\u0435\u0435 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c\u0438 \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044f\u043c\u0438 \u0447\u0438\u043d\u044f\u0442 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u0439 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0438. \u0415\u0441\u043b\u0438 \u043f\u0430\u0434\u0430\u0435\u0442 \u0442\u0440\u0438 \u0440\u0430\u0437\u0430 \u2014 \u044f \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e \u0437\u0430\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0439 fallback-\u043e\u0442\u0432\u0435\u0442 \u0438 \u043b\u043e\u0433\u0438\u0440\u0443\u044e \u0438\u043d\u0446\u0438\u0434\u0435\u043d\u0442.<\/p>\n<h3>Kill switch: circuit breaker \u043f\u043e \u0440\u0430\u0441\u0445\u043e\u0434\u0430\u043c \u0438 \u0442\u043e\u043a\u0435\u043d\u0430\u043c<\/h3>\n<p>\u042d\u0442\u043e \u0442\u043e\u0442 guardrail, \u043f\u0440\u043e \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u043f\u0438\u0448\u0435\u0442, \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u043e\u043d \u0441\u0442\u043e\u0438\u043b \u043c\u043d\u0435 $400.<\/p>\n<p>\u0423 \u043c\u0435\u043d\u044f \u0431\u044b\u043b \u0431\u0430\u0433, \u0438\u0437-\u0437\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0430\u0433\u0435\u043d\u0442 \u0432\u0445\u043e\u0434\u0438\u043b \u0432 \u0446\u0438\u043a\u043b \u043f\u043e\u0432\u0442\u043e\u0440\u043e\u0432. \u0412\u044b\u0437\u043e\u0432 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430 \u043f\u0430\u0434\u0430\u043b, \u0430\u0433\u0435\u043d\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u043b, \u043f\u043e\u0432\u0442\u043e\u0440 \u043f\u0430\u0434\u0430\u043b \u0447\u0443\u0442\u044c \u0438\u043d\u0430\u0447\u0435, \u0438 \u0430\u0433\u0435\u043d\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u043b \u0441\u043d\u043e\u0432\u0430. \u041a\u0430\u0436\u0434\u044b\u0439 \u043f\u043e\u0432\u0442\u043e\u0440 \u0441\u0436\u0438\u0433\u0430\u043b \u0442\u043e\u043a\u0435\u043d\u044b \u043d\u0430 \u0448\u0430\u0433\u0435 \u0440\u0430\u0441\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u044f \u043f\u043b\u044e\u0441 \u043d\u0430 \u0432\u044b\u0437\u043e\u0432\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430. \u041e\u043d \u043a\u0440\u0443\u0442\u0438\u043b\u0441\u044f \u0448\u0435\u0441\u0442\u044c \u0447\u0430\u0441\u043e\u0432 \u043d\u043e\u0447\u044c\u044e, \u043f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u044f \u0437\u0430\u043c\u0435\u0442\u0438\u043b.<\/p>\n<pre><code class=\"python\">import timefrom threading import Lockclass CostCircuitBreaker:    def __init__(        self,        max_tokens_per_request: int = 50_000,        max_tokens_per_session: int = 200_000,        max_api_calls_per_minute: int = 30,        max_daily_spend_usd: float = 50.0,    ):        self.max_tokens_per_request = max_tokens_per_request        self.max_tokens_per_session = max_tokens_per_session        self.max_api_calls_per_minute = max_api_calls_per_minute        self.max_daily_spend = max_daily_spend_usd        self._session_tokens = 0        self._minute_calls = []        self._daily_spend = 0.0        self._lock = Lock()    def check_budget(self, estimated_tokens: int) -&gt; ValidationResult:        with self._lock:            # Per-request limit            if estimated_tokens &gt; self.max_tokens_per_request:                return ValidationResult(                    is_valid=False,                    reason=f\"Request needs ~{estimated_tokens} tokens, \"                           f\"limit is {self.max_tokens_per_request}\"                )            # Session limit            if self._session_tokens + estimated_tokens &gt; self.max_tokens_per_session:                return ValidationResult(                    is_valid=False,                    reason=\"Session token budget exhausted\"                )            # Rate limit            now = time.time()            self._minute_calls = [t for t in self._minute_calls if now - t &lt; 60]            if len(self._minute_calls) &gt;= self.max_api_calls_per_minute:                return ValidationResult(                    is_valid=False,                    reason=\"API call rate limit exceeded\"                )            # Daily spend            estimated_cost = (estimated_tokens \/ 1_000_000) * 3.00  # ~GPT-4o rate            if self._daily_spend + estimated_cost &gt; self.max_daily_spend:                return ValidationResult(                    is_valid=False,                    reason=\"Daily spend limit reached\"                )            # All checks passed, record usage            self._session_tokens += estimated_tokens            self._minute_calls.append(now)            self._daily_spend += estimated_cost            return ValidationResult(is_valid=True)<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>Per-request \u043b\u0438\u043c\u0438\u0442 \u043b\u043e\u0432\u0438\u0442 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439: \u043e\u0434\u043d\u043e \u0433\u0438\u0433\u0430\u043d\u0442\u0441\u043a\u043e\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043d\u043e\u0435 \u043e\u043a\u043d\u043e, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u0440\u043e\u0436\u0436\u0451\u0442 \u0432\u0430\u0448 \u0431\u044e\u0434\u0436\u0435\u0442. Session-\u043b\u0438\u043c\u0438\u0442 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u0435\u0442 \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u044b\u0435 \u0442\u0440\u0430\u0442\u044b \u043d\u0430 \u043e\u0434\u0438\u043d \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440. Rate-\u043b\u0438\u043c\u0438\u0442 \u043f\u0440\u0435\u0434\u043e\u0442\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0448\u0442\u043e\u0440\u043c \u043f\u043e\u0432\u0442\u043e\u0440\u043e\u0432. \u0410 \u0434\u043d\u0435\u0432\u043d\u043e\u0439 \u043b\u0438\u043c\u0438\u0442 \u0442\u0440\u0430\u0442 \u2014 \u0432\u0430\u0448 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043b\u043e\u043a.<\/p>\n<p>\u042f \u0432\u044b\u0441\u0442\u0430\u0432\u0438\u043b \u0434\u043d\u0435\u0432\u043d\u043e\u0439 \u043b\u0438\u043c\u0438\u0442 \u0432 $50. \u0415\u0441\u043b\u0438 \u0443\u043f\u0438\u0440\u0430\u044e\u0441\u044c \u0432 \u043d\u0435\u0433\u043e \u2014 \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u0451\u0442 \u0437\u0432\u0430\u0442\u044c API \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043e\u0442\u0432\u0435\u0442 \u00ab\u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043d\u0435\u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d\u00bb. \u042f \u043b\u0443\u0447\u0448\u0435 \u043f\u043e\u043b\u0443\u0447\u0443 \u043f\u0440\u043e\u0441\u0442\u043e\u0439, \u0447\u0435\u043c \u0441\u0447\u0451\u0442-\u0441\u044e\u0440\u043f\u0440\u0438\u0437.<\/p>\n<h3>\u0412\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0432\u044b\u0437\u043e\u0432\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432: \u0430\u0433\u0435\u043d\u0442 \u043d\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0437\u0432\u0430\u0442\u044c \u0442\u043e, \u0447\u0442\u043e \u0432\u044b \u043d\u0435 \u043e\u0434\u043e\u0431\u0440\u0438\u043b\u0438<\/h3>\n<p>\u041a\u043e\u0433\u0434\u0430 \u0443 \u0430\u0433\u0435\u043d\u0442\u0430 \u0435\u0441\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445, \u0444\u0430\u0439\u043b\u043e\u0432\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0438\u043b\u0438 \u0432\u043d\u0435\u0448\u043d\u0435\u043c\u0443 API, \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u2014 \u043d\u0435 \u043e\u043f\u0446\u0438\u044f. \u0411\u0435\u0437 \u043d\u0435\u0451 \u0432\u0437\u043b\u043e\u043c\u0430\u043d\u043d\u044b\u0439 \u0438\u043b\u0438 \u0437\u0430\u043f\u0443\u0442\u0430\u0432\u0448\u0438\u0439\u0441\u044f \u0430\u0433\u0435\u043d\u0442 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u0440\u0430\u0437\u0440\u0443\u0448\u0438\u0442\u0435\u043b\u044c\u043d\u0443\u044e \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044e.<\/p>\n<pre><code class=\"python\">class ToolCallGuardrail:    def __init__(self, allowed_tools: dict[str, dict]):        \"\"\"        allowed_tools format:        {            \"search_knowledge_base\": {                \"allowed_params\": [\"query\", \"top_k\"],                \"max_calls_per_session\": 20,            },            \"get_account_info\": {                \"allowed_params\": [\"account_id\"],                \"max_calls_per_session\": 5,            },        }        \"\"\"        self.allowed_tools = allowed_tools        self._call_counts: dict[str, int] = {}    def validate_tool_call(        self, tool_name: str, params: dict    ) -&gt; ValidationResult:        # Tool must be in allowlist        if tool_name not in self.allowed_tools:            return ValidationResult(                is_valid=False,                reason=f\"Tool '{tool_name}' is not in the allowlist\"            )        tool_config = self.allowed_tools[tool_name]        # Check parameters        for param in params:            if param not in tool_config[\"allowed_params\"]:                return ValidationResult(                    is_valid=False,                    reason=f\"Parameter '{param}' not allowed for {tool_name}\"                )        # Check call frequency        count = self._call_counts.get(tool_name, 0)        if count &gt;= tool_config[\"max_calls_per_session\"]:            return ValidationResult(                is_valid=False,                reason=f\"Tool '{tool_name}' call limit reached\"            )        self._call_counts[tool_name] = count + 1        return ValidationResult(is_valid=True)<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u042f \u0432\u044b\u0431\u0440\u0430\u043b default deny. \u0415\u0441\u043b\u0438 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430 \u043d\u0435\u0442 \u0432 allowlist \u2014 \u0430\u0433\u0435\u043d\u0442 \u043d\u0435 \u043c\u043e\u0436\u0435\u0442 \u0435\u0433\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c. \u0415\u0441\u043b\u0438 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430 \u043d\u0435\u0442 \u0432 \u0441\u043f\u0438\u0441\u043a\u0435 \u0440\u0430\u0437\u0440\u0435\u0448\u0451\u043d\u043d\u044b\u0445 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430 \u2014 \u0432\u044b\u0437\u043e\u0432 \u043e\u0442\u043a\u043b\u043e\u043d\u044f\u0435\u0442\u0441\u044f. \u042d\u0442\u043e \u043b\u043e\u0432\u0438\u0442 \u0438 \u043f\u043e\u043f\u044b\u0442\u043a\u0438 \u0434\u0436\u0435\u0439\u043b\u0431\u0440\u0435\u0439\u043a\u0430 (\u043a\u043e\u0433\u0434\u0430 \u043c\u043e\u0434\u0435\u043b\u044c \u043f\u044b\u0442\u0430\u0435\u0442\u0441\u044f \u0432\u044b\u0437\u0432\u0430\u0442\u044c <code>execute_sql<\/code> \u0438\u043b\u0438 <code>delete_record<\/code>), \u0438 \u0433\u0430\u043b\u043b\u044e\u0446\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0438\u043c\u0435\u043d\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 (\u0447\u0442\u043e \u0441\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0447\u0430\u0449\u0435, \u0447\u0435\u043c \u0432\u044b \u0434\u0443\u043c\u0430\u0435\u0442\u0435).<\/p>\n<p>\u041b\u0438\u043c\u0438\u0442\u044b \u0447\u0430\u0441\u0442\u043e\u0442\u044b \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0434\u0435\u0440\u0436\u0443 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043f\u043e \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0443, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0443 \u0440\u0430\u0437\u043d\u044b\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0440\u0430\u0437\u043d\u044b\u0439 \u043f\u0440\u043e\u0444\u0438\u043b\u044c \u0440\u0438\u0441\u043a\u0430. \u041f\u043e\u0438\u0441\u043a \u2014 \u0434\u0451\u0448\u0435\u0432\u043e \u0438 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e \u0432\u044b\u0437\u0432\u0430\u0442\u044c 20 \u0440\u0430\u0437. \u041e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u0430 \u0434\u043e\u043b\u0436\u043d\u043e \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442\u044c \u043c\u0430\u043a\u0441\u0438\u043c\u0443\u043c \u0440\u0430\u0437-\u0434\u0432\u0430 \u0437\u0430 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440.<\/p>\n<h3>\u0421\u043e\u0431\u0438\u0440\u0430\u0435\u043c \u0432\u043c\u0435\u0441\u0442\u0435: \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d-\u0441\u0442\u0435\u043a guardrails<\/h3>\n<p>\u0412\u043e\u0442 \u043a\u0430\u043a \u044d\u0442\u0438 \u0447\u0435\u0442\u044b\u0440\u0435 \u0447\u0430\u0441\u0442\u0438 \u0441\u043e\u0435\u0434\u0438\u043d\u044f\u044e\u0442\u0441\u044f \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u043c \u043f\u0430\u0439\u043f\u043b\u0430\u0439\u043d\u0435 \u0430\u0433\u0435\u043d\u0442\u0430:<\/p>\n<pre><code>User Input    |[Input Guardrail] --&gt; reject \/ sanitize    |[Cost Circuit Breaker] --&gt; check budget    |[LLM Reasoning]    |[Tool Call Guardrail] --&gt; validate tool + params    |[Tool Execution]    |[LLM Response Generation]    |[Output Guardrail] --&gt; validate \/ retry \/ fallback    |User Response<\/code><div class=\"code-explainer\"><a href=\"https:\/\/sourcecraft.dev\/\" class=\"tm-button code-explainer__link\" style=\"visibility: hidden;\"><img style=\"width:14px;height:14px;object-fit:cover;object-position:left;\"\/><\/a><\/div><\/pre>\n<p>\u041a\u0430\u0436\u0434\u044b\u0439 guardrail \u043b\u043e\u0433\u0438\u0440\u0443\u0435\u0442 \u0441\u0432\u043e\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f. \u041d\u0430 \u043a\u0430\u0436\u0434\u044b\u0439 \u043e\u0442\u043a\u0430\u0437 \u2014 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0437\u0430\u043f\u0438\u0441\u044c \u0441 \u043f\u0440\u0438\u0447\u0438\u043d\u043e\u0439, \u0432\u0445\u043e\u0434\u043e\u043c, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0435\u0433\u043e \u0432\u044b\u0437\u0432\u0430\u043b, \u0438 \u0442\u0430\u0439\u043c\u0441\u0442\u0430\u043c\u043f\u043e\u043c. \u0420\u0430\u0437 \u0432 \u043d\u0435\u0434\u0435\u043b\u044e \u044f \u0433\u043e\u043d\u044f\u044e \u0437\u0430\u043f\u0440\u043e\u0441 \u043f\u043e \u044d\u0442\u0438\u043c \u043b\u043e\u0433\u0430\u043c \u0432 \u043f\u043e\u0438\u0441\u043a\u0430\u0445 \u043f\u0430\u0442\u0442\u0435\u0440\u043d\u043e\u0432: \u0435\u0441\u043b\u0438 \u043e\u0434\u043d\u0430 \u0438 \u0442\u0430 \u0436\u0435 \u043f\u043e\u043f\u044b\u0442\u043a\u0430 \u0438\u043d\u044a\u0435\u043a\u0446\u0438\u0438 \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u0435\u0442\u0441\u044f 50 \u0440\u0430\u0437 \u2014 \u044d\u0442\u043e, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e, \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u0430\u044f \u0430\u0442\u0430\u043a\u0430. \u0415\u0441\u043b\u0438 output guardrail \u043e\u0442\u043a\u043b\u043e\u043d\u044f\u0435\u0442 15% \u043e\u0442\u0432\u0435\u0442\u043e\u0432 \u0437\u0430 \u043d\u0438\u0437\u043a\u0443\u044e \u0443\u0432\u0435\u0440\u0435\u043d\u043d\u043e\u0441\u0442\u044c \u2014 \u044d\u0442\u043e \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0430 retrieval, \u043a\u043e\u0442\u043e\u0440\u0443\u044e \u043d\u0430\u0434\u043e \u0447\u0438\u043d\u0438\u0442\u044c \u0432\u044b\u0448\u0435 \u043f\u043e \u043f\u0430\u0439\u043f\u043b\u0430\u0439\u043d\u0443.<\/p>\n<p>\u0421\u0443\u043c\u043c\u0430\u0440\u043d\u044b\u0439 overhead \u043f\u043e latency \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u0447\u0435\u0442\u044b\u0440\u0451\u0445 guardrails \u2014 \u043c\u0435\u043d\u0435\u0435 40 \u043c\u0441 (\u0431\u0435\u0437 \u0443\u0447\u0451\u0442\u0430 ML-\u043a\u043b\u0430\u0441\u0441\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440\u043e\u0432). \u0414\u043b\u044f \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f \u044d\u0442\u043e \u043d\u0435\u0432\u0438\u0434\u0438\u043c\u043e.<\/p>\n<h3>\u0427\u0442\u043e \u0431\u044b \u044f \u0441\u0434\u0435\u043b\u0430\u043b \u0438\u043d\u0430\u0447\u0435<\/h3>\n<p>\u0415\u0441\u043b\u0438 \u0431\u044b \u043d\u0430\u0447\u0438\u043d\u0430\u043b \u0437\u0430\u043d\u043e\u0432\u043e, \u044f \u0431\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u043b guardrails \u0434\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u043f\u0435\u0440\u0432\u043e\u0439 \u0441\u0442\u0440\u043e\u043a\u0438 \u043b\u043e\u0433\u0438\u043a\u0438 \u0430\u0433\u0435\u043d\u0442\u0430. \u041e\u043f\u0438\u0441\u0430\u043d\u043d\u044b\u0439 \u0437\u0434\u0435\u0441\u044c \u043a\u0430\u0440\u043a\u0430\u0441 \u2014 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e 200 \u0441\u0442\u0440\u043e\u043a Python. \u0414\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 \u0443 \u043c\u0435\u043d\u044f \u0443\u0448\u043b\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u043f\u043e\u0442\u043e\u043c\u0443, \u0447\u0442\u043e \u044f \u0432\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u043b \u0435\u0433\u043e \u0432 \u0443\u0436\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0443\u044e\u0449\u0443\u044e \u0441\u0438\u0441\u0442\u0435\u043c\u0443 \u0438 \u043f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0440\u0430\u0437\u0431\u0438\u0440\u0430\u043b \u0438\u043d\u0446\u0438\u0434\u0435\u043d\u0442 \u0441 PII.<\/p>\n<p>\u041c\u043e\u0439 \u043f\u0440\u043e\u0433\u043d\u043e\u0437: \u0432 \u0442\u0435\u0447\u0435\u043d\u0438\u0435 12 \u043c\u0435\u0441\u044f\u0446\u0435\u0432 \u043a\u0440\u0443\u043f\u043d\u044b\u0435 \u0430\u0433\u0435\u043d\u0442\u043d\u044b\u0435 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0438 \u043d\u0430\u0447\u043d\u0443\u0442 \u043f\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0442\u044c guardrails \u043a\u0430\u043a first-class \u0444\u0443\u043d\u043a\u0446\u0438\u044e. LangGraph \u0443\u0436\u0435 \u0434\u0432\u0438\u0436\u0435\u0442\u0441\u044f \u0432 \u044d\u0442\u0443 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0441\u043e \u0441\u0432\u043e\u0438\u043c \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u043e\u043c interrupt. \u0410 \u043f\u043e\u043a\u0430 \u2014 \u0432\u044b \u0441\u0430\u043c\u0438 \u043f\u043e \u0441\u0435\u0431\u0435.<\/p>\n<p>\u041d\u0430\u0447\u043d\u0438\u0442\u0435 \u0441 input guardrails \u0438 cost circuit breaker. \u0422\u043e\u043b\u044c\u043a\u043e \u044d\u0442\u0438 \u0434\u0432\u0430 \u043f\u0440\u0435\u0434\u043e\u0442\u0432\u0440\u0430\u0442\u0438\u043b\u0438 \u0431\u044b \u043e\u0431\u0430 \u043c\u043e\u0438\u0445 \u0438\u043d\u0446\u0438\u0434\u0435\u043d\u0442\u0430 (\u0443\u0442\u0435\u0447\u043a\u0443 PII \u0438 \u043d\u043e\u0447\u043d\u043e\u0439 \u0441\u0447\u0451\u0442 \u043d\u0430 $400). \u0414\u043e\u0431\u0430\u0432\u044c\u0442\u0435 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044e \u0432\u044b\u0445\u043e\u0434\u0430, \u043a\u043e\u0433\u0434\u0430 \u043f\u043e\u044f\u0432\u0438\u0442\u0441\u044f \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d-\u0442\u0440\u0430\u0444\u0438\u043a, \u0447\u0442\u043e\u0431\u044b \u043d\u0430\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u043f\u043e\u0440\u043e\u0433\u0438 \u0443\u0432\u0435\u0440\u0435\u043d\u043d\u043e\u0441\u0442\u0438. \u0414\u043e\u0431\u0430\u0432\u044c\u0442\u0435 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044e \u0432\u044b\u0437\u043e\u0432\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432, \u0435\u0441\u043b\u0438 \u0443 \u0430\u0433\u0435\u043d\u0442\u0430 \u0435\u0441\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u043d\u0430 \u0437\u0430\u043f\u0438\u0441\u044c \u0445\u043e\u0442\u044c \u043a \u0447\u0435\u043c\u0443-\u043d\u0438\u0431\u0443\u0434\u044c.<\/p>\n<p>Guardrails \u043d\u0435 \u0441\u0434\u0435\u043b\u0430\u044e\u0442 \u0432\u0430\u0448\u0435\u0433\u043e \u0430\u0433\u0435\u043d\u0442\u0430 \u0443\u043c\u043d\u0435\u0435. \u041d\u043e \u043e\u043d\u0438 \u043d\u0435 \u0434\u0430\u0434\u0443\u0442 \u0433\u043b\u0443\u043f\u044b\u043c \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043c \u043f\u0440\u0435\u0432\u0440\u0430\u0442\u0438\u0442\u044c\u0441\u044f \u0432 \u0438\u043d\u0446\u0438\u0434\u0435\u043d\u0442\u044b.<\/p>\n<\/div>\n<p>\u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/1047022\/\">https:\/\/habr.com\/ru\/articles\/1047022\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u041d\u0430 \u0442\u0440\u0435\u0442\u0438\u0439 \u0434\u0435\u043d\u044c \u043c\u043e\u0439 \u0430\u0433\u0435\u043d\u0442 \u0441\u043b\u0438\u043b email \u043e\u0434\u043d\u043e\u0433\u043e \u043a\u043b\u0438\u0435\u043d\u0442\u0430 \u0432 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u043a\u0443 \u0441 \u0434\u0440\u0443\u0433\u0438\u043c \u043a\u043b\u0438\u0435\u043d\u0442\u043e\u043c. \u042d\u0442\u043e \u0431\u044b\u043b\u0430 \u043d\u0435 \u0433\u0438\u043f\u043e\u0442\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0430\u044f \u0438\u0441\u0442\u043e\u0440\u0438\u044f \u0438\u0437 \u0434\u043e\u043a\u043b\u0430\u0434\u0430 \u043d\u0430 \u043a\u043e\u043d\u0444\u0435\u0440\u0435\u043d\u0446\u0438\u0438. \u042d\u0442\u043e \u0431\u044b\u043b \u043c\u043e\u0439 \u043a\u043e\u0434, \u0432 \u043f\u0440\u043e\u0434\u0435, \u0434\u0435\u043b\u0430\u044e\u0449\u0438\u0439 \u0442\u043e, \u0447\u0442\u043e \u044f \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043b.\u042f \u0441\u043e\u0431\u0440\u0430\u043b support-\u0430\u0433\u0435\u043d\u0442\u0430 \u043d\u0430 LangGraph \u0438 GPT-4o. \u041e\u043d \u0443\u043c\u0435\u043b \u0438\u0441\u043a\u0430\u0442\u044c \u043f\u043e \u0431\u0430\u0437\u0435 \u0437\u043d\u0430\u043d\u0438\u0439, \u043f\u043e\u0434\u0442\u044f\u0433\u0438\u0432\u0430\u0442\u044c \u0434\u0435\u0442\u0430\u043b\u0438 \u0430\u043a\u043a\u0430\u0443\u043d\u0442\u0430 \u0438 \u0433\u043e\u0442\u043e\u0432\u0438\u0442\u044c \u043e\u0442\u0432\u0435\u0442\u044b. \u0412 staging \u043e\u043d \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e. \u0412 \u043f\u0440\u043e\u0434\u0435 \u0435\u043c\u0443 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u043b\u043e\u0441\u044c \u0440\u043e\u0432\u043d\u043e 72 \u0447\u0430\u0441\u0430, \u0447\u0442\u043e\u0431\u044b \u0432\u044b\u0442\u0430\u0449\u0438\u0442\u044c PII \u043e\u0434\u043d\u043e\u0433\u043e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f \u0432 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440 \u0441 \u0434\u0440\u0443\u0433\u0438\u043c. \u041f\u0440\u0438\u0447\u0438\u043d\u0430 \u043e\u043a\u0430\u0437\u0430\u043b\u0430\u0441\u044c \u0434\u043e \u043d\u0435\u043b\u043e\u0432\u043a\u043e\u0433\u043e \u043f\u0440\u043e\u0441\u0442\u043e\u0439: \u043c\u043e\u0434\u0435\u043b\u044c \u0432\u043a\u043b\u044e\u0447\u0438\u043b\u0430 \u0441\u044b\u0440\u043e\u0439 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u0438\u0437 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u0440\u044f\u043c\u043e \u0432 \u043e\u0442\u0432\u0435\u0442, \u0438 \u043d\u0438\u0447\u0442\u043e \u0432 \u043c\u043e\u0451\u043c \u043f\u0430\u0439\u043f\u043b\u0430\u0439\u043d\u0435 \u044d\u0442\u043e \u043d\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u043b\u043e.\u041f\u043e\u0441\u0442\u0444\u0430\u043a\u0442\u0443\u043c \u0444\u0438\u043a\u0441 \u0431\u044b\u043b \u043e\u0447\u0435\u0432\u0438\u0434\u0435\u043d. \u0424\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u0438 \u0434\u043b\u044f AI-\u0430\u0433\u0435\u043d\u0442\u043e\u0432 \u0434\u0430\u044e\u0442 \u0432\u0430\u043c \u043e\u0440\u043a\u0435\u0441\u0442\u0440\u0430\u0446\u0438\u044e, \u0432\u044b\u0437\u043e\u0432 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0438 \u043f\u0430\u043c\u044f\u0442\u044c. \u041e\u043d\u0438 \u043d\u0435 \u0434\u0430\u044e\u0442 \u0432\u0430\u043c \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u044c. \u042d\u0442\u043e \u0443\u0436\u0435 \u043d\u0430 \u0432\u0430\u0441.\u041f\u043e\u0447\u0435\u043c\u0443 \u0432\u0430\u0448 \u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a \u043d\u0435 \u0432\u043a\u043b\u044e\u0447\u0430\u0435\u0442 guardrailsLangChain, CrewAI, LangGraph, Agents SDK \u043e\u0442 OpenAI. \u0412\u044b\u0431\u0435\u0440\u0438\u0442\u0435 \u043b\u044e\u0431\u043e\u0439. \u041d\u0438 \u043e\u0434\u0438\u043d \u0438\u0437 \u043d\u0438\u0445 \u043d\u0435 \u0438\u0434\u0451\u0442 \u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438 \u0441 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0435\u0439 \u0432\u0445\u043e\u0434\u0430, \u0444\u0438\u043b\u044c\u0442\u0440\u0430\u0446\u0438\u0435\u0439 \u0432\u044b\u0445\u043e\u0434\u0430 \u0438\u043b\u0438 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0435\u043c \u0440\u0430\u0441\u0445\u043e\u0434\u043e\u0432. \u041e\u043d\u0438 \u0438\u0441\u0445\u043e\u0434\u044f\u0442 \u0438\u0437 \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0432\u044b \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u0435 \u044d\u0442\u043e \u0441\u0430\u043c\u0438.\u0411\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u043a\u043e\u043c\u0430\u043d\u0434 \u0442\u0430\u043a \u0438 \u043d\u0435 \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u044e\u0442.\u041f\u043e\u0447\u0435\u043c\u0443 \u044d\u0442\u043e \u0432\u0430\u0436\u043d\u043e \u2014 \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0435\u0442 \u043f\u0440\u043e\u0441\u0442\u0430\u044f \u0430\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u043a\u0430. \u041f\u0440\u0438 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u0438 90% \u043d\u0430 \u0448\u0430\u0433, \u0430\u0433\u0435\u043d\u0442\u043d\u044b\u0439 workflow \u0438\u0437 5 \u0448\u0430\u0433\u043e\u0432 \u0443\u0441\u043f\u0435\u0448\u0435\u043d \u0432 59% \u0441\u043b\u0443\u0447\u0430\u0435\u0432. Workflow \u0438\u0437 10 \u0448\u0430\u0433\u043e\u0432 \u043f\u0430\u0434\u0430\u0435\u0442 \u0434\u043e 35%. \u041d\u0430 20 \u0448\u0430\u0433\u0430\u0445 \u0432\u044b \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 12%. \u041a\u0430\u0436\u0434\u044b\u0439 \u043d\u0435\u0437\u0430\u0449\u0438\u0449\u0451\u043d\u043d\u044b\u0439 \u0448\u0430\u0433 \u2014 \u044d\u0442\u043e \u0443\u043c\u043d\u043e\u0436\u0435\u043d\u0438\u0435 \u0432\u0430\u0448\u0435\u0439 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u0438 \u043e\u0442\u043a\u0430\u0437\u0430.Guardrails \u043d\u0435 \u0447\u0438\u043d\u044f\u0442 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c. \u041e\u043d\u0438 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044e\u0442 \u0440\u0430\u0434\u0438\u0443\u0441 \u043f\u043e\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u043a\u043e\u0433\u0434\u0430 \u0442\u043e\u0447\u043d\u043e\u0441\u0442\u044c \u043e\u0442\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442. \u0420\u0430\u0437\u043d\u0438\u0446\u0430 \u043c\u0435\u0436\u0434\u0443 \u00ab\u0430\u0433\u0435\u043d\u0442 \u0434\u0430\u043b \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u043e\u0442\u0432\u0435\u0442\u00bb \u0438 \u00ab\u0430\u0433\u0435\u043d\u0442 \u0434\u0430\u043b \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u043e\u0442\u0432\u0435\u0442, \u0432 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u043f\u0430\u043b \u0447\u0435\u0439-\u0442\u043e \u043d\u043e\u043c\u0435\u0440 \u0441\u043e\u0446\u0441\u0442\u0440\u0430\u0445\u043e\u0432\u0430\u043d\u0438\u044f\u00bb \u2014 \u044d\u0442\u043e \u043e\u0434\u0438\u043d output-\u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440.\u0421\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 \u0434\u0432\u0435 \u043d\u0435\u0434\u0435\u043b\u0438 \u044f \u0441\u0442\u0440\u043e\u0438\u043b \u0441\u0442\u0435\u043a guardrails. \u041a\u043e\u0434 \u043d\u0438\u0436\u0435 \u2014 \u0442\u043e, \u043a \u0447\u0435\u043c\u0443 \u044f \u0432 \u0438\u0442\u043e\u0433\u0435 \u043f\u0440\u0438\u0448\u0451\u043b.\u0427\u0435\u0442\u044b\u0440\u0435 guardrail, \u043d\u0443\u0436\u043d\u044b\u0435 \u043a\u0430\u0436\u0434\u043e\u043c\u0443 \u0430\u0433\u0435\u043d\u0442\u0443\u041a\u0430\u0436\u0434\u043e\u043c\u0443 \u0430\u0433\u0435\u043d\u0442\u0443 \u043d\u0443\u0436\u043d\u0430 \u0437\u0430\u0449\u0438\u0442\u0430 \u0432 \u0447\u0435\u0442\u044b\u0440\u0451\u0445 \u0442\u043e\u0447\u043a\u0430\u0445:Input guardrails \u043b\u043e\u0432\u044f\u0442 prompt injection \u0438 \u0432\u044b\u0447\u0438\u0449\u0430\u044e\u0442 \u0447\u0443\u0432\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u0434\u0430\u043d\u043d\u044b\u0435 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0438\u0445 \u0443\u0432\u0438\u0434\u0438\u0442 LLM.Output guardrails \u0432\u0430\u043b\u0438\u0434\u0438\u0440\u0443\u044e\u0442 \u043e\u0442\u0432\u0435\u0442\u044b \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u0438\u0445 \u0443\u0432\u0438\u0434\u044f\u0442 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u0438, \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u044f \u0433\u0430\u043b\u043b\u044e\u0446\u0438\u043d\u0430\u0446\u0438\u0438 \u0438 \u0443\u0442\u0451\u043a\u0448\u0438\u0439 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442.Cost circuit breakers \u043d\u0435 \u0434\u0430\u044e\u0442 \u0441\u0447\u0451\u0442\u0443 \u0437\u0430 API \u0443\u043b\u0435\u0442\u0435\u0442\u044c \u0432 \u043a\u043e\u0441\u043c\u043e\u0441 \u0438\u0437-\u0437\u0430 \u0437\u0430\u0446\u0438\u043a\u043b\u0438\u0432\u0430\u043d\u0438\u044f \u0438\u043b\u0438 \u043d\u0435\u043e\u0436\u0438\u0434\u0430\u043d\u043d\u043e \u0434\u043b\u0438\u043d\u043d\u044b\u0445 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440\u043e\u0432.Tool call validators \u043f\u043e\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0430\u044e\u0442, \u0447\u0442\u043e \u0430\u0433\u0435\u043d\u0442 \u0432\u044b\u0437\u044b\u0432\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437\u0440\u0435\u0448\u0451\u043d\u043d\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b \u0441 \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c\u0438, \u043f\u0440\u043e\u0445\u043e\u0434\u044f\u0449\u0438\u043c\u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u0441\u0445\u0435\u043c\u044b.\u0412\u0441\u0435 \u0447\u0435\u0442\u044b\u0440\u0435 \u0443\u043c\u0435\u0449\u0430\u044e\u0442\u0441\u044f \u043c\u0435\u043d\u0435\u0435 \u0447\u0435\u043c \u0432 200 \u0441\u0442\u0440\u043e\u043a Python. \u041d\u0430\u043a\u043b\u0430\u0434\u043d\u044b\u0435 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043f\u043e latency \u2014 10\u201350 \u043c\u0441 \u043d\u0430 \u0441\u043b\u043e\u0439. \u0410\u043b\u044c\u0442\u0435\u0440\u043d\u0430\u0442\u0438\u0432\u0430 \u2014 \u0443\u0437\u043d\u0430\u0432\u0430\u0442\u044c \u043e \u0441\u0431\u043e\u044f\u0445 \u043e\u0442 \u0441\u0432\u043e\u0438\u0445 \u043a\u043b\u0438\u0435\u043d\u0442\u043e\u0432.Input guardrails: \u043b\u043e\u0432\u0438\u043c \u043f\u043b\u043e\u0445\u0438\u0435 \u043f\u0440\u043e\u043c\u043f\u0442\u044b \u0434\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044f\u0412\u0430\u0448 input-\u0432\u0430\u043b\u0438\u0434\u0430\u0442\u043e\u0440 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a LLM \u0432\u043e\u043e\u0431\u0449\u0435 \u0443\u0432\u0438\u0434\u0438\u0442 \u043f\u0440\u043e\u043c\u043f\u0442. \u041e\u043d \u0434\u0435\u043b\u0430\u0435\u0442 \u0434\u0432\u0435 \u0432\u0435\u0449\u0438: \u0431\u043b\u043e\u043a\u0438\u0440\u0443\u0435\u0442 \u043f\u043e\u043f\u044b\u0442\u043a\u0438 \u0438\u043d\u044a\u0435\u043a\u0446\u0438\u0438 \u0438 \u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0435\u0442 PII.import refrom dataclasses import dataclass@dataclassclass ValidationResult:    is_valid: bool    reason: str = &#171;&#187;    sanitized_input: str = &#171;&#187;class InputGuardrail:    INJECTION_PATTERNS = [        r&#187;ignore\\s+(all\\s+)?previous\\s+instructions&#187;,        r&#187;you\\s+are\\s+now\\s+a&#187;,        r&#187;disregard\\s+(your|all)\\s+(rules|instructions)&#187;,        r&#187;system\\s*prompt\\s*:&#187;,        r&#187;&lt;&lt;\\s*SYS\\s*&gt;&gt;&#187;,    ]    PII_PATTERNS = {        &#171;ssn&#187;: r&#187;\\b\\d{3}-\\d{2}-\\d{4}\\b&#187;,        &#171;credit_card&#187;: r&#187;\\b\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}\\b&#187;,        &#171;email&#187;: r&#187;\\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Z|a-z]{2,}\\b&#187;,    }    def validate(self, user_input: str) -&gt; ValidationResult:        # Check for prompt injection        for pattern in self.INJECTION_PATTERNS:            if re.search(pattern, user_input, re.IGNORECASE):                return ValidationResult(                    is_valid=False,                    reason=f&#187;Prompt injection detected: {pattern}&#187;                )        # Scrub PII from input        sanitized = user_input        for pii_type, pattern in self.PII_PATTERNS.items():            sanitized = re.sub(pattern, f&#187;[REDACTED_{pii_type.upper()}]&#187;, sanitized)        return ValidationResult(            is_valid=True,            sanitized_input=sanitized        )\u042d\u0442\u043e \u043d\u0435 \u043f\u0443\u043b\u0435\u043d\u0435\u043f\u0440\u043e\u0431\u0438\u0432\u0430\u0435\u043c\u043e. \u041d\u0430\u0441\u0442\u043e\u0439\u0447\u0438\u0432\u044b\u0439 \u0430\u0442\u0430\u043a\u0443\u044e\u0449\u0438\u0439 \u043e\u0431\u043e\u0439\u0434\u0451\u0442 \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u043d\u043e\u0435 \u043d\u0430 regex \u043e\u0431\u043d\u0430\u0440\u0443\u0436\u0435\u043d\u0438\u0435 \u0438\u043d\u044a\u0435\u043a\u0446\u0438\u0439. \u041d\u043e \u043e\u043d\u043e \u043b\u043e\u0432\u0438\u0442 \u0447\u0430\u0441\u0442\u044b\u0435 \u043f\u043e\u043f\u044b\u0442\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u043e \u043c\u043e\u0435\u043c\u0443 \u043e\u043f\u044b\u0442\u0443 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u044e\u0442 \u043e\u043a\u043e\u043b\u043e 80% \u0440\u0435\u0430\u043b\u044c\u043d\u044b\u0445 \u0430\u0442\u0430\u043a. \u0414\u043b\u044f \u043f\u0440\u043e\u0434\u0430\u043a\u0448\u0435\u043d\u0430 \u0441 \u0447\u0443\u0432\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u043c\u0438 \u0434\u043e\u0431\u0430\u0432\u044c\u0442\u0435 \u043f\u043e\u0432\u0435\u0440\u0445 regex-\u043f\u0440\u043e\u0445\u043e\u0434\u0430 \u043c\u043e\u0434\u0435\u043b\u044c-\u043a\u043b\u0430\u0441\u0441\u0438\u0444\u0438\u043a\u0430\u0442\u043e\u0440 (\u0432\u0440\u043e\u0434\u0435 Lakera Guard \u0438\u043b\u0438 \u0434\u043e\u043e\u0431\u0443\u0447\u0435\u043d\u043d\u043e\u0433\u043e DistilBERT).\u0412\u044b\u0447\u0438\u0441\u0442\u043a\u0430 PII \u2014 \u0438\u043c\u0435\u043d\u043d\u043e \u0442\u0430 \u0447\u0430\u0441\u0442\u044c, \u0447\u0442\u043e \u0441\u043f\u0430\u0441\u043b\u0430 \u0431\u044b \u043c\u0435\u043d\u044f \u043d\u0430 \u0442\u0440\u0435\u0442\u0438\u0439 \u0434\u0435\u043d\u044c. \u0415\u0441\u043b\u0438 \u0431\u044b \u043c\u043e\u0439 input guardrail \u0432\u044b\u0440\u0435\u0437\u0430\u043b email \u0438\u0437 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0430 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u043e \u0442\u043e\u0433\u043e, \u043a\u0430\u043a \u043e\u043d \u043f\u043e\u043f\u0430\u043b \u0432 \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440, \u0443\u0442\u0435\u0447\u043a\u0438 \u0431\u044b \u043d\u0435 \u0441\u043b\u0443\u0447\u0438\u043b\u043e\u0441\u044c.Output guardrails: \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u0433\u0430\u043b\u043b\u044e\u0446\u0438\u043d\u0430\u0446\u0438\u0438 \u0434\u043e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f\u0412\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0432\u044b\u0445\u043e\u0434\u0430 \u2014 \u0442\u043e \u043c\u0435\u0441\u0442\u043e, \u0433\u0434\u0435 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u043a\u043e\u043c\u0430\u043d\u0434 \u043f\u0440\u043e\u043f\u0443\u0441\u043a\u0430\u044e\u0442 guardrails \u0432\u043e\u0432\u0441\u0435. \u041c\u043e\u0434\u0435\u043b\u044c \u0434\u0430\u043b\u0430 \u043e\u0442\u0432\u0435\u0442, \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0440\u0430\u0437\u0443\u043c\u043d\u043e, \u043e\u0442\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u043c. \u041d\u043e \u00ab\u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0440\u0430\u0437\u0443\u043c\u043d\u043e\u00bb \u2014 \u044d\u0442\u043e \u043d\u0435 \u0442\u043e\u0442 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0430\u0433\u0430\u0442\u044c\u0441\u044f.from pydantic import BaseModel, field_validatorfrom typing import Optionalimport jsonclass AgentResponse(BaseModel):    answer: str    confidence: float    sources: list[str]    @field_validator(&#171;confidence&#187;)    @classmethod    def check_confidence(cls, v):        if not 0.0 &lt;= v &lt;= 1.0:            raise ValueError(&#171;Confidence must be between 0 and 1&#187;)        return v    @field_validator(&#171;answer&#187;)    @classmethod    def check_no_pii_leak(cls, v):        pii_patterns = [            r&#187;\\b\\d{3}-\\d{2}-\\d{4}\\b&#187;,  # SSN            r&#187;\\b\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}[\\s-]?\\d{4}\\b&#187;,  # Credit card        ]        for pattern in pii_patterns:            if re.search(pattern, v):                raise ValueError(&#171;Response contains potential PII&#187;)        return vclass OutputGuardrail:    def __init__(self, confidence_threshold: float = 0.7):        self.confidence_threshold = confidence_threshold    def validate(self, raw_response: dict) -&gt; ValidationResult:        try:            response = AgentResponse(**raw_response)        except Exception as e:            return ValidationResult(                is_valid=False,                reason=f&#187;Response failed schema validation: {e}&#187;            )        if response.confidence &lt; self.confidence_threshold:            return ValidationResult(                is_valid=False,                reason=f&#187;Confidence {response.confidence} below threshold&#187;            )        if not response.sources:            return ValidationResult(                is_valid=False,                reason=&#187;No sources provided for claim&#187;            )        return ValidationResult(is_valid=True, sanitized_input=response.answer)Pydantic-\u043c\u043e\u0434\u0435\u043b\u044c \u0434\u0435\u043b\u0430\u0435\u0442 \u0434\u0432\u043e\u0439\u043d\u0443\u044e \u0440\u0430\u0431\u043e\u0442\u0443. \u041e\u043d\u0430 \u043d\u0430\u0432\u044f\u0437\u044b\u0432\u0430\u0435\u0442 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 (LLM \u043e\u0431\u044f\u0437\u0430\u043d\u0430 \u0432\u0435\u0440\u043d\u0443\u0442\u044c JSON \u0441 answer, confidence \u0438 sources) \u0438 \u043f\u0440\u043e\u0433\u043e\u043d\u044f\u0435\u0442 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u043d\u044b\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0438 (\u043d\u0438\u043a\u0430\u043a\u043e\u0433\u043e PII \u0432 \u0432\u044b\u0445\u043e\u0434\u0435). \u041a\u043e\u0433\u0434\u0430 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u043f\u0430\u0434\u0430\u0435\u0442, \u043c\u043e\u0439 \u0430\u0433\u0435\u043d\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u0435\u0442 \u0437\u0430\u043f\u0440\u043e\u0441 \u0441 \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u043c \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043e\u043c: \u00ab\u0412\u0430\u0448 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0439 \u043e\u0442\u0432\u0435\u0442 \u043e\u0442\u043a\u043b\u043e\u043d\u0451\u043d, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e [\u043f\u0440\u0438\u0447\u0438\u043d\u0430]. \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0439\u0442\u0435 \u0441\u043d\u043e\u0432\u0430\u00bb.\u0414\u0432\u0430 \u043f\u043e\u0432\u0442\u043e\u0440\u0430 \u0441\u043e \u0432\u0441\u0451 \u0431\u043e\u043b\u0435\u0435 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u044b\u043c\u0438 \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u044f\u043c\u0438 \u0447\u0438\u043d\u044f\u0442 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u043f\u0430\u0434\u0435\u043d\u0438\u0439 \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u0438. \u0415\u0441\u043b\u0438 \u043f\u0430\u0434\u0430\u0435\u0442 \u0442\u0440\u0438 \u0440\u0430\u0437\u0430 \u2014 \u044f \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e \u0437\u0430\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u043d\u044b\u0439 fallback-\u043e\u0442\u0432\u0435\u0442 \u0438 \u043b\u043e\u0433\u0438\u0440\u0443\u044e \u0438\u043d\u0446\u0438\u0434\u0435\u043d\u0442.Kill switch: circuit breaker \u043f\u043e \u0440\u0430\u0441\u0445\u043e\u0434\u0430\u043c \u0438 \u0442\u043e\u043a\u0435\u043d\u0430\u043c\u042d\u0442\u043e \u0442\u043e\u0442 guardrail, \u043f\u0440\u043e \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0438\u043a\u0442\u043e \u043d\u0435 \u043f\u0438\u0448\u0435\u0442, \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u043e\u043d \u0441\u0442\u043e\u0438\u043b \u043c\u043d\u0435 $400.\u0423 \u043c\u0435\u043d\u044f \u0431\u044b\u043b \u0431\u0430\u0433, \u0438\u0437-\u0437\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0430\u0433\u0435\u043d\u0442 \u0432\u0445\u043e\u0434\u0438\u043b \u0432 \u0446\u0438\u043a\u043b \u043f\u043e\u0432\u0442\u043e\u0440\u043e\u0432. \u0412\u044b\u0437\u043e\u0432 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430 \u043f\u0430\u0434\u0430\u043b, \u0430\u0433\u0435\u043d\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u043b, \u043f\u043e\u0432\u0442\u043e\u0440 \u043f\u0430\u0434\u0430\u043b \u0447\u0443\u0442\u044c \u0438\u043d\u0430\u0447\u0435, \u0438 \u0430\u0433\u0435\u043d\u0442 \u043f\u043e\u0432\u0442\u043e\u0440\u044f\u043b \u0441\u043d\u043e\u0432\u0430. \u041a\u0430\u0436\u0434\u044b\u0439 \u043f\u043e\u0432\u0442\u043e\u0440 \u0441\u0436\u0438\u0433\u0430\u043b \u0442\u043e\u043a\u0435\u043d\u044b \u043d\u0430 \u0448\u0430\u0433\u0435 \u0440\u0430\u0441\u0441\u0443\u0436\u0434\u0435\u043d\u0438\u044f \u043f\u043b\u044e\u0441 \u043d\u0430 \u0432\u044b\u0437\u043e\u0432\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u0430. \u041e\u043d \u043a\u0440\u0443\u0442\u0438\u043b\u0441\u044f \u0448\u0435\u0441\u0442\u044c \u0447\u0430\u0441\u043e\u0432 \u043d\u043e\u0447\u044c\u044e, \u043f\u0440\u0435\u0436\u0434\u0435 \u0447\u0435\u043c \u044f \u0437\u0430\u043c\u0435\u0442\u0438\u043b.import timefrom threading import Lockclass CostCircuitBreaker:    def __init__(        self,        max_tokens_per_request: int = 50_000,        max_tokens_per_session: int = 200_000,        max_api_calls_per_minute: int = 30,        max_daily_spend_usd: float = 50.0,    ):        self.max_tokens_per_request = max_tokens_per_request        self.max_tokens_per_session = max_tokens_per_session        self.max_api_calls_per_minute = max_api_calls_per_minute        self.max_daily_spend = max_daily_spend_usd        self._session_tokens = 0        self._minute_calls = []        self._daily_spend = 0.0        self._lock = Lock()    def check_budget(self, estimated_tokens: int) -&gt; ValidationResult:        with self._lock:            # Per-request limit            if estimated_tokens &gt; self.max_tokens_per_request:                return ValidationResult(                    is_valid=False,                    reason=f&#187;Request needs ~{estimated_tokens} tokens, &#187;                           f&#187;limit is {self.max_tokens_per_request}&#187;                )            # Session limit            if self._session_tokens + estimated_tokens &gt; self.max_tokens_per_session:                return ValidationResult(                    is_valid=False,                    reason=&#187;Session token budget exhausted&#187;                )            # Rate limit            now = time.time()            self._minute_calls = [t for t in self._minute_calls if now &#8212; t &lt; 60]            if len(self._minute_calls) &gt;= self.max_api_calls_per_minute:                return ValidationResult(                    is_valid=False,                    reason=&#187;API call rate limit exceeded&#187;                )            # Daily spend            estimated_cost = (estimated_tokens \/ 1_000_000) * 3.00  # ~GPT-4o rate            if self._daily_spend + estimated_cost &gt; self.max_daily_spend:                return ValidationResult(                    is_valid=False,                    reason=&#187;Daily spend limit reached&#187;                )            # All checks passed, record usage            self._session_tokens += estimated_tokens            self._minute_calls.append(now)            self._daily_spend += estimated_cost            return ValidationResult(is_valid=True)Per-request \u043b\u0438\u043c\u0438\u0442 \u043b\u043e\u0432\u0438\u0442 \u043e\u0447\u0435\u0432\u0438\u0434\u043d\u044b\u0439 \u0441\u043b\u0443\u0447\u0430\u0439: \u043e\u0434\u043d\u043e \u0433\u0438\u0433\u0430\u043d\u0442\u0441\u043a\u043e\u0435 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u043d\u043e\u0435 \u043e\u043a\u043d\u043e, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043f\u0440\u043e\u0436\u0436\u0451\u0442 \u0432\u0430\u0448 \u0431\u044e\u0434\u0436\u0435\u0442. Session-\u043b\u0438\u043c\u0438\u0442 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u0435\u0442 \u0441\u0443\u043c\u043c\u0430\u0440\u043d\u044b\u0435 \u0442\u0440\u0430\u0442\u044b \u043d\u0430 \u043e\u0434\u0438\u043d \u0440\u0430\u0437\u0433\u043e\u0432\u043e\u0440. Rate-\u043b\u0438\u043c\u0438\u0442 \u043f\u0440\u0435\u0434\u043e\u0442\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0448\u0442\u043e\u0440\u043c \u043f\u043e\u0432\u0442\u043e\u0440\u043e\u0432. \u0410 \u0434\u043d\u0435\u0432\u043d\u043e\u0439 \u043b\u0438\u043c\u0438\u0442 \u0442\u0440\u0430\u0442 \u2014 \u0432\u0430\u0448 \u0430\u0431\u0441\u043e\u043b\u044e\u0442\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043b\u043e\u043a.\u042f \u0432\u044b\u0441\u0442\u0430\u0432\u0438\u043b \u0434\u043d\u0435\u0432\u043d\u043e\u0439 \u043b\u0438\u043c\u0438\u0442 \u0432 $50. \u0415\u0441\u043b\u0438 \u0443\u043f\u0438\u0440\u0430\u044e\u0441\u044c \u0432 \u043d\u0435\u0433\u043e \u2014 \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u043f\u0435\u0440\u0435\u0441\u0442\u0430\u0451\u0442 \u0437\u0432\u0430\u0442\u044c API \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u043e\u0442\u0432\u0435\u0442 \u00ab\u0441\u0435\u0440\u0432\u0438\u0441 \u0432\u0440\u0435\u043c\u0435\u043d\u043d\u043e \u043d\u0435\u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d\u00bb. \u042f \u043b\u0443\u0447\u0448\u0435 \u043f\u043e\u043b\u0443\u0447\u0443 \u043f\u0440\u043e\u0441\u0442\u043e\u0439, \u0447\u0435\u043c \u0441\u0447\u0451\u0442-\u0441\u044e\u0440\u043f\u0440\u0438\u0437.\u0412\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0432\u044b\u0437\u043e\u0432\u0430 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432: \u0430\u0433\u0435\u043d\u0442 \u043d\u0435 \u0434\u043e\u043b\u0436\u0435\u043d \u0437\u0432\u0430\u0442\u044c \u0442\u043e, \u0447\u0442\u043e \u0432\u044b \u043d\u0435 \u043e\u0434\u043e\u0431\u0440\u0438\u043b\u0438\u041a\u043e\u0433\u0434\u0430 \u0443 \u0430\u0433\u0435\u043d\u0442\u0430 \u0435\u0441\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u0431\u0430\u0437\u0435 \u0434\u0430\u043d\u043d\u044b\u0445, \u0444\u0430\u0439\u043b\u043e\u0432\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u0435 \u0438\u043b\u0438 \u0432\u043d\u0435\u0448\u043d\u0435\u043c\u0443 API, \u0432\u0430\u043b\u0438\u0434\u0430\u0446\u0438\u044f \u0432\u044b\u0437\u043e\u0432\u043e\u0432 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u2014&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-483479","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/483479","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=483479"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/483479\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=483479"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=483479"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=483479"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}