Benzinga API は、API リクエストの成功または失敗を示すために、標準的な HTTP レスポンスコードを使用します。概要は次のとおりです。
- 2xx: 成功。
- 4xx: クライアントエラー(例: パラメータ不足、無効なキー)。
- 5xx: サーバーエラー(Benzinga 側で問題が発生)。
リクエストが成功したかどうかを判断する際は、必ず最初に HTTP ステータスコード を確認してください。レスポンスボディだけに依存しないでください。フォーマットは API エンドポイントごとに異なる場合があります。
次の表は、遭遇しうる標準的なステータスコードの一覧です。
| Code | Status | Description |
|---|
| 200 | OK | リクエストは正常に処理されました。 |
| 400 | Bad Request | リクエストに問題があります。多くの場合、パラメータの欠如または不正が原因です。 |
| 401 | Unauthorized | 有効な API Key が指定されていません。Authorization ヘッダーまたは token パラメータを確認してください。 |
| 402 | Request Failed | パラメータは有効ですが、ビジネスロジック上の理由によりリクエストが失敗しました。 |
| 403 | Forbidden | API Key は有効ですが、このリソースへアクセスする権限がありません。 |
| 404 | Not Found | リクエストされたリソース(例: ID、エンドポイント)が存在しません。 |
| 429 | Too Many Requests | レート制限の上限を超過しています。 |
| 500 | Internal Server Error | Benzinga のサーバー側で問題が発生しました。これはまれに発生します。 |
| 503 | Service Unavailable | サービスは一時的に利用できません(例: メンテナンス)。 |
HTTP ステータスコードはエラーの主な指標ですが、レスポンスボディにはデバッグに役立つ詳細情報が含まれていることがよくあります。このボディの形式は、どの API を呼び出すかによって異なる場合があります。
多くのエンドポイント(News API など)は、シンプルな文字列、またはメッセージを含むフラットな JSON オブジェクトを返します。
"Invalid or Missing Query Parameters"
または
{
"message": "Invalid page size"
}
新しい API(Data API Proxy やファンダメンタルズなど)は、エラーの一覧を含む構造化されたオブジェクトを返します。
{
"data": null,
"errors": [
{
"code": "database_query_error",
"id": "ERR_12345",
"value": "シンボルのデータを取得できません: INVALID"
}
],
"ok": false
}
レスポンスボディにばらつきが生じる可能性があるため、堅牢なエラー処理を行うことを推奨します。
- HTTP ステータスコードを確認します。
>= 400 の場合はエラーとして扱います。
- レスポンスボディをログに記録します。 デバッグ目的でボディ全体をログに出力します。
- 汎用的なメッセージを表示します。 特定のエンドポイントと連携しておらず、その正確なエラー形式を把握していない場合は、ステータスコードとあわせてエンドユーザーに汎用的な「Something went wrong」メッセージを表示します。