コミュニティ貢献を扱うワークフロー

DevRel Engineering が扱うすべてのプロセス

ワークフロー

リアルタイムコミュニケーション

GitLab への貢献に興味がある人々のために、Discord で GitLab 貢献者ルームが利用できます。これは誰でも参加でき、コミュニティメンバーがネットワーキングし、互いに助け合うのに良い場所です。

Issue

貢献者リンク

誰もが貢献することを明確で簡単にするため、triage-ops プロセッサ が Issue に貢献者リンクを追加し、お客様/コミュニティメンバーがラベル付け、クローズ、自身への割り当てを行えるようにします。

GitLab チームメンバーではなく、ここでの初心者で、GitLab への機能、バグ修正、翻訳などの貢献を始めたいと思っていますか? 貢献者プラットフォームからオンボーディングを開始してください。

GitLab チームメンバーは、suppress-contributor-links ラベルを追加することで貢献者リンクを抑制できます。

コミュニティ貢献者向けの Issue ラベル付け

広範コミュニティの貢献を求めるに関するガイダンスと、quick win Issue の基準を参照してください。

コミュニティ Issue ワークフローの手動プロセス

部分的な Issue トリアージチェックリストを参照してください。

マージリクエスト

広範コミュニティのマージリクエストとは、https://about.gitlab.com/company/team/ に存在しない人 (任意のボット、サービスアカウントユーザー、または個人契約者を除く) が開いた MR です。

ラベル

トリアージレポート

コミュニティ関連のトリアージレポートを参照してください。

スケジュールされたワークフローオートメーション

コミュニティ関連のスケジュールされたワークフローオートメーションを参照してください。

リアクティブワークフローオートメーション

コミュニティ関連のリアクティブワークフローオートメーションを参照してください。

マージリクエストコーチ

マージリクエストコーチは、貢献者の MR を支援するために利用可能です。これには次のことが含まれます:

  • MR のレビュアーを特定する。
  • 貢献者からの質問に回答する。
  • 貢献承認基準について貢献者を教育する。
  • または、貢献者が応答しないか完了できない場合に MR を完了する。
    • その場合、coach will finish ラベルが MR に追加され、コーチは新しいコミットを直接 MR にプッシュするか、元の変更を含む新しい MR を再作成します。
    • 貢献者は MR で @gitlab-org/coaches と入力することでコーチをメンションできます。

現在のマージリクエストコーチのリストは、チームページで部門フィルタの Merge Request Coach を選択することで見つけることができます。

GitLab チームメンバーがコミュニティ貢献に関する質問がある場合は、GitLab Slack の #mr-coaching チャンネルもあります。

マージリクエストコーチに関する詳細情報 (マージリクエストコーチになる方法を含む) は、MR コーチライフサイクルページで見つけることができます。

GitLab Enterprise Edition (EE) への貢献

コミュニティ貢献者向け

GitLab Enterprise Edition の任意の有料機能に貢献するには、コミュニティ貢献者は GDK にライセンスを追加する必要があります。すでにライセンスを持っていない場合は、30 日間の無料トライアルを取得できます (Self-Managed オプションを選択)。30 日間で作業を完了できない場合は、限定数のユーザー (100) 向けに 90 日間の新しい EE ライセンスを発行できます。

このライセンスの更新:

  • 前回のライセンスサイクルでアクティブな貢献があった場合、このライセンスはさらに 1 年間更新できます。
  • 前回のライセンスサイクルでアクティブな貢献がなかった場合、90 日間の更新が許可されます。

貢献者は、ライセンスをリクエストするためにこのプロジェクトでリクエストを作成する必要があります: Wider Community Contributor License Request

Enterprise Edition (EE) ライセンスリクエストの処理

GitLab チームメンバーが完了する必要があります:

前提条件

プロセス

  • Okta 経由で Zendesk にログイン
  • GitLab L&R Internal Requests フォームにアクセス
  • 続くドロップダウンリストから Other > Wider community license を選択
  • リクエスト Issue で提供された必須フィールドを入力
    • 連絡先情報: リクエストする貢献者の情報を使用
  • その他の必須フィールド:
    • True-up: 0
    • リクエストの優先度: Low
    • ライセンスタイプ: Ultimate (特に指定がない限り)
    • 有効期限:
      • 新規貢献者は 90 日
      • 更新は 1 年
    • 1 年更新の場合、Nick の E メールを承認マネージャーとして使用
  • 「ライセンスが発行される理由は何ですか?」で、Wider community contributor EE license request を指定し、ライセンスリクエスト Issue へのリンクを追加
  • リクエスト Issue にリクエストが提出されたことを示すパブリックコメントを追加
  • サポートフォームを送信すると、Zendesk でリクエストを「作成」するパイプラインへのリンクがユーザーに表示されます。後で調査が必要な問題があった場合に備えて、このパイプラインへのリンクを内部コメントに保存

サポートチームは、24 時間以内にこのワークフローに従って応答します。

クローズ

ライセンスがプロビジョニングされたら:

  • ライセンスリクエストがプロビジョニングされたという確認のパブリックコメントを Issue に追加
  • サポートから送信された E メールに含まれる「Private Note」のスクリーンショット付きの機密コメントを追加
  • Issue をクローズ

DCO と CLA のガイダンス

GitLab への外部貢献はすべて、貢献が行われた場所と誰の代理で行われたかに応じて、GitLab の DCO または CLA の対象となります。

組織を代理で行われたすべての貢献をカバーする包括的な企業 CLA を締結する企業貢献者向けの手順は、DCO-CLA ページに記載されています。

企業 CLA 貢献者管理

Contributor success は、Legal and Corporate Affairs チームを支援して、GitLab が企業 CLA に関連付けられたユーザーのリストを維持できる名前空間の作成と維持を行ってきました。

このグループはここで見つけることができます: https://gitlab.com/gitlab-corporate-cla

新しいグループの追加

この名前空間下に新しい企業グループを追加するには、次のようにします:

  1. 組織名と一致する名前/スラッグでサブグループを作成します。
  2. 新しいサブグループの可視性が Private に設定されていることを確認します。
  3. 作成後、サブグループを編集 (Settings > General) し、グループ説明にテキスト Approved contributors for XXXXX under the GitLab Corporate CLA を追加します。
  4. 次の設定を確認/設定します:
    1. General > Permissions and Group Features
      1. Permissions - Group mentions are disabled
      2. Wiki - Group-level wiki is disabled
      3. Roles allowed to create projects - No one
      4. Roles allowed to create subgroups - Owner
      5. Customer relations is enabled - disabled
      6. Membership - Users can request access (disabled)
      7. GitLab Duo availability - Always off
  5. 組織の指定されたユーザーマネージャーのユーザーアカウントを Owner としてグループに追加します。(Subgroup information > Members の下)
  6. ご自身のユーザーアカウントをサブグループの直接メンバーから削除します。(Group owners の下、Membership = Direct でフィルタし、‘kebab メニュー’ をクリックして ‘Leave Group’ を選択)

教育資料

  1. Gitpod with GDK - Introduction (ビデオ)
  2. Gitpod with GDK - Setup (ビデオ)

GitLab Notable Contributor 選定プロセス

GitLab Notable Contributor 選定プロセスを参照してください。

貢献者への感謝メッセージ

Contributor Success チームは、マージリクエストへの活発な参加について広範コミュニティメンバーに定期的に感謝してきました。 これは、次の場所での週次感謝メッセージという形を取ります:

  • discord の #thanks チャンネル。
  • フォーラムの community エリア。

MR をマージしてもらった広範コミュニティメンバーや、マージされた他の MR に参加した広範コミュニティメンバーに感謝します。

これらのメッセージは、スクリプトの助けを借りて生成されます。 スクリプトは月曜日の朝に実行されます。

トラッキング Issue:

手動実行

メッセージを手動で生成する必要がある場合は、次の前提手順に従う必要があります:

  1. toolbox プロジェクトの最新の main ブランチをチェックアウト: git clone [email protected]:gitlab-org/developer-relations/contributor-success/toolbox.git

  2. チェックアウトしたプロジェクトのディレクトリに変更: cd toolbox

  3. 必要な gem をインストール: bundle install

  4. ここの ‘wider’ の例に従ってスクリプトを実行

  5. レポートを実行する期間を必ず確認してください。

  6. 結果のメッセージを discord の #thanks に貼り付け。

  7. 貼り付けたメッセージをダブルチェックして、ユーザー/名前がすべて「正しい」ように見えることを確認。

  8. メッセージを送信して、お祝いに参加!

  9. 必要に応じて、メッセージから PI 数をトラッキング Issue に記録。

  10. トラッキング Issue の担当者と期日を更新。

イベントの組織化と宣伝

イベント計画

  • ミーティング前にアジェンダを起草します (ドキュメントがリンクのある全員に開いていることを確認してください)
    • 出欠確認、紹介
    • 各種トピック
    • コミュニティがトピックを持ち寄れるオープンフロア
  • 参加方法の手順を含めます
    • Zoom (または他のビデオプラットフォーム) へのリンク
  • イベントをデベロッパーアドボカシーチームカレンダーに追加します。GitLab チームメンバーでない場合は、デベロッパーリレーションズチームのメンバーにイベントをカレンダーに追加するよう依頼してください。
  • ソーシャルサポートのために以下の手順に従うか、コードコントリビューターのプランニングリポでリクエストを開きます。

ソーシャル

  • 「Join the upcoming GitLab hackathon (link) on the N.」のような短いアクション指向のコピーを起草します。
  • イベントの少なくとも 2 週間前、1 週間前、前日に、次のチャンネルでメッセージを共有します:
    • Twitter: 自分のアカウントを使用しますが @gitlab をメンションします (注: Twitter で Zoom リンクを共有しないでください)
    • GitLab Community Discord

イベントプラットフォーム

ハッカソン

GitLab コミュニティメンバーが集まり、マージリクエストに取り組み、チュートリアルセッションに参加し、GitLab Discord で互いをサポートする四半期ごとのハッカソンがあります。ハッカソンのアジェンダ、ロジスティクス、資料、録画、その他の情報は GitLab Community Hackathon ページで利用できます。

イベントの計画は、ハッカソン Issue テンプレートに従って行われます。

バーチャルハッカソン/hackathon-in-a-box

私たちは広範コミュニティメンバーが GitLab への新しい貢献者を奨励し、サポートするためにイベントを組織化することも奨励しています。これは、対面またはバーチャル GitLab ミートアップの一部として行うことができます。

広範コミュニティメンバーがハッカソンをミートアップの一部として含めることに興味がある場合は、ミートアップ Issueを開く際にこの情報を含めるように依頼してください。Contributor Success チームメンバーがオーガナイザーに連絡し、イベントをサポートするために必要なリソースを提供します。

利用可能なリソースの一部は、hackathon-in-a-box フォルダGDK チュートリアルプレイリストなどで見つけることができます。プログラムマネージャーはオーガナイザーと協力して、初めて/経験の浅い貢献者に良い Issue のリストを作成し、イベント前に参加者と共有する必要があります。また、イベント中にマージリクエストを作成した人に配布できる GitLab グッズについて、オーガナイザーと連携する必要があります。

コミュニティオフィスアワー

広範コミュニティと GitLab チームメンバー間のコミュニケーションを促進するために、製品チームはコミュニティオフィスアワーをホストすることがあります。これらのオフィスアワーの目的は、製品/開発に関する広範コミュニティのフィードバックを集め、広範コミュニティの貢献を議論し、MR のバックログをレビューし、その他のトピックを話し合うことです。オフィスアワー関連の Issue または MR には、これらの例で見ることができるように、Office Hours ラベルが付きます。

通話は誰でも利用可能で、通話後に録画が投稿されます。このプレイリストで過去のオフィスアワーの例をご覧ください。コミュニティがビデオを見つけやすくするために、各ステージは独自のオフィスアワーのプレイリストを作成し、ハンドブックページからリンクする必要があります。

すべてのコミュニティオフィスアワー通話は、デベロッパーアドボカシーカレンダーmeetup.com グループに追加する必要があります。

コミュニティオフィスアワー通話の組織化方法

準備

通話の実行

  • 通話のライブストリーミングについて全員の許可を求めます。次に、Zoom で「YouTube でライブ配信」ボタンを押してストリーミングを開始します。
  • アクセシビリティのために Zoom でクローズドキャプションを有効にします。
  • 通話が始まったら、「何があなたをこの通話に連れてきましたか」という質問で自己紹介のラウンドを行います。これは、コミュニティのニーズに合わせて通話を調整し、彼らの質問/期待に応えるのに役立ちます。
  • 詳細な議事録を保持します

通話後

  • YouTube ビデオを「office hour calls」プレイリストに追加します
  • Discord にまとめとビデオ録画を投稿します

コミュニティチャレンジ

(ハッカソン中だけでなく) 継続的に優先 Issue への貢献を促すため、各製品ステージに最大 5 つの優先 Issue のリストを維持し、これらの Issue について MR がマージされた広範コミュニティメンバーに賞品が贈られます。これらの Issue にはラベル Community challenge と、賞品、これらの Issue の割り当てなど、より多くの詳細が記載されます。

広範コミュニティ貢献者のサポート

広範コミュニティの貢献のブロック解除

誰もが貢献できるという GitLab のミッションに従って、Contributor Success チームは広範コミュニティ貢献者のブロックを解除し、貢献を前進させるのを支援します。GitLab の他のチームがコミュニティ貢献をサポートする能力を持っていないことがありますが、これによってコミュニティの貢献を止めるべきではありません。

これら 10 個の GitLab の価値観が、広範コミュニティのブロック解除と前進を支援する努力をサポートします:

  1. 自分でやる
  2. Short toes
  3. Collaboration is not consensus
  4. 行動バイアス
  5. Disagree, commit, and disagree
  6. Escalate to unblock
  7. Cleanup over sign-up
  8. Minimal valuable change
  9. Everything is in draft
  10. Make two-way door decisions

広範コミュニティの貢献を求める

支援を求める GitLab チームメンバーは、貢献を求めて広範コミュニティに連絡することができます。より大きなプロジェクトのリクエストに移る前に、明確な実装計画を持つより小さな quick win Issue から始めることが推奨されます。

  • quick win Issue の基準に従って、Issue に quick win ラベルを追加します。
  • GitLab Community Discord の #contribute チャンネルで Issue を共有します。
  • コミュニティ貢献者が興味を示したら、彼らを Issue に割り当てます。
  • コミュニティ貢献者と連絡を取り、助けが必要かどうかを確認します。

quick win Issue の基準

GitLab は広範コミュニティに、貢献したい場合は quick win ラベルが付いた Issue を検索するようガイドしています。これらの Issue は、コミュニティ貢献者にとってわかりやすく、貢献プロセスを学びながら完了するのに十分速いことを意図しています。これは、誰もが貢献し、初回貢献者がコミュニティでオンボーディングするのをサポートするGitLab のミッションに従っています。GitLab Bot はこの基準の維持を支援し、Issue が要件を満たさない場合に quick win ラベルを削除します。機械的にシンプルに見えるが、ドメイン固有のロールアウト判断が必要な Issue は quick win ではありません。

  • Issue の説明には、貢献者が始めるのを助けるガイダンス付きの実装計画を、第二または第三レベルの見出しとして含める必要があります。 たとえば、## Implementation### Implementation## Implementation plan### Implementation guide はすべて受け入れられます。 このセクションは非常に簡潔でも、Issue を解決するための可能なアクションを提供してもかまいません。
  • Issue には 0-3 のウェイトを割り当てる必要があります。 Issue ウェイトは、複雑さと必要な努力を概算する必要があります。 ウェイトを時間の見積もりに関連付けないでください。
  • 貢献者が質問したりメンタリングを受けたりできるよう、GitLab チームメンバーまたは経験豊富なコミュニティ貢献者を連絡先として含めることを検討してください。

quick win::first-time contributor Issue の基準

オンボーディングプロセス中、新しい貢献者は quick win::first-time contributor Issue にリンクされます。これらの Issue は、私たちの最も簡単で最もわかりやすい Issue を使用して、新しい貢献者が貢献プロセスを学ぶのを助けることを目的としています。quick win::first-time contributor Issue を作成する際は、サポート連絡先を追加することが推奨されます。 各貢献者は 1 つの quick win::first-time contributor Issue のみを完了できます。最初の Issue を完了した後、貢献者は他の Issue に移るべきです。通常の quick win Issue には制限はありません。

  • Issue の説明には、貢献者が始めるのを助けるガイダンス付きの実装計画を、第二または第三レベルの見出しとして含める必要があります。 たとえば、## Implementation### Implementation## Implementation plan### Implementation guide はすべて受け入れられます。 このセクションは非常に簡潔でも、Issue を解決するための可能なアクションを提供してもかまいません。
  • 少なくとも 1 人の GitLab チームメンバーまたは経験豊富なコミュニティ貢献者 (たとえば「Support contact: @username」) を Implementation plan セクションでタグ付けすることが推奨されます

初回貢献者

貢献者が GitLab 名前空間に対して初めてマージリクエストを開くたびに、ラベル「~1st contribution」が自動的にマージリクエストに適用されます。

Core チームとの作業

Core チームに関する詳細情報は、Core チームハンドブックページで利用できます。

貢献者向け GitLab Duo

誰もが貢献できるという私たちのミッションをサポートするため、私たちはすべての広範コミュニティ貢献者向けに、GitLab コミュニティフォーク全体で無料の GitLab Duo Enterprise ライセンスを提供しています。 GitLab Duo は、Code Suggestions、Chat、Root Cause Analysis など、コードとパイプラインの記述・理解に必要な時間を削減することで効率と効果を高める、AI を活用した機能を備えています。 コミュニティ貢献者は、コミュニティフォークへのアクセスをリクエストした後に承認されると、GitLab Duo を受け取ります。

製品ボーナスによる高価値貢献のハイライト

これは FY25Q4 (2024 年 11 月 - 2025 年 1 月) に実施する実験です。

高価値の貢献方向をハイライトするために、Contributor Success チームは、特定の期間内に自分の領域の貢献者に与えることができる、製品マネージャー (PM) 向けの専用予算を設定する場合があります。全体の予算は、ユーザー向け製品ステージ全体に均等に共有され、PM はラベル (community-bonus::100community-bonus::200community-bonus::300community-bonus::500) を適用して、特定の Issue/エピックにどれだけの価値を与えるかを示すことができます。ボーナスは Issue がクローズされたときに会計され、エピックの場合、Contributor Success チームは関連する PM が議論したように、特定の Issue に対してボーナスの一部を渡すことができます。PM は Issue を選択する際、予算内に留まることが期待されます。

ボーナスは貢献後にも与えることができます。

このコンテキストでのボーナスは金銭的な助成金ではありません。これらのボーナスポイントは、貢献者ストアでの購入にのみ使用できます。

プロセス

コミュニティボーナスラベルが付いた Issue がクローズされると、トリアージレポートに表示されます。Developer Relations Engineering チームメンバーは:

貢献を検証する
  • Issue を訪問し、広範コミュニティ貢献者に割り当てられていることを確認します。
  • リンクされたマージリクエストが広範コミュニティ貢献者によって作成されたことを確認します。
  • 上記が明確であれば、ボーナスポイントを授与に進みます。
  • 上記が真でない場合、community-bonus:: スコープラベルを削除します。
  • 不確実な点がある場合は、Issue で関連チームに ping して確認します。
ボーナスポイントを授与する
  • https://contributors.gitlab.com/users/[GitLab username] に移動
  • Bonus Points までスクロール
  • Add points をクリック
    • 理由として Issue リンクを使用
    • ボーナスポイント数を入力
    • アクティビティタイプとして Community bonus を選択
    • Add points を選択
  • 授与したポイントが Bonus Points セクションに表示されることを確認
  • GitLab で、Issue に community-bonus-awarded ラベルを追加

クレジットカードを所有していない貢献者向け

クレジットカードを所有しておらず、手動で検証する必要がある貢献者には、 登録して サポートリクエストを発行するよう依頼します Gitlab.com user accounts and login issues の理由を使用します。

コンピュート分または他の CI/CD リソースを使い切った貢献者向け

広範コミュニティメンバーは、個人フォークから作業している場合、月次のコンピュート分を使い切ったり、他の GitLab CI/CD 制限に遭遇することがあります。

解決策は、GitLab コミュニティフォークから作業することです。

貢献者への連絡

貢献者のプライバシーを尊重するため、彼らに連絡するために公開されている連絡データのみを使用します。

貢献者に連絡する方法をいくつか紹介します:

  • GitLab ユーザー名を使用して Issue で彼らをメンションできます。
  • 私たちのコミュニケーションプラットフォーム (Discord、Slack など) を介してプライベートに。
  • ユーザーは GitLab プロフィールに E メールを持っている場合があります。場合によっては、ユーザーは他のプラットフォーム (例: GitHub) で同じユーザー名を持っており、そのプロフィールにより多くの情報がある場合があります。
  • プライベートコミット E メールを使用することを選択しない限り、E メールアドレスは git コミットに保存されます。

連絡する最良の方法を見つけたら、メンション、E メール、または Discord を使うことを選択できます。

貢献者ブログ投稿シリーズ

目標は、コミュニティの貢献者を取り上げる定期的なブログ投稿を発行することです。フォーマットはコミュニティメンバーとのカジュアルな Q&A で、GitLab ブログページに投稿されます。

ブログ投稿を開発する際は、ブログガイドラインに従ってください。

貢献者アウトリーチキャンペーン

アウトリーチキャンペーンは、貢献を停止した過去の GitLab 貢献者や、貢献に興味を表明したが始めていないユーザーと再びつながるのに役立ちます。 連絡する際、彼らの過去および/または将来の貢献を認識して、彼らの名前で GitLab forest に木を植えます。

アウトリーチの目標

Contributor Success チームは、繰り返し可能なアウトリーチキャンペーンを作成するために、3 つの目標で異なる基準とメッセージを試しました:

  1. 新しいマージリクエストを開くコミュニティメンバーを最大化
  2. キャンペーンを実行する Contributor Success の時間コミットメントを最小化
  3. アウトリーチキャンペーンが迷惑になったり、マーケティングスパムのように見えたりするのを防ぐ

復帰貢献者の候補基準

  • 過去 3 か月間に開かれたマージリクエストが 0 件
  • 過去 12 か月間に 2 件以上のマージリクエストがマージされている必要がある
  • 以前にアウトリーチキャンペーンで連絡されていない

新規貢献者の候補基準

  • 少なくとも 1 か月前にコミュニティフォークへのアクセスをリクエストして受け取った
  • 履歴にマージされたマージリクエストがない
  • 以前にアウトリーチキャンペーンで連絡されていない

結果の追跡

アウトリーチキャンペーンの結果は、アウトリーチ結果スプレッドシート で追跡され、すべてのアウトリーチキャンペーンに関するレポート Issue で報告されます。

復帰貢献者キャンペーンの結果

アウトリーチキャンペーン基準アウトリーチ総ユーザー復帰ユーザーユーザー復帰率マージ済み MR開かれた MRクローズ MR
2023 年 12 月6 か月アイドル49714.29%1102
2024 年 1 月3 か月アイドル124129.68%1522
2024 年 4 月3 か月アイドル40512.50%1211

新規貢献者キャンペーンの結果

アウトリーチキャンペーン基準アウトリーチ総ユーザー復帰ユーザーユーザー復帰率マージ済み MR開かれた MRクローズ MR
2024 年 4 月0 件の貢献27462.19%421

結果に関する観察

  • これまでのところ、復帰貢献者キャンペーンは平均ユーザー復帰率 11%、24 名の復帰貢献者、38 件のマージ済みマージリクエストで成功しています。
  • 4 月の新規貢献者キャンペーンでの実験は 2% の貢献率と低調でした。
    • このキャンペーンには、ユーザーがコミュニティフォークアクセスをリクエストしてからどれくらい前かの時間制限がなく、多くのユーザーがおそらく始めることへの興味を失っていました。
    • 復帰貢献者は、マージリクエストを開く点で新規貢献者よりも成功しやすいことが予想されます。
  • 開かれたマージリクエストとマージされたマージリクエストの結果に加えて、Issue でのユーザーエンゲージメント、オンボーディングタスクの完了、植樹への感謝を観察しました。
  • 多くの貢献者は、これらの結果に表示されるためにアウトリーチから 1 か月以内にマージリクエストを作成する空きがないでしょう。キャンペーンは、後で貢献する機会の前向きなリマインダーになる可能性があります。

アウトリーチキャンペーンのスケジュール

アウトリーチキャンペーンは 3 か月ごとに実行することを目指していますが、貢献者を引き付ける可能性のある発表と一致させる必要があります。 たとえば、今後のハッカソンや、GDK-in-a-box のような新しい貢献機能を発表します。

アウトリーチキャンペーンのワークフロー

候補プールのレビュー

Contributor Success チームは、次のものを削除するために候補プールをレビューします:

  • GitLab アカウントまたは個人アカウントのいずれかを持つ既知の GitLab チームメンバー
  • 失効したが、キャンペーンの外で別途連絡される必要がある長期貢献者 (例: Core メンバー、元 MVP、GitLab Heroes など)
  • 行動規範違反があった、連絡されたくない、または GitLab に貢献したくないと表明した既知のコミュニティメンバー

Issue を作成して木を植える

アウトリーチ Issue への対応とクローズ

  • アウトリーチ Issue で質問に回答するか、フィードバックを認識します
  • 2 か月後にクローズメッセージで Issue をクローズし、貢献者が Issue を再オープンしてサポートが必要な場合は連絡するよう促します

潜在的なイテレーション

  • ロール基準または除外候補リストに対して候補をチェックすることで、自動化により手動レビューステップを削減
  • アウトリーチキャンペーン後に貢献するユーザーをそれぞれの Issue で感謝し、戻ってきた理由を共有する機会を与える

貢献者の表彰

ハイライトされた貢献への感謝

時々、広範コミュニティメンバーが特に優れた貢献を提出します。任意の GitLab チームメンバーまたは広範コミュニティが、彼らを Notable Contributor として推薦するプロセスに従うことができます。

年間トップ貢献者

定期的な貢献者を認識するため、各暦年のトップ貢献者のリストが Top Annual Contributors ページ に公開されます。トップ貢献者には 3 つのカテゴリがあります:

  • SuperStar: 75 件以上のマージ済み MR
  • Star: 11 件から 75 件のマージ済み MR
  • Enthusiast: 5 件から 10 件のマージ済み MR

これらの貢献者向けにカスタマイズされた GitLab グッズが作成され、Printfection で利用可能になります。GitLab チームメンバーは、以下の手順に従って広範コミュニティメンバーに賞を送ることができます。

  1. 1Password の認証情報を使用して Printfection にログインします。
  2. Campaigns の下の Giveaways に移動し、新しい GIVEAWAY CAMPAIGN を作成します (複数のアイテムを含めたい場合は、Merchandise タブの下に新しい Kit を作成する必要があるかもしれません)。
  3. アイテム/キットをキャンペーンに追加します。
  4. 各貢献者用の Giveaway リンクを生成します。
  5. 個別の E メールに Giveaway リンクを含めて Top Annual Contributors に送信します。

貢献者ライフサイクルセグメント

GitLab コードコントリビューターコミュニティを理解、サポート、エンパワーする取り組みにおいて、次のライフサイクルセグメントを考えました。

これらのライフサイクルセグメントは個々のユーザーレベルで割り当てられます。

貢献者の経験レベルマージ済み MR
Level 00 MR
Level 11 - 3 MR
Level 24 - 25 MR
Level 326 - 75 MR
Level 475+ MR
貢献者ステータスマージ済み MR期間
カジュアル貢献者< 10 MR過去 6 か月
通常貢献者10+ MR過去 6 か月
リーディング貢献者20+ MR過去 6 か月
Core選挙ベース全期間

貢献者コミュニティをセグメント化することで、貢献者がこのファネル全体でどのように「移動」しているか、そして彼らのジャーニーを通じてどのようにサポートできるかをよりよく理解できるようになります。

目標は、貢献者をサポートし表彰する方法を特定することにより、すべてのセグメント (非アクティブセグメントを除く) でコードコントリビューターを増やすことです。

貢献者メトリクス

注: これは現在、貢献者メトリクスを収集できるすべての場所の作業リストです。これはまだ貢献者プログラムの成功をモニタリングするために使用するメトリクスの最終セットではありません。

Tableau ダッシュボード

社内では、GitLab はさまざまな KPI のパフォーマンスを追跡するために Tableau を使用しています。以下は、コミュニティ関連ダッシュボードのリストです。

ダッシュボード説明
Wider Community Dashboard貢献者 (人) と組織に関連するメトリクス
MRARR DashboardGitLab の顧客でもある貢献組織に関連するメトリクス

GitLab.com

gitlab.com 上のプロジェクト (たとえば CE、EE、Omnibus、Shell など) の Merge Requests ページからデータを直接クエリし、マイルストーン、ラベルなどに適切なフィルタを適用することもできます。例の一部は、以下のメトリクステーブルに記載されています。

貢献者数

過去には、この例で見られるように、GitLab コミュニティ (GitLab チームメンバー + 広範コミュニティ) の 2,000 以上の貢献者をしばしば言及していました。しかし、これには古い https://contributors.gitlab.com ページに基づいて、CE および EE プロジェクトへの貢献者のみが含まれていました。

他の GitLab プロジェクトを含めると、貢献者の総数ははるかに多くなります。

  • 総コードコントリビューター: GitLab チームメンバーと広範コミュニティ貢献者を含む (2015 年以降)

  • 広範コミュニティコードコントリビューター: 広範コミュニティ貢献者のみを含む (2015 年以降)

  • これらの数値は、マージリクエストがマージされたか、クローズされたか、まだオープンかに関係なく、少なくとも 1 つのマージリクエストを開いた貢献者をカウントします。

  • 成功した貢献 (マージリクエストがマージされた) を持つ広範コミュニティコードコントリビューターの数は、Wider Community Dashboard を見ることで見つけることができます。

  • 広範コミュニティメンバーの定義の更新については、トップ誤用語ページを参照してください。

GitLab の貢献者数について人々が尋ねたとき、彼らが総コードコントリビューターまたは広範コミュニティコードコントリビューターについて尋ねているかを明確にするのが最善です。ほとんどの場合、人々は広範コミュニティの数により興味を持つ傾向があります。

Contribute to GitLab ガイドに記載されているように、コード以外にもコミュニティが GitLab に貢献する方法があることに言及することも重要です。翻訳、エバンジェリズム、フォーラムでのサポート、開かれた Issue などの貢献は、上記のメトリクスには含まれていません。

モニタリング対象のプロジェクト

私たちは gitlab-org グループのさまざまなプロジェクトでの貢献を監視・表彰しており、GitLab プロジェクトだけではありません。

一般的なルールとして、プロジェクトは gitlab-org グループのマイルストーンと Community contribution ラベルを使用している場合、広範コミュニティ貢献を監視するためにセットアップされます。

モニタリング対象の gitlab-org グループプロジェクトの網羅的なリストを参照してください。

GitLab への貢献に興味がありますか? 利用可能な貢献機会はこちらで確認してください。