統合機能

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));
  $hmac == $signatureheader;
}

ウェブフックイベント

イベント名

概要

branches:create

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

branches:merge

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

comments:create

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

custom_metadata_values:batch_update

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

custom_metadata_values:update

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

jobs:complete

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

jobs:create

ジョブが作成されます。

jobs:locale:complete

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

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

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

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

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

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

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

ジョブ:再度開かれた

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

ジョブ:開始

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

jobs:update

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

keys:batch_delete

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

keys:create

キーが作成されました。

keys:delete

キーが削除されました。

keys:update

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

locales:create

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

locales:delete

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

locales:update

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

project:update

プロジェクトが変更または再構成されました。

releases:create

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

releases:delete

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

screenshots:create

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

screenshots:delete

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

screenshots:update

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

translations:batch_delete

翻訳の一覧は削除されました。

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:create

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

uploads:processing

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

ウェブフックの追加

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

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

    Webhooks ページが開きます。

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

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

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

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

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

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

ウェブフックのテスト

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

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

    テストが成功したことを示すメッセージが表示されます。

RequestBin などのサービスを使用してウェブフックのコンテンツを取得します。RequestBin は、検査のためにリクエストデータを収集する URL を提供します。

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

特定のタイプのイベントが発生するたびに、特定のコールバック URL に POST 要求が送信されます。要求の 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":"ジョー・ドウ",
    "email": "joe@phrase.com",
    "position":リードデベロッパー
    "created_at":"2015-01-28T09:52:53Z",
    "updated_at":"2015-01-28T09:52:53Z"
  },
  "project": {
    "id": "abcd1234cdef1234abcd1234cdef1234",
    "name":"マイ Android プロジェクト",
    "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":「私の翻訳」、
    "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.