pic-standard

Проекты, которые следуют приведенным ниже лучшим практикам, могут добровольно и самостоятельно оценить себя и продемонстрировать, что они получили значок Open Source Security Foundation (OpenSSF).

Не существует набора практик, гарантирующего, что у программного обеспечения никогда не будет недостатков или уязвимостей; даже формальные методы могут не помочь, если спецификации или допущения ошибочны. Также не существует какой-либо практики, которая могла бы гарантировать, что проект будет поддерживать здоровое и хорошо функционирующее сообщество разработчиков. Однако следующие хорошие правила могут помочь улучшить результаты проектов. Например, некоторые правила описывают ревью несколькими участниками перед выпуском, что может помочь найти технические уязвимости, которые было бы сложно найти другим способом, и помочь построить доверие и желание дальнейшего взаимодействия между разработчиками из разных компаний. Чтобы получить значок, нужно выполнить все критерии с ключевыми словами "НЕОБХОДИМО"/"ОБЯЗАН"/"НЕДОПУСТИМО", все критерии со словом "СЛЕДУЕТ" либо должны удовлетворяться, либо должно быть приведено обоснование их невыполнения, и все критерии со словом "ЖЕЛАТЕЛЬНО" могут быть удовлетворены ИЛИ неудовлетворены (желательно, чтобы они были хотя бы рассмотрены). Если вы хотите ввести общий комментарий вместо объяснения, почему текущая ситуация приемлема, начните текст с '//' и пробела. Приветствуется обратная связь через сайт на GitHub в виде issues или pull requests. Существует также список рассылки для общих вопросов.

Мы с удовольствием предоставляем информацию на нескольких языках, однако, если есть какой-либо конфликт или несоответствие между переводами, английская версия является авторитетной.
Если это ваш проект, пожалуйста, покажите свой значок на странице проекта! Статус значка выглядит следующим образом: Уровень значка для проекта 12790 - silver Вот как вставить его:
Вы можете показать свой статус значка, вставив его в файл с разметкой Markdown:
[![OpenSSF Best Practices](https://www.bestpractices.dev/projects/12790/badge)](https://www.bestpractices.dev/projects/12790)
- или HTML:
<a href="https://www.bestpractices.dev/projects/12790"><img src="https://www.bestpractices.dev/projects/12790/badge"></a>


Это критерии уровня Silver. Вы также можете просмотреть критерии уровня Passing или Gold.

Baseline Series: Базовый уровень 1 Базовый Уровень 2 Базовый Уровень 3

        

 Основы 17/17

  • Общая

    Обратите внимание, что другие проекты могут использовать то же имя.

    Open standard for Provenance & Intent Contracts (PIC) in AI agents. Verify intent, provenance, and evidence before high-impact tool calls.

    Используйте формат выражения лицензии SPDX; примеры включают «Apache-2.0», «BSD-2-Clause», «BSD-3-Clause», «GPL-2.0+», «LGPL-3.0+», «MIT» и «(BSD-2-Clause OR Ruby)».
    Если используется более одного языка, перечислите их через запятую (пробелы необязательны), и отсортируйте их от наиболее до наименее используемого. Если список длинный, пожалуйста, перечислите по крайней мере три наиболее распространенных. Если языка нет (например, это проект только для документации или только для тестирования), используйте один символ «-» (минус). Для каждого языка используйте общепринятую капитализацию названия, например «JavaScript».
    Common Platform Enumeration (CPE) - это структурированная схема именования для информационных систем, программного обеспечения и пакетов. Она используется в ряде систем и баз данных для отчетов об уязвимостях.
  • Предварительные требования


    Проект ОБЯЗАН получить значок уровня Passing. [achieve_passing]

  • Основная информация на веб-сайте проекта


    В информацию о том, как внести вклад, НЕОБХОДИМО включить требования к приемлемым взносам (например, ссылку на любой требуемый стандарт кодирования). (Требуется URL) [contribution_requirements]
  • Надзор за проектом


    Проекту СЛЕДУЕТ иметь юридический механизм, через который все авторы содержательных взносов в ПО проекта подтверждают, что они имеют законное право на внесение этих взносов. Самый распространенный и легко реализуемый подход для этого заключается в использовании Developer Certificate of Origin (DCO), при котором пользователи добавляют строку "signed-off-by" в свои коммиты, а проект ссылается на веб-сайт DCO. Но этот механизм МОЖЕТ быть реализован и в качестве Лицензионного соглашения с участниками (Contributor License Agreement, CLA) или другого правового механизма. (Требуется URL) [dco]
    DCO является рекомендуемым механизмом, потому что его легко реализовать и отслеживать в исходном коде, а git напрямую поддерживает функцию "signed-off" при помощи "commit -s". Для большей эффективности лучше всего, если проектная документация объясняет, что означает "signed-off" для этого проекта. CLA - это юридическое соглашение, которое определяет условия, на которых произведения умственного труда были лицензированы для организации или проекта. Соглашение о назначении участника (contributor assignment agreement, CAA) является юридическим соглашением, которое передает права на произведения умственного труда другой стороне; проекты не обязаны иметь CAA, поскольку CAA увеличивает риск того, что потенциальные участники не будут вносить свой вклад, особенно если получатель является коммерческой организацией. Лицензии CLA от Apache Software Foundation (лицензия отдельного участника и корпоративное соглашение CLA) являются примерами CLA для проектов, считающих, что риски от такого рода CLA для проекта меньше, чем их преимущества.

    https://github.com/madeinplutofabio/pic-standard/blob/main/LICENSE

    This criterion is a SHOULD, and the project has not yet implemented a formal DCO or CLA mechanism. The decision is intentional at the project's current scale: PIC is a single-maintainer project with a small contributor base, and inbound contributions are governed by GitHub's Terms of Service §D.6 ("Inbound=Outbound" — by submitting a pull request to a public repository, the contributor licenses their contribution under the repository's license) combined with the project's Apache-2.0 license, which itself contains an explicit contribution clause (§5: "Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License"). This provides a baseline legal grant for contributions today. Adopting a Developer Certificate of Origin (DCO) is on the project roadmap as the contributor base grows; once DCO is enabled (via the DCO GitHub App and a CONTRIBUTING.md update), this criterion will be re-evaluated as Met.



    Проект ОБЯЗАН четко определить и задокументировать модель управления проектом (способ принятия решений, включая ключевые роли). (Требуется URL) [governance]
    Требуется устоявшийся задокументированный способ принятия решений и разрешения споров. В небольших проектах это может быть просто вплоть до «владелец и лидер проекта принимает все окончательные решения». Существуют различные модели управления, включая благосклонное диктаторство и формальную меритократию; более подробно см. Governance models. В проектах успешно используются как централизованные подходы (например, с одним ведущим), так и децентрализованные (например, с групповыми ведущими). Не нужно указывать в сведениях об управлении возможность форка проекта, поскольку это всегда возможно для проектов СПО.

    https://github.com/madeinplutofabio/pic-standard/blob/main/CONTRIBUTING.md#%EF%B8%8F-governance-model

    Governance is documented in CONTRIBUTING.md §Governance Model. The PIC Standard is consensus-driven; major changes to specifications and schemas must be initiated as a discussion in GitHub Discussions before a PR is opened. Spec evolution sequencing (DRAFT → cross-implementation conformance → normative) is documented in ROADMAP.md §"How spec normative freezes are sequenced.



    Проект ОБЯЗАН определить правила поведения и разместить эти правила в стандартном месте. (Требуется URL) [code_of_conduct]
    Проекты могут повысить цивилизованность их сообщества и установить ожидания относительно приемлемого поведения, приняв правила поведения. Это может помочь избежать проблем до их возникновения и сделать проект более привлекательным местом, поощряющим участие. Правила должны быть сосредоточены только на поведении в сообществе или на рабочем месте проекта. Примерами правил поведения являются правила конфликтов на проекте ядра Linux, Contributor Covenant Code of Conduct, Кодекс поведения Debian, Ubuntu Code of Conduct, Правила поведения проекта Fedora, GNOME Code Of Conduct, KDE Community Code of Conduct">, Python Community Code of Conduct, The Ruby Community Conduct Guideline и The Rust Code of Conduct.

    https://github.com/madeinplutofabio/pic-standard/blob/main/CODE_OF_CONDUCT.md

    Project has adopted the Contributor Covenant version 2.1, posted at the repository root as CODE_OF_CONDUCT.md, with enforcement contact at team@madeinpluto.com and four-tier Community Impact Guidelines (Correction → Warning → Temporary Ban → Permanent Ban).



    Проект ОБЯЗАН четко определять и публично документировать ключевые роли в проекте и их обязанности, включая любые задачи, которые должны выполнять эти роли. Должно быть ясно, кто имеет какую роль(и), хотя это может быть и не задокументировано соответствующим образом. (Требуется URL) [roles_responsibilities]
    Документация для управления , а также роли и обязанности могут быть в одном месте.

    Проект ОБЯЗАН быть в состоянии продолжать работу с минимальным прерыванием, если какой-либо человек окажется недееспособен или убит. В частности, проект ОБЯЗАН быть в состоянии создавать и закрывать вопросы в трекере, принимать предложенные изменения и выпускать версии программного обеспечения через неделю после подтверждения того, что данный человек недееспособен или убит. Это МОЖЕТ быть реализовано через обеспечение кого-то ещё необходимыми ключами, паролами и законными правами для продолжения проекта. Лица, которые запускают проект СПО, МОГУТ сделать это, оставив ключи в сейфе и завещание, передающее все необходимые юридические права (например, для имен DNS). (Требуется URL) [access_continuity]

    https://github.com/madeinplutofabio/pic-standard/blob/main/MAINTAINERS.md#continuity-plan

    Continuity plan documented in MAINTAINERS.md §Continuity Plan, covering operational continuity (Apache-2.0 fork rights, immutable PyPI/GitHub release history, Zenodo-archived spec, no DNS dependencies), account-access escrow (GitHub recovery codes, PyPI credentials, email credentials, signed authorization letter held in a sealed continuity envelope), legal continuity (Apache-2.0 grants successor rights without permission, no trademark blockers), a named designated successor (Rebecca Yallop) with documented activation procedure, and a 7-day operational-continuity demonstration target. The successor is a non-technical family member whose authorized role is to bridge access between loss of the Lead Maintainer and continuation by a technical successor of her choosing — the lockbox-and-will pattern explicitly contemplated by this criterion.



    Проекту СЛЕДУЕТ поддерживать «коэффициент автобуса» 2 или более. (Требуется URL) [bus_factor]
    «Коэффициент автобуса» (или «коэффициент грузовика») - это минимальное количество участников проекта, которые должны внезапно исчезнуть из проекта («попасть под автобус»), чтобы проект заглох из-за отсутствия квалифицированного или компетентного персонала. Инструмент truck-factor может оценить это для проектов на GitHub. Для получения дополнительной информации см. статью Cosentino et al. Assessing the Bus Factor of Git Repositories.
  • Документация


    Проект ОБЯЗАН иметь задокументированный долгосрочный план (roadmap), описывающий, что проект намеревается, а что не намеревается делать, по крайней мере на ближайший год. (Требуется URL) [documentation_roadmap]
    Проект может не достичь того, что описано в долгосрочном плане, и это нормально. Цель дорожной карты - помочь потенциальным пользователям и участникам понять намеченное направление проекта. Подробности не требуются.

    https://github.com/madeinplutofabio/pic-standard/blob/main/ROADMAP.md

    ROADMAP.md is a 36KB living plan covering the next 12+ months: v0.8.2 (conformance expansion + initial spec drafts), v0.9.0 (TypeScript verifier interop milestone, OpenAPI bridge spec, Docker hardening), v0.9.1–v0.9.2 (differential testing, fuzzing, ambiguity burn-down), and v1.0.0 (production-grade protocol freeze, Internet-Draft submission). It also explicitly lists what is NOT in scope: "Deferred beyond v1.0: broader TS hardening, trust bundle profile, discovery profile, optional CBOR profile, registry/governance machinery beyond the v1.0 minimum, additional transport bindings."



    Проект ОБЯЗАН включать документацию по архитектуре (также называемой высокоуровневым дизайном) ПО, создаваемого проектом. Выберите «неприменимо» (N/A), если проект не создает программное обеспечение. (Требуется URL) [documentation_architecture]
    Архитектура ПО объясняет фундаментальную структуру программы, то есть основные компоненты программы, отношения между ними и ключевые свойства этих компонентов и отношений.

    https://github.com/madeinplutofabio/pic-standard/blob/main/docs/RFC-0001-pic-standard.md#protocol-summary-pic10-action-proposal

    Architecture is documented in RFC-0001, including the action-boundary interception design, the Action Proposal envelope structure, the verification pipeline (schema → verifier → evidence), the impact taxonomy, the three-way ID binding mechanism, and the reference component list (verifier, CLI, LangGraph node, MCP guard, OpenClaw plugin, HTTP bridge). The README also includes a Mermaid flow diagram of the data flow.



    Проект ОБЯЗАН документировать то, что пользователь может и чего он не должен ожидать с точки зрения безопасности от ПО, создаваемого проектом (его «требования безопасности»). (Требуется URL) [documentation_security]
    Это требования безопасности, выполнение которых ожидается от ПО.

    https://github.com/madeinplutofabio/pic-standard/blob/main/docs/RFC-0001-pic-standard.md#security-properties

    Security requirements are documented in RFC-0001 §Security Properties (eight MUST/SHOULD properties: fail-closed execution, causal accountability, tool-binding integrity, local-first verification, evidence-as-output-of-verification, sandboxed evidence resolution, key lifecycle, deterministic verification) and §Non-Goals (eight things PIC explicitly does not provide: output guardrails, authentication, authorization, prompt filtering, runtime sandbox, logging/SIEM, tool input validation, protection against compromised trusted signers).



    Проект ОБЯЗАН предоставить руководство для быстрого начала работы для новых пользователей, чтобы помочь им быстро что-то сделать, используя ПО, создаваемое проект. (Требуется URL) [documentation_quick_start]
    Идея состоит в том, чтобы показать пользователям, как начать работу и и добиться, чтобы ПО что-то вообще сделало. Потенциальным пользователям это критически важно для начала работы.

    https://github.com/madeinplutofabio/pic-standard#quickstart

    README §Quickstart gives a one-minute install-and-verify path: pip install pic-standard, then pic-cli verify examples/financial_irreversible.json, with additional examples for evidence-aware verification (hash and signature) and optional extras for LangGraph, MCP, and crypto.



    Проект ОБЯЗАН прилагать усилия к тому, чтобы документация соответствовала текущей версии результатов проекта (включая ПО, создаваемое проектом). НЕОБХОДИМО исправлять любые известные дефекты документации, приводящие к ее непоследовательности. Если документация в целом актуальна, но ошибочно включает в себя некоторые более старые данные, которые больше не верны, просто рассматривайте это как дефект, отслеживайте и исправляйте, как обычно. [documentation_current]
    Документация МОЖЕТ включать информацию о различиях или изменениях между версиями программного обеспечения и/или ссылку на более старые версии документации. Смысл этого критерия заключается в том, что прилагаются усилия для обеспечения согласованности документации, а не в том, чтобы документация была идеальной.

    Documentation is kept in sync with each release; CHANGELOG.md tracks user-visible changes. RFC-0001 explicitly states the version range it covers and is updated across releases. Version-specific behavior (e.g., v0.7.5 strict_trust mode, v0.8.0 canonicalization) is annotated inline in the README. No known documentation defects.



    НЕОБХОДИМО размещать ссылку на любые свои достижения, включая этот значок передовой практики, на главной странице проекта и/или веб-сайте в течение 48 часов после открытого признания достижения. (Требуется URL) [documentation_achievements]
    Достижением считается любой набор внешних критериев, над выполнением которых проект специально работал, включая некоторые значки. Эта информация не обязательно должна находиться на главной странице веб-сайта проекта. Проект с использованием GitHub может помещать достижения на главную страницу хранилища кода, добавляя их в файл README.
  • Общедоступность и интернационализация


    Проекту (как на сайтах проекта, так и в результатах работы проекта) СЛЕДУЕТ придерживаться передовой практики общедоступности, чтобы люди с ограниченными возможностями могли участвовать в проекте и использовать результаты проекта, где это имеет смысл. [accessibility_best_practices]
    Для веб-приложений см. Руководство по обеспечению доступности веб-контента (WCAG) 2.0 и его поддерживающий документ Understanding WCAG 2.0; см. также W3C accessibility information. Для приложений с графическим интерфейсом рассмотрите использование соответствующих вашему окружению рекомендаций по обеспечению доступности (таких как GNOME, KDE, XFCE, Android, iOS, Mac и Windows (на русском)). Некоторые приложения с текстовым интерфейсом пользователя (например, программы на ncurses) могут сделать некоторые вещи, чтобы сделать себя более доступными (например, параметр `force-arrow-cursor` в `alpine`). Большинство приложений командной строки довольно общедоступны как они есть. Этот критерий часто неприменим, например, для библиотек программ. Вот несколько примеров действий или проблем, которые следует учитывать:
    • Должны предоставляться текстовые альтернативы для любого нетекстового контента, так чтобы его можно изменить на другие необходимые формы, например крупная печать, шрифт Брайля, озвучка текста, символы или упрощенный язык (Understanding WCAG 2.0 guideline 1.1)
    • Цвет не должен использоваться в качестве единственного визуального средства передачи информации, указания на действие, запрос реакции пользователя или выделения визуальных элементов. (WCAG 2.0 guideline 1.4.1)
    • Визуальное представление текста и изображений текста должно иметь контрастность не менее 4,5:1, за исключением большого текста, случайного текста и логотипов (WCAG 2.0 guideline 1.4.3)
    • Все функциональные возможности должны быть доступны с клавиатуры (WCAG guideline 2.1)
    • GUI или веб-проект ДОЛЖНЫ тестировать, по крайней мере, одно средство чтения экрана на целевой платформе(ах) (например, NVDA, Jaws или WindowEyes в Windows; VoiceOver на Mac и iOS; Orca на Linux/BSD; TalkBack на Android). Программы с текстовым интерфейсом пользователя МОГУТ по возможности сокращать переписывание текста на экране, чтобы предотвратить лишнее чтение средствами чтения экрана.

    Project sites are GitHub repository pages and PyPI, both of which follow WCAG accessibility practices. Project documentation is plain Markdown rendered with semantic HTML, alt text on images, descriptive link text, and accessible headings. The Mermaid diagram in the README is paired with a textual description of the same flow. CLI output is plain text and screen-reader compatible.



    Проекту СЛЕДУЕТ интернационализировать создаваемое ПО, чтобы обеспечить легкую локализацию под культуру, регион или язык целевой аудитории. Выберите «неприменимо» (N/A), если интернационализация (i18n) не применяется (например, ПО не генерирует текст, предназначенный для конечных пользователей, и не сортирует текст, читаемый человеком), [internationalization]
    Локализация "относится к адаптации продукта, приложения или содержимого документа для соответствия языковым, культурным и другим требованиям конкретного целевого рынка (языковому стандарту)". Интернационализация - это «проектирование и разработка продукта, приложения или содержимого документа, которые позволяют легкую локализацию под целевые аудитории, различающиеся по культуре, региону или языку». (См. «Локализация по сравнению с интернационализацией» на веб-сайте W3C.) Чтобы ПО соответствовало этому критерию, достаточно лишь интернационализации. Не требуется локализация для другого конкретного языка, так как после того, как программное обеспечение было интернационализировано, другие могут работать над локализацией.

    PIC is a verifier library and CLI for AI agent action gating. It does not generate user-facing text intended for end-user consumption, does not sort human-readable text in locale-sensitive ways, and emits only structured machine-readable output (JSON decisions, error codes). Internationalization does not apply.


  • Другое


    Если на сайтах проекта (веб-сайт, хранилище и URL-адреса загрузки) хранятся пароли для аутентификации внешних пользователей, НЕОБХОДИМО хранить пароли как итерированные хеши с отдельной "солью" для каждого пользователя с использованием алгоритма (итерированного) растяжения ключа (например, Argon2id, Bcrypt, Scrypt или PBKDF2). Выберите «неприменимо» (N/A), если сайты проекта не хранят пароли для этой цели. [sites_password_security]
    Примечание: использование GitHub автоматически выполняет этот критерий. Этот критерий применяется только к паролям, используемым для аутентификации внешних пользователей на сайтах проекта (т.н. входящей аутентификации). Если сайты проекта должны подключаться к другим сайтам (т.н. исходящая аутентификация), им может потребоваться хранить аутентифицирующие данные (пароли, ключи) для этой цели как-то иначе (поскольку хранение контрольной суммы для этой цели бесполезно). В данном случае критерий crypto_password_storage применяется к сайтам проекта, по аналогии с критерием sites_https.

    The project does not operate any site that stores user passwords. The repository is hosted on GitHub and the package is distributed via PyPI; both providers manage their own authentication systems. The project does not host its own website or authentication service.


 Управление изменениями 1/1

  • Предыдущие версии


    Проект ОБЯЗАН поддерживать наиболее часто используемые старые версии продукта или предоставлять возможность простого перехода на более новые версии (upgrade path). Если переход затруднен, проект ОБЯЗАН задокументировать порядок обновления (например, изменившиеся интерфейсы и подробные предлагаемые шаги для обновления). [maintenance_or_update]

    https://github.com/madeinplutofabio/pic-standard/blob/main/docs/migration-trust-sanitization.md

    The project follows Semantic Versioning and provides a documented upgrade path to newer versions. Per SECURITY.md, only the latest minor release on the v0.x line receives security fixes; older versions are end-of-life, and users are expected to upgrade. To support that upgrade path, the project provides:
    (1) CHANGELOG.md — a detailed per-release log following semver, with explicit Added / Deprecated / Changed / Notes sections noting wire-format compatibility on every release.
    (2) docs/migration-trust-sanitization.md — a dedicated migration guide for the v0.7.x → v0.8.x → v1.0 trust-model migration, covering: what is changing and why, a per-version timeline table (v0.7.x, v0.8.0, v0.8.1, v1.0), the deprecation warnings producers will see (PICTrustFutureWarning, PICSemiTrustedDeprecationWarning), and step-by-step migration instructions (audit → add evidence → enable evidence verification → opt in to strict_trust=True early).
    (3) ROADMAP.md §"How spec normative freezes are sequenced" — documents the trajectory of every spec artifact (DRAFT → cross-implementation conformance → normative) and the release ladder showing exactly what changes between versions.
    Wire-format compatibility is explicitly tracked: v0.8.1 release notes confirm "Existing v0.8.0 proposals continue to parse, verify, and produce the same allow/block verdicts under v0.8.1," and a verdict-regression matrix in tests/test_trust_deprecation_warning.py is a permanent CI guard against silent behavior changes.


 Отчеты о проблемах 3/3

  • Процесс сообщения об ошибках


    Проект ОБЯЗАН использовать трекер вопросов (issue tracker) для отслеживания отдельных вопросов. [report_tracker]
  • Процесс отчета об уязвимостях


    Проект ОБЯЗАН отмечать автора(-ов) всех отчетов об уязвимостях, разрешенных за последние 12 месяцев, за исключением авторов, которые просят об анонимности. Выберите «неприменимо» (N/A), если в течение последних 12 месяцев не было обнаружено никаких уязвимостей. (Требуется URL) [vulnerability_report_credit]

    https://github.com/madeinplutofabio/pic-standard/security/advisories

    No vulnerabilities have been resolved in the last 12 months. The project's first commit was 2026-01-08 and no security advisories have been filed via the GitHub Security Advisories channel as of submission. The repository's Security Advisories page is publicly viewable at the URL above. SECURITY.md commits the project to crediting reporters in published advisories unless they explicitly request anonymity ("Reporters are credited in the published advisory unless they explicitly request anonymity").



    Проект ОБЯЗАН иметь документированный процесс реагирования на отчеты об уязвимостях. (Требуется URL) [vulnerability_response_process]
    Этот критерий тесно связан с критерием vulnerability_report_process, который требует документированного способа для сообщения об уязвимостях. Он также связан с vulnerability_report_response, который требует ответа на отчеты об уязвимостях в течение определенного периода времени.

    https://github.com/madeinplutofabio/pic-standard/blob/main/SECURITY.md

    The vulnerability response process is documented in SECURITY.md and covers: (1) reporting channel — GitHub Security Advisories private vulnerability reporting, with a step-by-step submission path and explicit instruction not to file public issues; (2) what to include — affected versions, component, reproduction, impact assessment, optional suggested mitigation; (3) disclosure timeline — acknowledgment within 7 days, initial triage within 30 days, fix release targeted within 90 days for High/Critical issues, coordinated public disclosure default 90 days from acknowledgment; (4) scope — in-scope components (Python SDK, canonicalization implementation, verifier, pipeline, evidence, keyring, integration adapters, conformance suite, OpenClaw plugin, specs under docs/) and out-of-scope (downstream code, third-party plugins, hosted services, end-of-life pre-v0.8.0 releases); (5) reporter credit policy — credited in advisory unless anonymity requested; (6) supported-versions table aligning with the SemVer release line.


 Качество 19/19

  • Стандарты кодирования


    Проект ОБЯЗАН задать определенные правила стиля кодирования для основных языков, которые он использует, и требовать его соблюдения от предлагаемого кода. (Требуется URL) [coding_standards]
    В большинстве случаев это делается путем ссылки на некоторые существующие руководства по стилю, возможно, с перечислением различий. Эти руководства по стилю могут включать в себя способы повышения удобочитаемости и способы снижения вероятности дефектов (включая уязвимости). Многие языки программирования имеют один или несколько широко используемых руководств по стилю. Примеры руководств по стилю включают Руководство по стилю Google и Стандарты кодирования SEI CERT.

    https://github.com/madeinplutofabio/pic-standard/blob/main/CONTRIBUTING.md

    Python contributions follow PEP 8 as stated in CONTRIBUTING.md §"Requirements for Acceptable Contributions" ("Python code should follow PEP 8 style"). TypeScript contributions in integrations/openclaw use TypeScript's strict mode ("strict": true in tsconfig.json) with NodeNext module resolution and ES2022 target, type-checked in CI via tsc --noEmit.



    Проект ОБЯЗАН автоматически применять свой выбранный стиль(и) кодирования, если есть хотя бы один инструмент на СПО, который может сделать это на выбранном языке (языках). [coding_standards_enforced]
    Это МОЖЕТ быть реализовано при помощи инструмента(ов) статического анализа и/или путем пропускания кода через средства переформатирования. Во многих случаях конфигурация инструмента включена в репозиторий проекта (так как разные проекты могут выбирать разные конфигурации). Проекты МОГУТ (и, как правило, будут) допускать исключения стиля; там, где происходят исключения, они ОБЯЗАНЫ быть редки и документированы в соответствующих местах кода, чтобы эти исключения можно было пересматривать и инструменты могли автоматически обрабатывать их в будущем. Примеры таких инструментов включают ESLint (JavaScript) и Rubocop (Ruby).

    Python style enforced by Ruff (config in pyproject.toml; rule set E F W I N B SIM RUF). TypeScript style enforced by ESLint v9 flat config + Prettier (config in integrations/openclaw/eslint.config.mjs and .prettierrc.json). Both gated in CI via .github/workflows/ci.yml. Documented for contributors in CONTRIBUTING.md.


  • Рабочая система сборки


    Системы сборки для нативных двоичных файлов ОБЯЗАНЫ учитывать соответствующие переменные (среды) для компилятора и компоновщика, переданные им (например, CC, CFLAGS, CXX, CXXFLAGS и LDFLAGS) и передавать их на вызовы компилятора и компоновщика. Система сборки МОЖЕТ расширять их дополнительными флагами; НЕДОПУСТИМО просто заменять предоставленные значения своими. Выберите «неприменимо» (N/A), если нативные двоичные файлы не создаются. [build_standard_variables]
    Должно быть легко включить специальные функции сборки, такие как Address Sanitizer (ASAN), или выполнить рекомендации по упрочнению от дистрибутивов (например, путем простого включения флагов компилятора для этого).

    PIC produces no native binaries. The Python package builds via setuptools to a pure-Python wheel; the TypeScript plugin builds via tsc to JavaScript. No C/C++ compiler or linker is invoked.



    В системах сборки и установки СЛЕДУЕТ сохранять отладочную информацию, если передаваемые флаги требуют этого (например, не используется «install -s»). Выберите «неприменимо» (N/A), если системы сборки или установки нет (например, для типичных библиотек JavaScript), . [build_preserve_debug]
    Например, установка CFLAGS (C) или CXXFLAGS (C++) должна создавать соответствующую информацию для отладки, если эти языки используются, и ее не следует удалять во время установки. Отладочная информация необходима для поддержки и анализа, а также полезна для того, чтобы определить наличие упрочняющих функций в скомпилированных двоичных файлах.

    No native build occurs. Python sources are distributed as-is in the wheel; TypeScript compiles to JavaScript with sourcemap-capable settings in tsconfig.json. No stripping step exists.



    НЕДОПУСТИМО, чтобы система сборки ПО, создаваемого проектом, рекурсивно собирала подкаталоги, если в подкаталогах есть кросс-зависимости. Выберите «неприменимо» (N/A), если системы сборки или установки нет (например, типичные библиотеки JavaScript). [build_non_recursive]
    Информация о внутренних зависимостях системы сборки проекта должна быть точной, в противном случае изменения в проекте могут быть включены в сборку неправильно. Неправильные сборки могут привести к дефектам (включая уязвимости). Общей ошибкой в ​​больших системах сборки является использование «рекурсивной сборки» или «рекурсивного make», то есть иерархии подкаталогов, содержащих исходные файлы, где каждый подкаталог собирается независимо. Если только каждый из подкаталогов не является полностью независимым, это ошибка, потому что информация о зависимостях неверна.

    Build is handled by setuptools (Python) and tsc (TypeScript). Neither performs recursive Make-style subdirectory builds; both resolve the full dependency graph in a single pass before producing artifacts.



    Проект ОБЯЗАН быть в состоянии повторить процесс генерации информации из исходных файлов и получить такой же результат с точностью до бита. Выберите «неприменимо» (N/A), если в проекте не используется сборка (например, языки сценариев, в которых исходный код используется непосредственно вместо компиляции), . [build_repeatable]
    Пользователи GCC и clang могут найти полезной опцию -frandom-seed; в некоторых случаях это может быть разрешено путем задания определенного порядка сортировки. Дополнительные предложения можно найти на сайте Reproducible builds.

    PIC is a Python package distributed as source plus a pure-Python wheel; source files are used directly and no compilation occurs. The Dockerfile pins the base image by SHA-256 digest (python:3.12-slim@sha256:3d5ed9...) and installs pinned dependency versions for reproducible container builds, but the underlying Python package itself does not have a compilation step subject to bit-for-bit reproducibility.


  • Система установки


    Проект ОБЯЗАН предоставлять возможность легко установить и удалить ПО, создаваемое проектом, с использованием общепринятых способов. [installation_common]
    Примеры включают использование менеджера пакетов (на уровне системы или языка), «make install/uninstall» (с поддержкой DESTDIR), контейнер в стандартном формате или образ виртуальной машины в стандартном формате. Процесс установки и удаления (например, его упаковка) МОЖЕТ быть реализован третьей стороной, при условии что он построен на СПО.

    PIC is published to PyPI and installable via the standard Python convention pip install pic-standard (or with extras: pip install "pic-standard[langgraph,mcp,crypto]"). Uninstall via pip uninstall pic-standard. Documented in README §Quickstart. A Docker image is also available via the included Dockerfile and docker-compose.yml.



    В системе установки для конечных пользователей НЕОБХОДИМО учитывать стандартные соглашения при выборе места, в которое собранные артефакты записываются при установке. Например, если она устанавливает файлы в системе POSIX, НЕОБХОДИМО учитывать переменную окружения DESTDIR. Если установочной системы или стандартного соглашения нет, выберите «неприменимо» (N/A). [installation_standard_variables]

    Installation uses pip, which honors standard Python packaging install-location conventions including --prefix, --root (the Python equivalent of DESTDIR for staged installs), --user, and --target. The project does not override or replace these mechanisms; setuptools handles them via the standard Python build backend declared in pyproject.toml.



    Проект ОБЯЗАН предоставить возможность потенциальным разработчикам быстро установить все результаты проекта и поддерживать среду, необходимую для внесения изменений, включая тесты и тестовое окружение. Проект ОБЯЗАН использовать для этого общепринятые соглашения. [installation_development_quick]
    Это МОЖЕТ быть реализовано при помощи сгенерированного контейнера или установочных сценариев. Внешние зависимости обычно устанавливаются путем вызова системных и/или языковых пакетов, как описано в критерии external_dependencies.

    https://github.com/madeinplutofabio/pic-standard#quickstart

    README §Quickstart documents the standard editable-install convention: git clone ... && cd pic-standard && pip install -e ".[langgraph,mcp,crypto]" && pytest -q. This installs the package in development mode with all optional integrations and runs the full test suite (24 test files in tests/) plus the conformance suite via python -m conformance.run.


  • Компоненты, поддерживаемые извне


    Проект ОБЯЗАН перечислять внешние зависимости в машинночитаемом виде. (Требуется URL) [external_dependencies]
    Обычно это делается при помощи инструкций для диспетчера пакетов и/или системы сборки. Обратите внимание, что это помогает реализовать критерий installation_development_quick.

    https://github.com/madeinplutofabio/pic-standard/blob/main/pyproject.toml

    External dependencies are declared in computer-processable form in pyproject.toml ([project] dependencies and [project.optional-dependencies] for langgraph/crypto/mcp extras), and in pinned form in sdk-python/requirements.txt, requirements-dev.txt, requirements-langgraph.txt, and requirements-mcp.txt. TypeScript dependencies for the OpenClaw integration are declared in integrations/openclaw/package.json with a package-lock.json lockfile.



    Проекты ОБЯЗАНЫ следить за своими внешними зависимостями или периодически проверять их (включая копии, сделанные для удобства) на предмет известных уязвимостей, а также исправлять уязвимости, которые могут быть использованы, или проверять невозможность их использования. [dependency_monitoring]
    Это можно сделать с помощью средств анализа происхождения/зависимостей, например Dependency-Check от OWASP, Nexus Auditor от Sonatype, Protex от Black Duck , Protecode от Synopsys и Bundler-аудит (для Ruby). Некоторые менеджеры пакетов включают в себя соответствующие механизмы. Допустимо оставлять уязвимость, если ее невозможно использовать, но такой анализ труден, и временами проще просто обновить или исправить эту часть кода.

    https://github.com/madeinplutofabio/pic-standard/blob/main/.github/dependabot.yml
    Dependabot is configured in .github/dependabot.yml with weekly scans across four ecosystems: Python (pyproject.toml at root), Python (sdk-python/requirements.txt), npm (integrations/openclaw), and github-actions. Major version bumps are intentionally held for manual review; minor and patch updates are grouped into PRs. GitHub also performs automated vulnerability scanning on the repository's dependency graph.*



    Проект ОБЯЗАН:
    1. позволять легко идентифицировать и обновлять повторно используемые компоненты, поддерживаемые извне; или
    2. использовать стандартные компоненты, предоставляемые системой или языком программирования.
    В этом случае, если уязвимость обнаружена в повторно используемом компоненте, будет легко обновить этот компонент. [updateable_reused_components]
    Типичным способом выполнить этот критерий является использование предоставляемых операционной системой и языком программирования систем управления пакетами. Многие свободные программы распространяются с «подсобными библиотеками», которые являются локальными копиями стандартных библиотек (возможно, форков библиотек). Само по себе это нормально. Однако, если программа *должна* использовать эти локальные копии/форки, то обновление «стандартных» библиотек через системное обновление безопасности оставит эти дополнительные копии по-прежнему уязвимыми. Это особенно актуально для облачных систем; если провайдер облака обновляет свои «стандартные» библиотеки, но программа их не собирается использовать, обновления фактически не помогут. См., например, "Chromium: Why it isn't in Fedora yet as a proper package" от Тома Каллавея.

    PIC uses standard ecosystem components only — Python packages from PyPI (pydantic, jsonschema, cryptography, jsonschema, etc.) and Node packages from npm. All dependencies are managed via standard package managers (pip, npm) and can be updated via the standard pip install -U <pkg> or npm update flows. There are no vendored convenience copies of third-party code.



    Проекту СЛЕДУЕТ избегать использования нерекомендуемых (deprecated) или устаревших (obsolete) функций и API в тех случаях, когда альтернативы на СПО доступны в используемом наборе технологий («стек технологий» проекта) и для подавляющего большинства пользователей, поддерживаемых проектом (т.е. так чтобы пользователи могли быстро воспользоваться этой альтернативой). [interfaces_current]

    PIC targets Python ≥3.10 and uses current, actively-maintained dependencies: Pydantic ≥2.13.3 (current major version, not the deprecated 1.x line), jsonschema ≥4.0.0 (current major version), cryptography ≥42.0.0 (current; older, deprecated cryptography releases are excluded by the version floor). The TypeScript plugin targets Node ≥18, ES2022, and uses NodeNext module resolution. CI tests against Python 3.10, 3.11, and 3.12 to catch deprecation warnings early.


  • Набор автотестов


    НЕОБХОДИМО применять автоматический набор тестов к каждому коммиту в общий репозиторий по крайней мере для одной ветки. Этот набор тестов ОБЯЗАН создавать отчет об успешном или неудачном тестировании. [automated_integration_testing]
    Это требование можно рассматривать как подмножество test_continuous_integration, но сосредоточенное только на тестировании, без требования непрерывной интеграции.

    https://github.com/madeinplutofabio/pic-standard/blob/main/.github/workflows/ci.yml

    Two CI workflows run on every push and pull request: (1) .github/workflows/ci.yml runs pytest across a Python 3.10/3.11/3.12 matrix (with both pinned and latest dependency canaries) plus a separate job for the TypeScript OpenClaw integration (tsc type-check + vitest); (2) .github/workflows/conformance.yml runs the PIC Conformance suite (python -m conformance.run) against the canonicalization and core verifier vectors. Both produce per-job pass/fail reports visible in the Actions tab. CI status is shown via the ![CI] README badge.



    Проект ОБЯЗАН добавить регрессионные тесты к автоматизированному набору тестов по крайней мере на 50% ошибок, исправленных в течение последних шести месяцев. [regression_tests_added50]

    The project routinely adds regression tests for fixed bugs and behavior changes. Concrete examples in tests/: test_trust_deprecation_warning.py codifies the v0.8.0 verdict baseline as a 24-row parametrized verdict-regression matrix (6 example proposals × strict_trust × verify_evidence) that pins behavior across the dict-vs-model boundary refactor (CHANGELOG §[0.8.1]); test_evidence_sandbox.py codifies path-traversal rejection; test_mcp_guard_async_timeout.py and test_mcp_guard_time_budget.py codify DoS-limit behavior; test_strict_trust.py codifies trust-sanitization semantics. The conformance suite (conformance/) provides additional behavior-pinning vectors that run on every PR.



    Проект ОБЯЗАН иметь автоматические тестовые пакеты на СПО, которые обеспечивают покрытие не менее 80% инструкций кода, если есть хотя бы один инструмент на СПО, который может измерять этот критерий на выбранном языке. [test_statement_coverage80]
    Для измерения тестового покрытия существует множество средств на СПО, включая gcov/lcov, Blanket.js, Istanbul и JCov. Обратите внимание, что соответствие этому критерию не является гарантией того, что тестовый пакет является исчерпывающим; вместо этого, несоответствие этому критерию является сильным индикатором плохого набора тестов.

    Python statement coverage 82.0% measured by coverage.py (config in pyproject.toml; gate fail_under = 80 enforced by CI). TypeScript integration plugin coverage measurement deferred to v0.9.x follow-up. See PR #73 for the implementation.


  • Тестирование новых функций


    Проект ОБЯЗАН иметь формальную задокументированную политику о том, что при добавлении существенной новой функциональности НЕОБХОДИМО добавлять тесты для новой функциональности в набор автоматических тестов. [test_policy_mandated]

    https://github.com/madeinplutofabio/pic-standard/blob/main/CONTRIBUTING.md

    CONTRIBUTING.md §Test Policy formally requires that pull requests adding or changing behavior include automated tests under tests/, with conformance vectors under conformance/ for new verifier behavior, and regression tests for bug fixes. Documentation-only and refactor-only PRs are exempt. Maintainers will not merge PRs adding new functionality without corresponding tests.



    Проект ОБЯЗАН включать в свои документированные инструкции для предложений об изменениях политику, по которой для существенной новой функциональности должны добавляться тесты. [tests_documented_added]
    Однако даже неформальное правило приемлемо, если тесты добавляются на практике.
  • Флаги предупреждений


    Проекты ОБЯЗАНЫ быть максимально строгими с предупреждениями в ПО, создаваемом проектом, где это целесообразно. [warnings_strict]
    Некоторые предупреждения не могут быть эффективно задействованы в некоторых проектах. Что необходимо в этом критерии - это доказательства того, что проект стремится включать флаги предупреждений там, где это возможно, чтобы ошибки обнаруживались на ранней стадии.

    CI + test suite already enforces clean runs; the deprecation handling shows strictness.


 Безопасность 13/13

  • Знание безопасной разработки


    Проект ОБЯЗАН реализовывать принципы безопасного дизайна (из критерия «know_secure_design»), где это применимо. Выберите «неприменимо» (N/A), если проект не создает программное обеспечение. [implement_secure_design]
    Например, результаты проекта должны иметь отказоустойчивые значения по умолчанию (доступ по умолчанию должен быть запрещен, а установка проектов по умолчанию должна быть в защищенной конфигурации). Также должно использоваться полное отграничение (любой доступ, который может быть ограничен, должен проверяться на достаточность прав доступа и не иметь обходных путей). Обратите внимание, что в некоторых случаях принципы будут противоречить друг другу, и в этом случае необходимо делать выбор (например, многочисленность механизмов может усложнять дизайн, противореча принципу экономичности/простоты механизма).

    https://github.com/madeinplutofabio/pic-standard/blob/main/docs/RFC-0001-pic-standard.md#security-properties

    PIC is itself a secure-design protocol; the Saltzer & Schroeder principles are explicit in its architecture and documented in RFC-0001:
    Fail-safe defaults (fail-closed) — every error path (schema invalid, evidence missing, tool-binding mismatch, timeout, signature invalid, file not found) results in the action being blocked. There is no fallback to "allow anyway." Documented as Security Property #1 and Conformance MUST #2.
    Complete mediation — every high-impact tool call is gated at the action boundary; the verifier intercepts before any side effect occurs. Documented in RFC-0001 §Protocol Summary and §Conformance MUST #1 (schema validation before execution).
    Open design — protocol, schema, reference implementation, and conformance vectors are all Apache-2.0 and public. RFC-0001 is published as a defensive publication; security does not depend on obscurity.
    Least privilege & separation of privilege — trust is verifier-derived, not declared by the agent: untrusted provenance can only be upgraded to trusted via successful cryptographic evidence verification (Security Property #5). The strict_trust mode (v0.7.5+) sanitizes all inbound trust to "untrusted" before any pipeline step consumes it.
    Economy of mechanism — local-first verifier, deterministic, no external services required (Security Property #4 and #8). The pipeline is intentionally minimal: schema → verifier → evidence.
    Defense in depth — multiple independent gates: JSON Schema validation, fail-closed enforcement, tool-binding integrity check, sandboxed evidence resolution within evidence_root_dir with path-traversal rejection (Security Property #6), Ed25519 signature verification with key expiry and revocation lists (Security Property #7), and DoS resistance limits (64 KB max proposal, 500 ms eval budget, 5 MB max evidence file, 64-item array caps — threat T7).
    Minimize attack surface — local-first by default with no outbound network calls; HTTP bridge is opt-in; integration extras (langgraph, mcp, crypto) are opt-in; trust sanitization shrinks the exploitable surface to verifiable evidence only.
    Input validation — every proposal is validated against the PIC/1.0 JSON Schema before execution; tool arguments cannot exceed what the proposal binds to (tool-binding integrity, Conformance MUST #4).
    Threat model and mitigations for seven concrete attack classes (T1–T7: prompt injection, hallucination-driven loss, privilege escalation via tool chaining, untrusted-data laundering, evidence forgery, verification bypass, DoS via proposals) are documented in RFC-0001 §Threat Model.


  • Основы правильного использования криптографии

    Обратите внимание, что некоторое ПО не нуждается в использовании криптографических механизмов.

    В ПО, создаваемом проектом, НЕДОПУСТИМО делать механизмы безопасности по умолчанию зависимыми от криптографических алгоритмов или режимов с известными серьезными слабостями (например, криптографический алгоритм хеширования SHA-1 или режим CBC в SSH). [crypto_weaknesses]
    Проблемы, связанные с режимом CBC в SSH, обсуждаются в описании уязвимости CERT: SSH CBC.

    No SHA-1, no CBC in SSH, no weak modes.



    Проекту СЛЕДУЕТ поддерживать несколько криптографических алгоритмов, чтобы пользователи могли быстро переключиться, если один из них поврежден. Общие симметричные ключевые алгоритмы включают AES, Twofish и Serpent. Общие алгоритмы контрольных сумм (хешей) включают SHA-2 (SHA-224, SHA-256, SHA-384 и SHA-512) и SHA-3. [crypto_algorithm_agility]

    PIC's evidence model is algorithm-extensible: the evidence field uses a discriminated type enum (hash, sig) and the schema is designed so additional algorithm types can be added without breaking existing implementations. The current reference implementation supports SHA-256 hashes and Ed25519 signatures — both modern, non-deprecated primitives. Algorithm migration is enabled at the protocol layer (new type values can be added) and at the keyring layer (alg field on signature evidence makes the algorithm explicit per signature, supporting parallel algorithms during migration). The KeyResolver protocol (v0.7+) further allows operators to plug in custom trust backends including HSM-backed services with their own algorithm support.



    Проект ОБЯЗАН поддерживать хранение данных для аутентификации (например, паролей и динамических токенов) и закрытых криптографических ключей в файлах, отдельных от остальной информации (например, файлов конфигурации, баз данных и журналов) и позволять пользователям их обновление и замену без перекомпиляции кода. Выберите «неприменимо» (N/A), если проект никогда не работает с данными аутентификации и закрытыми криптографическими ключами. [crypto_credential_agility]

    https://github.com/madeinplutofabio/pic-standard/blob/main/docs/keyring.md

    Trusted public keys are stored in a dedicated keyring file (pic_keys.json, see pic_keys.example.json for schema) entirely separate from configuration (pic_policy.json), code, and logs. The keyring file contains trusted_keys (with per-key expires_at) and revoked_keys. Keys can be added, expired, revoked, or rotated at runtime by editing the file — no code recompilation required. The KeyResolver protocol (v0.7+) additionally allows custom trust backends (HSM-backed services, Vault-managed keys, cached remote keyrings) to plug into the verifier and pipeline directly via the StaticKeyRingResolver or any operator-supplied implementation. PIC never stores private keys; the project handles only public keys for verification.



    В ПО, создаваемом проектом, СЛЕДУЕТ поддерживать безопасные протоколы для всех сетевых коммуникаций, такие как SSHv2 или новее, TLS1.2 или новее (HTTPS), IPsec, SFTP и SNMPv3. По умолчанию СЛЕДУЕТ отключать небезопасные протоколы, такие как FTP, HTTP, telnet, SSLv3 или более ранние версии, и SSHv1, и разрешать их только в том случае, если пользователь явным образом это задаёт. Если программное обеспечение, созданное проектом, не поддерживает сетевые коммуникации, выберите «неприменимо» (N/A). [crypto_used_network]

    PIC is a local-first verifier library and performs no outbound network communications. The MCP integration runs in-process (no HTTP). The optional pic-cli serve HTTP bridge is opt-in (the operator must explicitly invoke the subcommand) and intended for loopback IPC only. No insecure network protocol is enabled by default.



    Если ПО, создаваемое проектом, поддерживает или использует TLS, ему СЛЕДУЕТ поддерживать как минимум версию TLS 1.2. Примечание: предшественник TLS называется SSL. Если программное обеспечение не использует TLS, выберите «неприменимо» (N/A). [crypto_tls12]

    The PIC reference implementation does not use TLS. The verifier and SDK are local-first; the optional HTTP bridge is intended for loopback IPC only and does not terminate TLS.



    В ПО, создаваемом проектом, НЕОБХОДИМО выполнять проверку сертификата TLS по умолчанию при использовании TLS, в том числе в подресурсах. Если программное обеспечение не использует TLS, выберите «неприменимо» (N/A). [crypto_certificate_verification]
    Обратите внимание, что неправильная проверка сертификата TLS является распространенной ошибкой. Для дальнейших сведений см. "The Most Dangerous Code in the World: Validating SSL Certificates in Non-Browser Software" Мартина Георгиева и др. и "Do you trust this application?" Майкла Катанзаро.

    PIC does not use TLS. The reference implementation is local-first; no outbound TLS connections are made.



    В ПО, создаваемом проектом, НЕОБХОДИМО, если поддерживается TLS, выполнять проверку сертификата TLS по умолчанию при использовании TLS, в том числе в подресурсах. Если программное обеспечение не использует TLS, выберите «неприменимо» (N/A). [crypto_verification_private]

  • Безопасный выпуск


    Проект ОБЯЗАН криптографически подписывать выпуски результатов проекта, предназначенные для широкого использования, и ОБЯЗАН иметь задокументированный процесс, объясняющий пользователям, как они могут получить общедоступные ключи подписи и проверить подпись(и) выпусков. НЕДОПУСТИМО размещать закрытый ключ для этих подписей на сайте(сайтах), используемом для прямого распространения ПО для общественности. Выберите «неприменимо» (N/A), если выпуски не предназначены для широкого использования. [signed_releases]
    Результаты проекта включают как исходный код, так и любые сгенерированные результаты, если это применимо (например, исполняемые файлы, пакеты и контейнеры). Сгенерированные результаты МОГУТ быть подписаны отдельно от исходного кода. Подписывание МОЖЕТ быть реализовано как подписанные теги git (с использованием криптографических цифровых подписей). Проекты МОГУТ предоставлять генерируемые результаты отдельно от таких инструментов, как git, но в этих случаях отдельные результаты ОБЯЗАНЫ быть отдельно подписаны.

    Releases are cryptographically signed via two complementary layers:

    Layer 1 (PyPI distribution artifacts): PEP 740 attestations (Sigstore-backed, tied to the GitHub Actions Trusted Publisher workflow identity madeinplutofabio/pic-standard running release.yml under the pypi environment). Verifiable via pypi-attestations verify pypi --repository https://github.com/madeinplutofabio/pic-standard <wheel-or-sdist>.

    Layer 2 (git tags): SSH-signed with the project's dedicated Ed25519 release-signing key (public key at .github/release-signing-key.pub; fingerprint SHA256:blCcqBpKLCrJUtUYwOvxE3tmUa4F37/COJvy8F80hHg). Verifiable via git tag -v.

    First release through the new infrastructure: v0.8.1.1 (2026-05-11). Both verification paths reproducibly succeed against this release. Full documented process: https://github.com/madeinplutofabio/pic-standard/blob/main/RELEASING.md



    ЖЕЛАТЕЛЬНО, чтобы в системе контроля версий каждый важный тег версии (тег, который является частью основного выпуска, минорной версии или исправляет общедоступные уязвимости) подписывался криптографической подписью и поддавался проверке, как описано в критерииsigned_releases. [version_tags_signed]

    All release tags from v0.8.1.1 onward are cryptographically signed using the project's dedicated Ed25519 release-signing key. The signature is verified by the release workflow before any artifact is built (.github/workflows/release.yml → verify-and-build job). GitHub server-side verification of the v0.8.1.1 tag returns "verified": true with reason "valid".

    Public key + fingerprint pinned in https://github.com/madeinplutofabio/pic-standard/blob/main/RELEASING.md


  • Другие вопросы безопасности


    В результатах проекта НЕОБХОДИМО проверять любой ввод из потенциально ненадежных источников, чтобы убедиться, что они действительны (*белый список*), и отклонять недействительный ввод, если вообще есть какие-либо ограничения на данные. [input_validation]
    Обратите внимание, что сравнения ввода со списком «плохих форматов» (также известным как *черный список*) обычно недостаточно, потому что злоумышленники часто могут обойти черный список. В частности, числа преобразуются во внутренние форматы, а затем проверяются, находятся ли они между их минимальным и максимальным (включительно), а текстовые строки проверяются, чтобы убедиться, что они являются допустимыми текстовыми шаблонами (например, действительный UTF-8, длина, синтаксис и т. д.). От некоторых данных может требоваться, чтобы они были «хоть чем-нибудь» (например, загрузчик файлов), но такое обычно случается редко.

    Every Action Proposal is validated against the PIC/1.0 JSON Schema (sdk-python/pic_standard/schemas/proposal_schema.json) using jsonschema before any pipeline step executes — schema validation is the first stage of the verifier and uses an explicit allowlist of permitted fields, types, and enum values (impact classes, trust levels, evidence types). Pydantic models in sdk-python/pic_standard/ provide a second validation layer with field validators (e.g., the Provenance.trust validator that normalizes deprecated values). Invalid inputs are rejected fail-closed: schema violations, unknown enum values, missing required fields, oversized payloads (>64 KB), oversized arrays (>64 items), and oversized evidence files (>5 MB) all return block. File evidence is sandboxed within evidence_root_dir with explicit path-traversal rejection. Tool-binding integrity is verified — action.tool MUST match the actual tool being invoked, and unexpected tool arguments outside the proposal envelope are rejected.



    В ПО, создаваемом проектом, СЛЕДУЕТ использовать механизмы упрочнения безопасности (hardening), чтобы дефекты программного обеспечения с меньшей вероятностью приводили к уязвимостям в безопасности. [hardening]
    Механизмы упрочнения могут включать HTTP-заголовки, такие как Content Security Policy (CSP), флаги компилятора для противостояния атакам (например, -fstack-protector) или флаги компилятора, устраняющие неопределенное поведение. Для наших целей политика наименьших привилегий не считается механизмом упрочнения (использовать наименьшие достаточные привилегии важно, но этому посвящён отдельный критерий).

    https://github.com/madeinplutofabio/pic-standard/blob/main/docs/RFC-0001-pic-standard.md#security-properties

    PIC implements multiple hardening mechanisms documented in RFC-0001: (1) fail-closed enforcement on every error path; (2) sandboxed evidence resolution within a configured evidence_root_dir, with path-traversal rejection; (3) DoS resistance limits (64 KB max proposal, 500 ms eval budget, 5 MB max evidence file, 64-item array caps); (4) Ed25519 signature verification with key expiry and revocation lists; (5) strict-trust mode (v0.7.5+) sanitizing inbound provenance trust; (6) tool-binding integrity check rejecting any tool mismatch. See RFC-0001 §Security Properties and §Threat Model.



    Проект ОБЯЗАН предоставить обоснование того, что требования безопасности соблюдаются проектом. В обоснование НЕОБХОДИМО включить: описание модели угроз, четкое указание границ доверия, доказательство того, что использовались принципы безопасного дизайна, и доказательство того, что слабости в безопасности реализации нейтрализованы. (Требуется URL) [assurance_case]
    Обоснованием является «документальное подтверждение, которое дает убедительное и корректное доказательство того, что указанный набор критических заявлений относительно свойств системы адекватно оправдан для данного приложения в данной среде» (перевод выдержки из "Software Assurance Using Structured Assurance Case Models", Thomas Rhodes et al, NIST Interagency Report 7608). Границы доверия - это границы, на которых меняется уровень доверия к данным или выполнению кода, например границы сервера в типичном веб-приложении. В обосновании обычно перечисляются принципы безопасного проектирования (такие как Saltzer and Schroeer) и общие слабости безопасности в реализации (такие как OWASP Top 10 или CWE/SANS Top 25), и показывается, как противодействовать каждой из них. Полезным примером может служить обоснование для BadgeApp. Этот критерий связан с documentation_security, documentation_architecture и implement_secure_design.

    https://github.com/madeinplutofabio/pic-standard/blob/main/docs/RFC-0001-pic-standard.md

    RFC-0001 serves as the project's assurance case and contains all four required elements:
    (1) Threat model — RFC-0001 §Threat Model enumerates seven concrete threats (T1–T7: prompt injection to side effect, hallucination to financial loss, privilege escalation via tool chaining, untrusted-data laundering, evidence forgery, verification bypass, DoS via proposals) with explicit PIC mitigations for each.
    (2) Trust boundaries — RFC-0001 §Scope and §Non-Goals identify the security boundary explicitly. PIC operates at the action boundary (after agent reasoning, before any side effect). Inputs are classified by a three-level provenance trust model (trusted, semi_trusted [deprecated], untrusted). Trust is verifier-derived in v1.0+, never declared by the agent. Non-Goals enumerate eight things explicitly outside the boundary (model output guardrails, user/agent authentication, RBAC, prompt filtering, runtime sandbox, logging/SIEM, tool input validation, protection against compromised trusted signers).
    (3) Secure-design principles applied — argued in RFC-0001 §Security Properties (eight MUST/SHOULD properties: fail-safe defaults via fail-closed enforcement, complete mediation at the action boundary, open design via Apache-2.0 + defensive publication, separation of privilege via verifier-derived trust, economy of mechanism via local-first design, deterministic verification, sandboxed evidence resolution, key lifecycle management).
    (4) Common implementation weaknesses countered — JSON Schema + Pydantic input validation against an allowlist (counters injection, malformed input, type confusion); fail-closed on every error path (counters logic-error vulnerability classes); sandboxed file resolution with path-traversal rejection (counters CWE-22); DoS limits on proposal size, evaluation time, evidence size, and array length (counters CWE-400); Ed25519 with key expiry and revocation (counters key compromise and stale-trust); tool-binding integrity check (counters confused-deputy patterns); deprecation/migration warnings before behavior changes (counters silent-semantic-shift vulnerability classes).
    The assurance case is anchored to specific code modules with SHA-256 fingerprints in RFC-0001 §Spec Fingerprint and docs/RFC-0001.SHA256, providing tamper-evident binding between the argument and the implementation it argues about.


 Анализ 2/2

  • Статический анализ кода


    Проект ОБЯЗАН использовать хотя бы один инструмент статического анализа с правилами или подходами для поиска распространенных уязвимостей в анализируемом языке или окружении, если есть хотя бы один инструмент на СПО, который может реализовать этот критерий на выбранном языке. [static_analysis_common_vulnerabilities]
    Инструменты статического анализа, специально предназначенные для поиска распространенных уязвимостей, с большей вероятностью найдут их. Тем не менее, использование любых статических инструментов обычно помогает найти какие-то проблемы, поэтому мы предлагаем, но не требуем этого для получения базового значка.

    The TypeScript type checking + Python test/conformance suite already surface many common issues.


  • Динамический анализ кода


    Если ПО, создаваемое проектом, включает ПО, написанное с использованием небезопасного языка (например, C или C++), тогда проект ОБЯЗАН регулярно использовать хотя бы один динамический инструмент (например, фаззер или сканер веб-приложения) в сочетании с механизмом для обнаружения проблем безопасности памяти, таких как перезапись буфера. Выберите «неприменимо» (N/A), если проект не создает ПО, написанное на небезопасном языке. [dynamic_analysis_unsafe]
    Примерами механизмов обнаружения проблем безопасности памяти являются Address Sanitizer (ASAN) (доступен в GCC и LLVM), Memory Sanitizer и valgrind. Другие потенциально используемые инструменты включают Thread Sanitizer и Undefined Behavior Sanitizer. Достаточно широкое использование утверждений (assertions) тоже может быть приемлемо.

    main codebase is Python (memory-safe) and the small TypeScript integration is also memory-safe with type checking. No C/C++ or other unsafe languages.



Эти данные доступны по лицензии Community Data License Agreement – Permissive, Version 2.0 (CDLA-Permissive-2.0). Это означает, что получатель данных может распространять данные с изменениями или без них, при условии, что получатель данных предоставляет текст данного соглашения вместе с распространяемыми данными. Пожалуйста, укажите в качестве источника Fabio Marcello Salvadori и участников OpenSSF Best Practices badge.

Владелец анкеты на значок проекта: Fabio Marcello Salvadori.
2026-05-09 11:08:52 UTC, последнее изменение сделано 2026-06-22 23:27:53 UTC. Последний раз условия для получения значка были выполнены 2026-05-09 13:34:54 UTC.