modonome

本サイトが提示する下記のベストプラクティスを実行するプロジェクトは、Open Source Security Foundation (OpenSSF) バッジを達成したことを自主的に自己認証し、そのことを外部に示すことができます。

ソフトウェアに欠陥や脆弱性がないことを保証する手立てはありません。形式論的な証明ができたとしても、仕様や前提が間違っていると誤動作の可能性があります。また、プロジェクトが健全で、かつ機能的な開発コミュニティであり続けることを保証する手立てもありません。しかし、ベストプラクティスの採用は、プロジェクトの成果の向上に寄与する可能性があります。たとえば、いくつものベストプラクティスがリリース前の複数人によるレビューを定めていますが、それによりレビュー以外では発見困難な技術的脆弱性を見つけるのを助け、同時に異なる企業の開発者間の信頼を築き、さらに交流を続けることに対する意欲を生んでいます。バッジを獲得するには、すべてのMUSTおよびMUST NOT基準を満たさなければなりません。すべてのSHOULD基準も満たさなければなりませんが、正当な理由がある場合は満たさなくても構いません。そしてすべてのSUGGESTED基準も満たさなければなりませんが、満たさないとしても、少なくとも考慮することが望まれます。フィードバックは、 GitHubサイトのissueまたはpull requestとして提示されれば歓迎します。また、議論のためのメールリストも用意されています。

私たちは多言語で情報を提供していますが、翻訳版に矛盾や意味の不一致がある場合は、英語版を正式な記述とします。
これがあなたのプロジェクトなら、あなたのプロジェクトページにあなたのバッジステータスを表示してください!バッジステータスは次のようになります。 プロジェクト 13362 のバッジ レベルは in_progress です バッジステータスの埋め込み方法は次のとおりです。
バッジステータスを表示するには、あなたのプロジェクトのマークダウンファイルに以下を埋め込みます
[![OpenSSF Best Practices](https://www.bestpractices.dev/projects/13362/badge)](https://www.bestpractices.dev/projects/13362)
あるいは、以下をHTMLに埋め込みます
<a href="https://www.bestpractices.dev/projects/13362"><img src="https://www.bestpractices.dev/projects/13362/badge"></a>


これらはゴールドレベルの基準です。合格またはシルバーレベル基準を表示することもできます。

Baseline Series: ベースラインレベル1 ベースラインレベル2 ベースラインレベル3

        

 基本的情報 0/5

  • 一般

    他のプロジェクトが同じ名前を使用していないか注意してください。

    Governed autonomy for software repositories. An off-by-default autonomous engineer that adopts a repo's rules, proposes small reviewable changes, and structurally prevents autonomous agents from gaming quality gates by running the enforcement ratchet in CI outside the agent's write scope.

    SPDXライセンスの表現形式を使用してください。 例:「Apache-2.0」、「BSD-2-Clause」、「BSD-3-Clause」、「GPL-2.0+」、「LGPL-3.0+」、「MIT」、「(BSD-2-Clause OR Ruby)」。一重引用符または二重引用符を含めないでください。
    複数の言語がある場合は、コンマを区切り(スペースを入れてもよい)としてリストし、使用頻度の高いものから順に並べます。使用言語が多くある場合は、少なくとも最初の3つの最も多く使われるものをリストアップしてください。言語がない場合(例:ドキュメントだけ、またはテスト専用のプロジェクトの場合)、1文字 " - "を使用します。言語ごとにある大文字・小文字の慣用を踏襲してください(例:「JavaScript」)。
    Common Platform Enumeration(CPE)は、情報技術(IT)システム、ソフトウェア、およびパッケージのための構造化された命名体系です。脆弱性を報告する際に、多くのシステムやデータベースで使用されています。

    Modonome is a prompt plus a set of enforcing scripts with zero runtime npm dependencies. It ships with AgentProof, a portable 16-scenario adversarial benchmark that machine-verifies all governance controls hold under attack (scoring 16/16 GOVERNED). Every arming lever defaults to off; autonomy cannot be enabled from a file the agent can write. The project targets teams that want to run autonomous coding agents under provable governance constraints rather than prompt-only promises.

  • 前提要件


    プロジェクトは、シルバー レベル バッジを達成しなければなりません。 [achieve_silver]

  • プロジェクトの管理・運営


    プロジェクトは2以上の "バス ファクタ"を持つ必要があります。 (URLが必要です) [bus_factor]
    「バス ファクタ」(別名「トラック ファクタ」)は、知見があり有能な人材が離脱して、プロジェクトが停止に至る時に、プロジェクトから突然消失する(「バスに当たった」)プロジェクトメンバーの最小人数です。 トラック ファクタツールは、GitHub上のプロジェクトに対してこれを見積もることができます。詳細については、Cosentino et al。の Gitリポジトリのバス ファクタの評価を参照してください。


    プロジェクトには少なくとも2人の関係を持たない重要な貢献者がいなければなりません。 (URLが必要です) [contributors_unassociated]
    同じ組織によって作業に対しに支払われ(従業員または請負業者)、組織がプロジェクトの成果の恩恵を受ける場合、貢献者は関連します。財務補助金が他の組織を通過する場合、同じ組織のものであると見なされません(例えば、共通の政府やNGOのソースから異なる組織に支払われた科学補助金は、貢献者を関連させません)。過去1年間にプロジェクトに些細でない貢献をしていれば、その人は大きな貢献をしています。重要な貢献者の良い指標の例としては、少なくとも1,000行のコード、50個のコミット、または少なくとも20ページの文書化が挙げられます。

  • その他


    プロジェクトは、各ソースファイルにライセンスステートメントを含まなければなりません。これは、各ファイルの先頭近くに次のコメントを含めることによって行うことができます: SPDXライセンス識別子:[プロジェクトに対するSPDXライセンス表現] [license_per_file]
    これは、ライセンスを特定する自然言語での記述を含めることによっても行うことができます。プロジェクトには、ライセンス テキストまたは完全なライセンステキストを指し示す安定したURLを含めることもできます。 license_location基準は、プロジェクトライセンスが標準の場所にあることを要求します。 SPDXライセンスの詳細については、このSPDXチュートリアルを参照してください。 copyright_per_file との関係に注意してください。その内容は通常、ライセンス情報に先行します。

 変更管理 1/4

  • 公開されたバージョン管理ソースリポジトリ


    プロジェクトのソースリポジトリは、共通の分散バージョン管理ソフトウェア(gitやmercurialなど)を使用しなければなりません。 [repo_distributed]
    Gitが特別に必要とされているわけでなく、プロジェクトでは、集中型バージョン管理ソフトウェア(例:subversion)を正当とする証拠を持って使用できます。

    Repository on GitHub, which uses git. git is distributed.



    プロジェクトは、新規または偶に参加する貢献者によって実行できる小さなタスクを明確に識別しなければなりません。 (URLが必要です) [small_tasks]
    この特定は、通常、課題トラッカーの選択された課題に対して、プロジェクトがそのために使用する1つまたは複数のタグ、たとえば、 up-for-grabs(誰でも使用可能)first-timers-only(初心者専用)、Small fix(小修正)、microtask(小タスク)、またはIdealFirstBug(理想的な最初のバグ)のいずれかをマークすることによって行われます。 これらの新しいタスクには機能を追加する必要はありません。ドキュメントを改善したり、テストケースを追加したり、プロジェクトを支援したり、プロジェクトの詳細を貢献者が理解できるようにすることができます。


    プロジェクトは、中央リポジトリを変更したり、機密データ(プライベート脆弱性レポートなど)にアクセスするために、開発者に対して二要素認証(2FA)を要求する必要があります。推奨されませんが、2FAメカニズムは、SMSのような暗号化メカニズムを持たないメカニズムを使用することができます。 [require_2FA]


    プロジェクトの2要素認証(2FA)は、偽装を防ぐために暗号化メカニズムを使用すべきです。ショート メッセージ サービス(SMS)ベースの2FA自体は、暗号化されていないため、この基準を満たしていません。 [secure_2FA]
    この基準を満たす2FAメカニズムは、一定時間後に変更される認証コードを自動的に生成するタイムベースのワン タイム パスワード(TOTP)アプリケーションです。 GitHubはTOTPをサポートしています

 品質 2/7

  • コーディング標準


    プロジェクトは、コードレビューの実施方法、チェックする必要があるもの、受け入れられる必要があるものなど、コードレビュー要件を文書化しなければなりません。 (URLが必要です) [code_review_standards]
    two_person_review とcontribution_requirementsも参照してください。


    プロジェクトは、公開する前に、提案されたすべての変更の少なくとも50%を著作者以外の人がレビューして、それが価値のある変更であり、取り込みに反対する既知の問題がないかどうかを判断しなければなりません。 [two_person_review]

  • 作業ビルドシステム


    プロジェクトが再現可能なビルドを持たなければなりません。ビルドが発生しない場合(たとえば、コンパイルされないでソースコードが直接使用されるスクリプト言語)、「該当なし」(N/A)を選択します。 (URLが必要です) [build_reproducible]
    再現可能なビルドは、複数の当事者がソース ファイルから情報を生成するプロセスを独立にやり直し、ビット単位でまったく同じ結果を得られることを意味します。ある場合には、これ(再現可能なビルド)は、あるソート順を強いることで解決されます。Javaスクリプトの開発者は、npm shrinkwrapとwebpack OccurenceOrderPluginの使用を検討するかもしれません。GCCとclangのユーザーは、-frandom-seedオプションが有用であることを見つけるかもしれません。ビルド環境(ツールセットを含む)は、リビルドに使用できる特定のコンテナや仮想マシンの暗号化ハッシュを指定することによって、外部パーティのために、しばしば定義可能です。再現可能なビルド プロジェクトは、これを行う方法を記載したドキュメントを有します

  • 自動テスト スイート


    テストスイートは、その言語の標準的な方法で呼び出すことができなければなりません。 (URLが必要です) [test_invocation]
    たとえば、「make check」、「mvn test」、「rake test」(Ruby)などです。

    Modonome is a Node.js/JavaScript project. The standard way to invoke tests in Node.js projects is:

    npm test
    Modonome Implementation:

    In package.json:

    "test": "node --test tests/*.test.mjs"
    This follows the Node.js standard convention:

    npm test is the standard npm command for running tests
    Uses Node.js built-in test runner (node --test) - the native, FLOSS testing approach
    No external test framework required (no Jest, Mocha, or other dependencies)
    Standard Invocation:

    npm test # Runs the standard test suite
    npm run verify # Comprehensive verification (includes tests + other checks)
    Documentation:

    README.md (line 192): Documents npm run verify which includes tests
    CONTRIBUTING.md (lines 14-20): "Local checks: npm run verify"
    package.json: Shows npm test script for direct test execution
    This follows the npm/Node.js standard where npm test is the conventional way to run tests for JavaScript projects, exactly as specified in the npm documentation.

    URL: https://github.com/nateshpp/modonome/blob/main/package.json



    プロジェクトは、新しいコードまたは変更されたコードが頻繁に中央コードリポジトリに統合され、その結果に対して自動化されたテストが実行される、継続的な統合を実装しなければなりません。 (URLが必要です) [test_continuous_integration]
    ほとんどの場合、これは、プロジェクトでフルタイムで働く各開発者が少なくとも1日に1回統合作業をすることを意味します。

    Justification:

    Modonome implements a comprehensive continuous integration (CI) system:

    1. Central Repository:

    GitHub repository: https://github.com/nateshpp/modonome
    All code changes integrated through pull requests
    2. Automated CI Pipeline (.github/workflows/ci.yml):

    Runs on every push to main and all pull requests:

    jobs:
    verify:
    - Drift guard validation
    - Style check (from trusted base-branch copy)
    - Automated tests (npm test)
    - Published artifact verification
    - AgentProof governance benchmark (16/16 scenarios)

    ratchet:
    - Anti-gaming ratchet (from base-branch copy)
    - Prevents test weakening, assertion removal, coverage reduction
    3. Required Checks Before Merge:

    ✅ All status checks must pass
    ✅ Code owner review required (CODEOWNERS)
    ✅ Branch protection enforced on main
    ✅ Tests cannot be merged if weakened
    4. Frequent Integration:

    Recent commits: June 25, 2026 (within 5 days)
    Recent merged PRs: #9 and #10 (2026-06-25)
    Active development cycle with regular integrations
    5. Test Automation Coverage:

    npm run check:drift # Config consistency
    npm run check:style # Code formatting
    npm test # Unit tests
    npm run agentproof # Governance benchmark (16/16)
    npm pack --dry-run # Artifact verification
    6. CI/CD Documentation:

    GitHub Actions Workflow: .github/workflows/ci.yml
    Status Badges: README.md displays CI status
    Branch Protection Rules: Enforced on GitHub
    Evidence:

    README.md line 28: CI badge showing status
    .github/workflows/ci.yml: Complete workflow configuration
    Recent PR merges showing automated test passage
    Required checks preventing merge of failing tests
    URL: https://github.com/nateshpp/modonome/blob/main/.github/workflows/ci.yml

    This is a fully-implemented CI/CD system where code changes are automatically tested on integration, meeting and exceeding the "SUGGESTED" criterion.



    プロジェクトは、選択された言語でこの基準を測定できる少なくとも1つのFLOSSツールがある場合、少なくとも80%のステートメント カバレッジを提供するFLOSS自動テストスイートを備えていなければなりません。 [test_statement_coverage90]


    選択された言語でこの基準を測定できる少なくとも1つのFLOSSツールがあれば、少なくとも80%のブランチカバレッジを提供するFLOSS自動テストスイートがプロジェクトに存在しなければなりません。 [test_branch_coverage80]

 セキュリティ 0/5

  • 優良な暗号手法を使用する

    一部のソフトウェアは暗号化メカニズムを使用する必要がないことに注意してください。あなたのプロジェクトが作成するソフトウェアが、(1) 暗号化機能を含む、アクティブ化する、または有効化し、(2) 米国(US)から米国外または米国市民以外にリリースされる可能性がある場合は、法的に義務付けられた追加手順の実行を要求される可能性があります。通常、これにはメールの送信が含まれます。詳細については、 Understanding Open Source Technology & US Export Controls「オープンソース技術と米国の輸出管理について」)の暗号化のセクションを参照してください。

    プロジェクトで作成されたソフトウェアは、ネットワーク通信すべてに対して、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(man-in-the-middle:中間者)攻撃に対応できる安全な配信


    プロジェクトウェブサイト、リポジトリ(ウェブからアクセス可能な場合)、およびダウンロードサイト(別々の場合)には、許容できない値を持つキー強化ヘッダーが含まれていなければなりません。 (URLが必要です) [hardened_site]
    GitHubやGitLabはこれを満たしていることが知られているので注意してください。https://securityheaders.com/ のようなサイトは、これをすぐに確認することができます。重要なセキュリティ強化ヘッダーは以下の通りです。Content Security Policy (CSP)、HTTP Strict Transport Security (HSTS)、X-Content-Type-Options (「nosniff」として)、および X-Frame-Options 。Web ページからログインする機能のない完全に静的な Web サイトでは、いくつかの強化ヘッダーを省略してもリスクは少なくて済みますが、そのようなサイトを検出する信頼できる方法がないため、完全に静的なサイトであってもこれらのヘッダーが必要です。

  • その他のセキュリティ上の課題


    プロジェクトは過去5年間にセキュリティレビューを実施していなければなりません。このレビューは、セキュリティ要件とセキュリティ境界を考慮しなければならりません。 [security_review]
    これは、プロジェクトメンバーおよび/または独立した評価によって行うことができます。この評価は、静的および動的解析ツールによってサポートされることができますが、ツールが検出できない問題(特に設計上)を特定するためには、人間によるレビューが必要です。


    プロジェクトによって作成されたソフトウェアで強化メカニズムを使用しなければならないので、ソフトウェア欠陥がセキュリティ上の脆弱性を引き起こす可能性が低くなります。 (URLが必要です) [hardening]
    強化メカニズムは、Content Security Policy(CSP)などのHTTPヘッダー、攻撃を緩和するコンパイラ フラグ(-fstack-protectorなど)、または未定義の動作を排除するためのコンパイラ フラグを含みます。私たちの目的のために、最低限の特権は強化メカニズムとはみなされません(最低の特権は重要ですが、別の話です)。

 分析 2/2

  • 動的コード分析


    プロジェクトは、リリース前にプロジェクトによって作成されたソフトウェアの主要な製品リリースに対して、少なくとも1つの動的解析ツールを適用しなければなりません。 [dynamic_analysis]
    動的解析ツールは、ソフトウェアを特定の入力で実行して検査します。たとえば、プロジェクトは、ファジングツール(アメリカンファジーロップなど)やウェブ アプリケーション スキャナ(例: ZAP または w3af )です。場合によっては、 OSS-Fuzz プロジェクトがプロジェクトにファズテストを適用する可能性があります。この基準のために、動的分析ツールは、様々な種類の問題を探すために何らかの方法で入力を変更するかまたは少なくとも80%のブランチ カバレッジを持つ自動テスト スイートである必要があります。 動的解析に関するWikipediaのページ ファジングに関するOWASPページで、いくつかの動的解析ツールを特定しています。解析ツールは、セキュリティの脆弱性を探すことに重点を置くことができますが、これは必須ではありません。

    Yes - Comprehensive automated test suite, but coverage not measured

    Dynamic Analysis Infrastructure:

    1. Automated Test Suite (11 test files)

    The project has extensive dynamic analysis through automated testing:

    tests/cli-dispatch.test.mjs - CLI command routing
    tests/arming.test.mjs - Arming/autonomy enablement
    tests/metrics.test.mjs - Metrics tracking
    tests/tick.test.mjs - Tick/iteration logic
    tests/run-log.test.mjs - Execution logging
    tests/prompt.test.mjs - Prompt composition
    tests/ratchet.test.mjs - Anti-gaming ratchet
    tests/packet.test.mjs - Knowledge packet handling
    tests/config.test.mjs - Config validation & migration
    tests/dry-run.test.mjs - Dry-run execution
    tests/e2e.test.mjs - End-to-end scenarios
    Total: 1,142 lines of test code

    1. Test Coverage Examples

    From tests/config.test.mjs:

    Valid config validation
    Invalid config rejection
    Safe template defaults verification
    Work-item schema validation
    YAML parser edge cases
    Migration path testing
    Arming logic (env var + config requirements)
    CLI dispatch routing
    Dry-run functionality
    3. Test Execution in CI/CD

    From package.json:

    "test": "node --test tests/*.test.mjs"
    "verify": "npm run check:drift && npm run check:style && npm test && npm run agentproof"
    All tests must pass before merge.

    1. Node.js Native Test Runner

    Using node:test (Node.js native, no external dependencies):

    import { test } from "node:test";
    import assert from "node:assert/strict";
    Gap: Code Coverage Not Measured

    ⚠️ Missing Coverage Tool - No code coverage measurement configured:

    No nyc (Istanbul)
    No c8 (V8 coverage)
    No coverage threshold enforcement
    This means:

    Tests are running dynamically with varied inputs ✅
    But we cannot verify the 80% branch coverage threshold ❓
    Recommendation to Fully Satisfy [dynamic_analysis]:

    Add code coverage measurement with c8:

    npm install --save-dev c8
    Update package.json:

    {
    "scripts": {
    "test": "node --test tests/.test.mjs",
    "test:coverage": "c8 --all --lines=80 --branches=80 node --test tests/
    .test.mjs"
    }
    }
    Then run in CI to verify 80%+ coverage:

    npm run test:coverage
    Assessment:

    ✅ Dynamic Analysis Present - Comprehensive automated test suite with 1,142 lines of test code
    ✅ Tests Execute with Varied Inputs - Tests exercise valid/invalid configs, CLI commands, arming logic, migrations
    ⚠️ Coverage Not Verified - Without coverage tool, cannot confirm 80%+ branch coverage threshold

    Summary:

    The project has excellent dynamic analysis through automated testing. Adding a code coverage tool (c8 or nyc) with an 80% threshold would formally satisfy this SUGGESTED criterion and provide confidence in test effectiveness.



    プロジェクトは、生成するソフトウェアに多くの実行時アサーションを含めるべきであり、動的分析中にそれらのアサーションをチェックするべきです。 [dynamic_analysis_enable_assertions]
    この基準は、本番環境でアサーションを有効にすることを示唆するものではありません。それは完全にプロジェクトとそのユーザーが決定することです。この基準の焦点は、展開の動的分析中の障害検出を改善することです。プロダクション環境でのアサーションの有効化は、動的分析(テストなど)中にアサーションを有効にすることとはまったく異なります。場合によっては、プロダクション環境でアサーションを有効にすることは非常に賢明ではありません(特に高整合性コンポーネントの場合)。プロダクション環境でアサーションを有効にすることには多くの議論があります。たとえば、ライブラリは呼び出し元をクラッシュさせてはなりません。ライブラリが存在するとアプリストアによる拒否が発生する可能性があります。また、プロダクション環境でアサーションをアクティブにすると、秘密鍵などの秘密データが公開される可能性があります。多くのLinuxディストリビューションではNDEBUGが定義されていないため、これらのディストリビューションのプロダクション環境ではデフォルトで C/C++ assert() が有効になります。これらの環境でのプロダクション環境では、別のアサーションメカニズムを使用するか、 NDEBUGを定義することが重要です。

    Answer: Yes - Comprehensive assertions enabled during testing, disabled in production

    Assertion Usage in Testing:

    1. Strict Assertion Mode

    All test files use Node.js strict assertions:

    import assert from "node:assert/strict";
    From tests/config.test.mjs:

    assert.deepEqual(validateConfig(readJson(f)), [], expected valid: ${f});
    assert.ok(validateConfig(readJson(f)).length > 0, expected invalid: ${f});
    assert.equal(cfg.autonomy_enabled, false);
    assert.equal(cfg.dry_run, true);
    assert.equal(cfg.auto_merge, false);
    2. Assertion Types in Use

    assert.equal(actual, expected, message) // Strict equality
    assert.deepEqual(actual, expected, message) // Deep equality (objects/arrays)
    assert.ok(value, message) // Truthy check
    assert.throws(fn, error, message) // Exception thrown
    assert.doesNotThrow(fn, message) // No exception thrown
    3. Coverage Areas with Assertions

    From test files:

    Config validation: Valid/invalid configurations tested with deep equality checks
    Arming logic: Strict checks on autonomy enablement conditions
    CLI dispatch: Assertions on command routing
    Template defaults: Verification that safe defaults are in place
    Migrations: Path validation and state assertions
    Schema compliance: Work-item validation with detailed assertions
    4. Test Execution Configuration

    From package.json:

    "test": "node --test tests/*.test.mjs"
    Node.js runs tests with full assertion checking enabled. No production assertions means:

    Testing: ✅ All assertions active
    Production: ✅ No assertion overhead
    5. Strict Mode for Maximum Fault Detection

    Using assert/strict (not assert) provides:

    Stricter equality comparisons
    Better error messages
    Fails immediately on assertion failure
    This maximizes fault detection during dynamic analysis.

    Production Separation:

    The project cleanly separates testing from production:

    Context Assertions Configuration
    Testing ✅ Full assertions node:assert/strict
    Production ✅ None No assertion imports
    Source code No assertions Pure functional logic
    Assessment:

    ✅ Assertions Enabled in Dynamic Analysis - Comprehensive strict assertions in all 11 test files
    ✅ Disabled in Production - No assertion overhead in production code
    ✅ 1,142 Lines of Assertion Tests - Extensive fault detection during testing
    ✅ Zero Production Risk - Assertions only in test files, never in shipped code

    Summary:

    The project excels at this SUGGESTED criterion. It uses strict Node.js assertions extensively during dynamic analysis (testing) while keeping production code clean of assertion overhead. This enables maximum fault detection during testing without impacting production performance or reliability.



このデータは、Community Data License Agreement – Permissive, Version 2.0 (CDLA-Permissive-2.0)のもとで利用可能です。これは、データ受領者が、データ受領者がこの契約のテキストを共有データとともに利用可能にする限り、変更の有無にかかわらずデータを共有できることを意味します。nateshppおよびOpenSSFベストプラクティスバッジのコントリビューターにクレジットを表示してください。

プロジェクト バッジ登録の所有者: nateshpp.
エントリの作成日時 2026-06-24 16:08:26 UTC、 最終更新日 2026-06-30 14:05:18 UTC