Heimdall

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

Если это ваш проект, пожалуйста, покажите свой значок на странице проекта! Статус значка выглядит следующим образом: Уровень значка для проекта 9841 - passing Вот как вставить его:

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

        

 Основы 2/5

  • Идентификация

    Python library for easily importing, exporting or migrating between one or more databases formats, including SQL databases, noSQL ones, XML, CSV, JSON or YAML files, or various REST or non-RESTful APIs.

  • Предварительные требования


    Проект ОБЯЗАН получить серебряный значок. [achieve_silver]

  • Надзор за проектом


    Проект ОБЯЗАН иметь «коэффициент автобуса» 2 или более. (Требуется URL) [bus_factor]

    Heimdall is a public sector research project. We will probably never have a bus factor greater than 1. - if you're interested by this project, don't wait my death to be involved ; - if you're interested by this project and I already died, ... just fork.



    Проект ОБЯЗАН иметь как минимум двух несвязанных значительных соавторов. (Требуется URL) [contributors_unassociated]

  • Другое


    Проект ОБЯЗАН указывать лицензию в каждом исходном файле. Это МОЖЕТ быть сделано путем включения в комментарий рядом с началом каждого файла следующей строки: SPDX-License-Identifier: [SPDX-выражение лицензии для проекта]. [license_per_file]

    License statements are included in each source module's docstring (ie. description comment), as long as in __license__ dunder at the end of the same file. For example:
    https://gitlab.huma-num.fr/datasphere/heimdall/python/-/blob/main/src/heimdall/heimdall.py


  • Публичное хранилище исходного кода с поддержкой версий


    Хранилище проектного исходного кода ОБЯЗАНО использовать типовое ПО для распределенного управления версиями (например, git или mercurial). [repo_distributed]

    Project uses git.



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

    As is described in the project's CONTRIBUTING document, the "up-for-grabs" issue label is used for this purpose:
    https://gitlab.huma-num.fr/datasphere/heimdall/python/-/issues/?sort=created_date&state=all&label_name%5B%5D=up-for-grabs



    Проект ОБЯЗАН требовать двухфакторной аутентификации (ДФА) от разработчиков для изменения центрального хранилища или доступа к конфиденциальным данным (например, приватным отчетам об уязвимостях). Этот механизм ДФА МОЖЕТ использовать механизмы без криптографической защиты, такие как SMS, хотя это не рекомендуется. [require_2FA]

    The project's main repository is hosted on a GitLab instance, and relies on it for this feature.



    При двухфакторной аутентификации (ДФА) проекту СЛЕДУЕТ использовать криптографические механизмы для предотвращения имперсонации. ДФА на основе службы коротких сообщений (SMS) сама по себе НЕ соответствует этому критерию, поскольку короткие сообщения не шифруются. [secure_2FA]

    The project's main repository is hosted on a GitLab instance, and relies on it for this feature.


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


    Проект ОБЯЗАН документировать свои требования по ревью кода, в том числе, как проводится ревью кода, что необходимо проверять и что необходимо для приемлемости кода. (Требуется URL) [code_review_standards]

    Code review requirements are described in the project's CONTRIBUTING document:
    https://gitlab.huma-num.fr/datasphere/heimdall/python/-/raw/main/CONTRIBUTING.rst



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

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


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

    Each dependency of the project is documented in the pyproject.toml file which is, at the time of writing, the recommended Python way: https://gitlab.huma-num.fr/datasphere/heimdall/python/-/raw/main/pyproject.toml

    Every step of the build is documented in the continuous integration configuration file:
    https://gitlab.huma-num.fr/datasphere/heimdall/python/-/raw/main/.gitlab-ci.yml
    Only mature and widely used build tools are used.


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


    Набор тестов ОБЯЗАН запускаться стандартным способом для этого языка. (Требуется URL) [test_invocation]

    Project README explains how to run the test suite using pytest:
    https://gitlab.huma-num.fr/datasphere/heimdall/python/-/blob/main/README.rst

    Every step of the build is documented in the continuous integration configuration file:
    https://gitlab.huma-num.fr/datasphere/heimdall/python/-/raw/main/.gitlab-ci.yml



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

    Continuous integration results are available here: https://gitlab.huma-num.fr/datasphere/heimdall/python/-/pipelines
    Continuous integration analytics are available here: https://gitlab.huma-num.fr/datasphere/heimdall/python/-/pipelines/charts



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

    Coverage is measured using the widely known coverage tool. % statement coverage is maintained as high as possible, and well above 90%.

    You can check this yourself in the latest coverage report: https://datasphere.gitpages.huma-num.fr/heimdall/python/coverage/index.html



    Проект ОБЯЗАН иметь автоматические тестовые пакеты на СПО, которые обеспечивают покрытие не менее 80% веток кода, если есть хотя бы один инструмент на СПО, который может измерять этот критерий на выбранном языке. [test_branch_coverage80]

    Coverage is measured using the widely known coverage tool. % branch coverage is maintained as high as possible, and well above 80%.

    You can check this yourself in the latest coverage report: https://datasphere.gitpages.huma-num.fr/heimdall/python/coverage/index.html


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

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

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


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

  • Доставка, защищенная от атак посредника (MITM)


    Веб-сайт проекта, репозиторий (если он доступен через Интернет) и сайт загрузки (если он существует отдельно) ОБЯЗАНЫ использовать упрочняющие безопасность (hardening) заголовки с неразрешающими значениями. (Требуется URL) [hardened_site]

    GitLab is known to meet this, as can be seen in the project repository:
    https://gitlab.huma-num.fr/datasphere/heimdall/python


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


    Проект ОБЯЗАН иметь проверку безопасности за последние 5 лет. При проверке НЕОБХОДИМО учитывать требования и границы безопасности. [security_review]


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

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


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

    Automated tests are run with each new (pushed) version, including releases.



    Проекту СЛЕДУЕТ включать достаточно много утверждений (assertions) времени выполнения в создаваемом им ПО и проверять эти утверждения во время динамического анализа. [dynamic_analysis_enable_assertions]

    All test modules are made available with the source code, in the /tests top-level folder.



This data is available under the Community Data License Agreement – Permissive, Version 2.0 (CDLA-Permissive-2.0). This means that a Data Recipient may share the Data, with or without modifications, so long as the Data Recipient makes available the text of this agreement with the shared Data. Please credit Régis Witz and the OpenSSF Best Practices badge contributors.

Владелец анкеты на значок проекта: Régis Witz.
2024-12-18 16:45:07 UTC, последнее изменение сделано 2025-04-11 13:16:52 UTC. Последний раз условия для получения значка были выполнены 2024-12-20 09:50:53 UTC.

Назад