Habitica Wiki JP
Habitica Wiki JP
Advertisement
Habitica Wiki JP

Habiticaは、アカウントで発生する可能性がある特定のアクション(たとえば、タスクを完了したとき、または所属しているギルドに誰かがメッセージを投稿したとき)に「ウェブフック」を提供します。そのようなアクションが発生するとWebhookがトリガーされ、アクションに関する情報が別のWebサイトのスクリプトまたはその他のツールに送信されます。

詳細な技術情報[]

HabiticaはPOSTリクエストでWebhook URLを呼び出します。

HabiticaのWebhookから情報を受信するスクリプトを指定するには、HabiticaのWebサイトにログインし、[ユーザーアイコン]> [設定]> [API]に移動します。

詳細については、HabiticaのAPIドキュメントのWebhooksセクションをご覧ください。

誤ったURLを指定すると、Habiticaでエラーまたは速度低下が発生する可能性があるため、Webhookの動作が不明な場合は、この機能を使用しないことをお勧めします。Webhookは、タイムアウトエラーがトリガーされるまでに、2xx HTTPコードの応答に30秒かかります。最適解は、200 HTTPコードと空ではない応答(例:非常に小さいjson、またはHtmlService.createHtmlOutput()を使用)を含むリクエストを受信したらすぐにHabiticaサーバーに応答することです。これにより、Habiticaサーバーが必要最低限​​の時間(応答を送信した後にデータを処理できます)でWebhookに接続されたままになり、30秒のタイムアウト制限に達するリスクがなくなります。月に10回以上失敗したWebhookは自動的に無効になります。

Webhookに応答するスクリプトの開発についてサポートが必要な場合は、Aspiring Comradesギルドで他の開発者にアドバイスを求めてください。

Webhook開発の認知度を高めたい場合は、en:Guidance for Comrades(未翻訳)で詳細を確認してください。

[]

Python Flaskの例[]

次のスクリプトは、Python Flaskを使用してWebhookの処理を実装しています。HabiticaのWebサイトに入力するURLは次のようになります。http://<your_ip>:<your_port>/taskevent

Flaskはデフォルトでポート5000を監視しますが、<your_port>で示される別のポートを指定できます。

スクリプトがファイアウォールの背後でホストされている場合は、ポート転送を使用するか、ファイアウォールを介したポートへのアクセスを許可する必要があります。

from flask import Flask, request
app = Flask(__name__)
  # URI for receiving inbound webhook request
@app.route('/taskevent', methods=['POST'])
def webhook():
    # Request contains data as shown at https://habitica.com/apidoc/#api-Webhook
     # .json converts request to Python dictionary
    print(request.json)  # type: dict
 
    # <YOUR CODE FOR HANDLING EVENT HERE>
 
    return '', 200 # Return 200 code to the sending webserver
 
if __name__ == "__main__":
    app.run(host='0.0.0.0', port='<your_port>')

Google Apps Scriptの例[]

次のスクリプトは、Google Apps Scriptを使用してHabitica Webhookを監視します。スクリプトは、「バージョンの管理」を使用して編集するたびに新しいバージョンとして保存する必要があります。新しいバージョンを有効にするには、「Webアプリ」としてデプロイし、スクリプトを「As Yourself」で実行して、「everyone, even anonymous」にアクセスを許可する必要があります。

次の例は、クエストの招待を即座に自動承諾します。

function doPost(e) {
  var habiticaUserId = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"; // your Habitica UserId
  var habiticaApiToken = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"; // your Habitica API-Token (don't share, = password!)

  try {
    var dataContents = JSON.parse(e.postData.contents);
    var type = dataContents.type;
  } catch (err) {}

  if (type == 'questInvited') {
    var params = {
      "method": "post", 
      "headers" : {
        "x-client": habiticaUserId + "-Webhook Script questInvited",
        "x-api-user": habiticaUserId, 
        "x-api-key": habiticaApiToken
      }
    }

    var url = "https://habitica.com/api/v3/groups/party/quests/accept"; 
    UrlFetchApp.fetch(url, params);
  }

  return HtmlService.createHtmlOutput();
}

詳細:Google Apps ScriptによるWebhook処理

Webhookのサードパーティツール[]

現在、Webhookを作成および編集するためのHabiticaの独自のインターフェースは制限されていますが、HabiticaのAPIはより詳細な制御を提供します。つまり、以下にリストされているようなWebhookのセットアップにサードパーティツールを使用できます。拡張機能・アドオン・カスタマイズページに他のページが表示される場合があります。サードパーティのツールと同様に、使用に適しているかどうかを慎重に評価する必要があります。Habiticaのスタッフは、ツールを直接サポートしたり、ツールを保証したりしません。

Advertisement