統合機能

Webhooks (Strings)

本コンテンツはPhrase Language AIの機械翻訳により、英語から翻訳されています。

利用可能対象

  • Team、Professional、Business、Enterpriseプライズプラン

ライセンスに関する質問は、営業担当までお問い合わせください。

ウェブフックは、チャットクライアントやその他の外部APIなどの外部サービスにイベントを通知します。ウェブフックは、特定のイベントが発生したときに URL を設定できます。

File uploads only trigger the uploads:作成 および  uploads:処理ウェブフック イベント。

ウェブフック履歴には30日間の保存期間があります。

ウェブフック応答

ウェブフック エンドポイントは、コールバックを受け取ってから 5 秒以内に 200 ~ 299 の範囲の HTTP ステータス コードを返す必要があります。その他のステータス コードやリクエスト タイムアウトは、配信失敗と見なされます。ウェブフックは、10 回以上連続して配信に失敗した場合、非アクティブになります。コールバックは繰り返されません。

コールバックを受信した場合は、5 秒のリクエストタイムアウト時間内に応答してください。アプリケーションが誤ってタイムアウトを発生させないように、HTTPレスポンスが送信されるまで処理を保留します。

ウェブフック要求の整合性

各ウェブフック要求には、要求で送信されるデータとともに、ウェブフック検証トークンをシークレットとして使用して生成される X-PhraseApp-Signature ヘッダーが含まれます。要求ボディの HMAC ダイジェストを計算し、X-PhraseApp-Signature ヘッダーの値と比較して、要求の送信元を検証します。

例:

Ruby

def verify_webhook(signatureheader)
  digest = OpenSSL::Digest::Digest.new('sha256')
  hmac = OpenSSL::HMAC.digest(digest, VERIFICATION_TOKEN, request.body)
  hmac = Base64.encode64(hmac).strip
  hmac == signatureheader
end

PHP

function verify_webhook($signatureheader){
  $hmac = hash_hmac('sha256', $requestBody, $verificationToken, true);
  $hmac = trim(base64_encode($hash));
  return $hmac == $signatureheader;
}

ウェブフックイベント

イベント名

概要

ブランチ:作成

ブランチが作成されました。

branches:merge

ブランチがマージされました。

コメント:作成

翻訳キーのコメントが追加されました。

custom_metadata_values:batch_update

カスタムメタデータフィールドの値が複数のキーで更新されました。

custom_metadata_values:update

カスタムメタデータフィールドの値がキーで更新されました。

ジョブ:完了

ジョブが完了済になりました。

ジョブ:作成

ジョブが作成されました。

ジョブ:ロケール:完了

ジョブのロケールが完了済になりました。

ジョブ:ロケール:再度開かれた

ジョブのロケールが再度開かれました。

ジョブ:ロケール:レビュー:完了

ジョブのロケールがレビュー済かつ完了済になりました。

ジョブ:ロケール:レビュー:再度開く

ジョブのロケールがレビュー済かつ再度開かれました。

ジョブ:再度開かれた

ジョブが再度開かれました。

ジョブ:開始

ジョブが開始されました。

ジョブ:更新

ジョブが更新されました。

keys:batch_delete

複数のキーが削除されました。

キー:作成

キーが作成されました。

キー:削除

キーが削除されました。

キー:更新

キーが名前または変更されました。

locales:create

新しい言語バージョンがプロジェクトで作成されました。

locales:delete

言語バージョンが削除されました。

locales:update

言語バージョンが変更、名前変更、または再設定されました。

リリース:作成

OTAリリースが作成されました。

リリース:削除

OTAリリースは削除されました。

screenshots:create

スクリーンショットを作成しました。

screenshots:delete

スクリーンショットが削除されました。

screenshots:update

スクリーンショットが変更または名前変更されました。

translations:batch_review

翻訳の一覧がレビュー済されました。

translations:batch_unreview

翻訳の一覧が未レビューです。

translations:batch_unverify

翻訳の一覧が未検証です。

translations:batch_verify

翻訳の一覧は検証済みです。

translations:create

特定の言語バージョンのキーの翻訳が追加されました。

translations:deliver

特定の言語バージョンのキーの翻訳が言語サービスプロバイダによって納品されました。

translations:review

特定の言語バージョンのキーの翻訳がレビュー済です。

translations:unreview

特定の言語バージョンのキーの翻訳がレビューされていませんでした。

translations:unverify

特定の言語バージョンのキーの翻訳が未検証です。

translations:update

特定の言語バージョンのキーの翻訳が編集されました。

translations:verify

特定の言語バージョンのキーの翻訳が検証済みです。

uploads:作成

ロケール ファイルが正常に処理されました。

uploads:処理

ロケールファイルを処理しています。

ウェブフックの追加

ウェブフックの追加手順は、次のとおりです。

  1. [Integrations]ページから[Webhooks]までスクロールし、[Configure]をクリックします。

    ウェブフックのページが開きます。

  2. ウェブフック追加をクリックします。

    ウェブフックの追加ウィンドウが開きます。

  3. ウェブフックの詳細を入力します。

  4. オプションでブランチを含めることもできます。

  5. 保存 をクリックします。指定したウェブフックがウェブフックページの一覧に追加されます。

ウェブフックは、特定のウェブフックの [その他] メニューから無効化できます。

ウェブフックをテストする

ウェブフックをテストする

  • Webhooks ページでウェブフックを選択し、More メニューから Send Test-Notice を選択します。

    テストが成功したことを示す通知が表示されます。

RequestBin などのサービスを使用してウェブフックの内容をキャプチャします。RequestBinは検査依頼データを収集するURLを提供します。

ウェブフックデータの使用

特定のタイプのイベントが発生するたびに、POSTリクエストが特定のコールバックURLに送信されます。リクエストのPOSTペイロードは、イベントの関連データを含むJSONエンコードされたドキュメントです。属性のイベントメッセージは常に含まれ、ウェブフックがトリガーされたユーザー 、プロジェクト 、ブランチ など、イベントに関連する追加属性も含まれます。

Reponse ヘッダー

コールバックURLに対するHTTPリクエストには、いくつかの特殊なヘッダーが含まれます。

  • X-PhraseApp-Event:ウェブフックをトリガーしたイベントのタイプ。

  • X-PhraseApp-Signature:フックの秘密をキーとして使用した、ペイロードの HMAC 16 進ダイジェスト。

例:

コンテンツタイプ: application/json
X-PhraseApp-Event: translation:create
X-PhraseApp-Signature: abc123

{
  "event": "translations:create",
  "message":"Peter translated page.help.title in fr.",
  "user": {
    "id": "abcd1234cdef1234abcd1234cdef1234",
    "username": "joe.doe",
    "name":"Joe Doe",
    "email": "joe@phrase.com",
    "position":"Lead Developer",
    "created_at":"2015-01-28T09:52:53Z",
    "updated_at":"2015-01-28T09:52:53Z"
  },
  "project": {
    "id": "abcd1234cdef1234abcd1234cdef1234",
    "name":"My Android Project",
    "main_format": "xml",
    "project_image_url": "http://assets.phrase.com/project.png",
    "account": "account",
    "created_at":"2015-01-28T09:52:53Z",
    "updated_at":"2015-01-28T09:52:53Z"
  },
  "branch": {
  "name": "branch_name"
  },
  "translation": {
    "id": "abcd1234cdef1234abcd1234cdef1234",
    "content":"My translation",
    "unverified": false,
    "excluded": false、
    "plural_suffix": "",
    "key": {
      "id": "abcd1234cdef1234abcd1234cdef1234",
      "name": "home.index.headline",
      "plural": false
    },
    "locale": {
      "id": "abcd1234cdef1234abcd1234cdef1234",
      "name": "de",
      "code": "de-DE"
    },
    "placeholders": [
      "%{count}"
    ],
    "created_at":"2015-01-28T09:52:53Z",
    "updated_at":"2015-01-28T09:52:53Z"
  }
}
この記事は役に立ちましたか?

Sorry about that! In what way was it not helpful?

The article didn’t address my problem.
I couldn’t understand the article.
The feature doesn’t do what I need.
Other reason.

Note that feedback is provided anonymously so we aren't able to reply to questions.
If you'd like to ask a question, submit a request to our Support team.
Thank you for your feedback.