Docs Menu
Docs Home
/
MongoDB Cloud Manager
/

パブリック APIプリンシパル

項目一覧

  • HTTPメソッド
  • JSON
  • リンク
  • リスト
  • エンベロープ
  • Pretty Printing(整形表示)
  • 応答コード
  • Errors
  • 認証
  • オートメーション
  • レート制限
  • 詳細情報

Cloud Manager パブリックAPIは、 RESTアーキテクチャの原則に従い、Cloud Manager の機能へのプログラムによるアクセスを提供する内部リソースを公開します。

Web インターフェースを通じて行われた変更と同様、API を通じて行われた変更には Cloud Manager価格が適用されます。 サーバーを追加して料金が発生する場合は、Cloud Managerに登録されている有効なクレジットカードが必要です。そうしないと、アカウントがロックされる可能性があります。

APIには、次の機能があります。

JSONエンティティ
すべてのエンティティはJSONで表現されます。
ブラウザ可能なインターフェース
一貫性のあるリンク メカニズムを使用すると、ルート リソースから開始し、関連するリソースへのリンクを追跡することで、API 全体をブラウザできます。
ユーザー アクセス制御

各 Cloud Manager ユーザーのAPI機能は、 Cloud Manager ロールが付与する権限と一致します。

APIネットワーク アクセス リスト

Cloud Manager APIは、 API アクセス リストを通じて Cloud Manager Administration API へのアクセスを保護できます。 このリストは、特定の IP アドレスまたは CIDR アドレスへの API へのアクセスを制限します。各APIキーには、独自の Cloud Manager Administration API アクセス リストがあります。 Cloud Manager UI を使用して新しい組織を作成すると、MongoDB Atlas ではデフォルトでAPIアクセス リストの要求が有効になります。

詳細については、「 (任意)組織の API アクセス リストが必要 」を参照してください。

HTTPS Only
HTTPS 経由でのみ API にアクセスできるため、ネットワーク経由で送信されるすべてのデータは TLS を使用して完全に暗号化されます。

すべてのリソースは、次の一般的なHTTPメソッドのサブセットをサポートしています。

方式
目的
GET
リソースのJSON表現を取得します。
POST
指定されたJSON表現を使用して新しいリソースを作成します。
PUT
リソースを指定されたJSON表現で置き換えます。
PATCH
提供されたJSON表現を使用して、リソース内の指定されたフィールドを更新します。
DELETE
リソースを削除します。
HEAD
リソースのJSON表現なしでレスポンスヘッダーを取得します。

すべてのエンティティはJSONで表されます。 リクエストと応答の規則には次のルールが適用されます。

正しいコンテンツタイプヘッダーの適用
POSTまたはPUTを介してサーバーにJSONを送信する場合は、必ず正しいコンテンツタイプのリクエスト ヘッダーを指定してください。 Content-Type: application/json
ISO8601 string として日付を設定

サーバーに日付を送信する場合(POST または リクエスト エンティティのクエリPATCH パラメータまたはフィールドとして)は、 に準拠した日付を使用します: 8601標準。タイムゾーンを指定しない場合、Cloud Manager はUTCを想定します。 あいまいさを避けるために、タイムゾーン指定子を含めます。

  • 2018 年 9 月 27 日は2018-09-27として表されます。

  • 2018 年 9 月 27 日、午前 4 時 00分 EDT は(タイムゾーンとともに) 2018-09-27T16:00-04:00として表されます。

場合によっては、タイムスタンプが BSON タイムスタンプ JSON 表現として返されます 、特にバックアップ リソースがバックアップ リソースに含まれます。BSONタイムスタンプのこの表現は、2 つのフィールドを持つオブジェクトとしてJSON document を提供します。

フィールド
定義
date
UNIXエポック からの秒数
increment
特定の秒内の操作の増分 32 ビット整数序数。

2018 年 9 月 27 日、午前 4:00、EDT の 3 回目の操作は、次のように表されます(タイムゾーン)

{ date: 2018-09-27T16:00-04:00, increment: 3 }
無効なフィールドを拒否

無効なフィールドは無視されるのではなく拒否されます。

新しいエンティティを作成し、フィールドのいずれかのスペルをうっかり間違えた場合、または既存のエンティティをアップデートして変更できないフィールドを含めた場合、Cloud Manager はHTTP 400 ステータス コードと、どのフィールドが変更されたかを示すエラーメッセージを返します。無効。

日付を ISO8601 として返します String
すべての日付は ISO8601 として返されます。 UTC で指定された 形式の文字列 。
単位を曖昧にするフィールドにラベルを付ける

特定の単位の数値を含むフィールドには、使用される単位を明確に区別するために名前が付けられます。

ホストのアップタイムはミリ秒単位で返されるため、ホスト エンティティ フィールドの名前はuptimeMsecです。

他の値がないフィールドのデフォルト値を返します

現在の値がないフィールドは、適切なデフォルト値とともに返されます。

Cloud Manager には新しく検出されたホストの統計がないため、統計関連のフィールドの値はゼロになります。

認識可能なデフォルト値を持たないフィールドは、エンティティから省略されます。

認証を使用していないホストでは、返されるエンティティからusernameフィールドが省略されます。

アルファベット順のフィールドを返します
Cloud Manager が返すJSONドキュメント内のフィールドはアルファベット順です。 順序が変更される可能性があります。 フィールドの順序に依存しないでください。

各リソースには、サブリソースや関連リソースへの 1 つ以上のリンクが含まれています。

ホストには、属するプロジェクト、属するレプリカセットなどへのリンクがあります。

リンクは、リンク関係オブジェクトの配列であるエンティティのlinksフィールドに配置されます。 各リンク関係には 2 つのフィールドがあります。

フィールド
定義
rel
関係の名前(またはタイプ)。 これらの多くは拡張関係タイプと見なされ、 http://mms.mongodb.comというプレフィックスが付きます。
href
ターゲットURL

すべてのエンティティには、 selfと呼ばれるリンク関係が少なくとも 1 つ含まれます。これはつまり、独自のURLです。 エンティティがリストの一部である場合(つまり、プロジェクト内のすべてのホストをリクエストする場合)、そのエンティティにはselfリンク関係のみが含まれます。

これは、いくつかのリンクを含むhostリソースの一部です。

1{
2 "id": "xxx",
3 "projectId": "yyy",
4 "hostname": "mongodb.example.com",
5 "port": 27017,
6 "links": [
7 {
8 "rel": "self",
9 "href": "https://cloud.mongodb.com/api/public/v1.0/projects/xxx/hosts/yyy"
10 },
11 {
12 "rel": "http://mms.mongodb.com/project",
13 "href": "https://cloud.mongodb.com/api/public/v1.0/projects/xxx"
14 }
15 ]
16}

詳細については、「 Web リンク仕様 」を参照してください。 。

注意

Web リンク仕様です が で HTTP レスポンス ヘッダーにリンクを含めるための形式が記述されていますが、これは必須ではありません。APIを簡単に閲覧できるようにするには、レスポンス ヘッダーではなくレスポンス本体にリンクを含めます。

一部のリソースはエンティティのリストを返します。

プロジェクト内のすべてのホストのリストをリクエストできます。

応答でエンティティのリストが要求される場合、結果は 2 つのクエリ パラメータに囲まれたバッチで返されます。

フィールド
定義
pageNum
ページ番号(1 から始まる)。 指定しない場合、デフォルトは 1 です。
itemsPerPage
1 ページあたりに返す項目の数は最大 500 です。 指定しない場合、デフォルトは 100 です。

応答エンティティには、次の 3 つのフィールドが含まれています。

フィールド
定義
totalCount

結果セット全体内の項目の合計数。

たとえば、プロジェクトに合計57のホストがあり、 pageNum=6itemsPerPage=10を使用してリクエストを作成した場合、 totalCount57になります。

results
結果セット 。これはエンティティ ドキュメントの配列です。
links

1 から 3 のリンク関係が含まれています。

  • previous 前の結果のページ(最初のページは省略)。

  • next 次のページの結果(最後のページは省略)。

  • self 現在のページ用(常に存在)。

エンティティのリストのリクエストを行って結果がない場合、 APIHTTP 200 ステータス コードと空のresults配列で応答します。 この場合、エンティティのリストが将来のある時点で空ではなくなる可能性があるため、この場合は 404 では応答しませ

存在しないコンテキストでエンティティのリスト(つまり、存在しないプロジェクトのホストのリスト)を要求した場合は、 HTTP 404 応答ステータスが返されます。

これは、合計 57 ホストを持つプロジェクト内の 10 個のホストの 2 ページのHTTP応答です。

1{
2
3 "totalCount": 57,
4 "results": [
5 {
6 "id": "yyy",
7 "projectId": "xxx",
8 // additional host properties...
9 },
10 // additional host documents...
11 ],
12 "links": [
13 {
14 "rel" : "self",
15 "href" : "https://www.mongodb.com/api/public/v1.0/projects/xxx/hosts?pageNum=2&itemsPerPage=10"
16 },
17 {
18 "rel": "previous",
19 "href": "https://www.mongodb.com/api/public/v1.0/projects/xxx/hosts?itemsPerPage=10&pageNum=1"
20 },
21 {
22 "rel": "next",
23 "href": "https://www.mongodb.com/api/public/v1.0/projects/xxx/hosts?itemsPerPage=10&pageNum=3"
24 }
25 ]
26}

一部のクライアントは、 HTTPレスポンス ヘッダーやステータス コードにアクセスできない場合があります。 この場合は、応答にenvelopeを含めることをリクエストできます。これは、通常応答 ヘッダーに含まれる関連詳細を含む、 JSONドキュメント内の追加の情報レイヤーです。

デフォルトでは、 APIのエンベロープに応答は含まれませ。 リクエストするには、クエリ パラメータenvelope=trueを追加します。

単一のエンティティを含む応答の場合、エンベロープには 2 つのフィールドが含まれます。

フィールド
定義
status
HTTP status code.
content
要求されたエンティティ。

エンティティのリストを含む応答の場合、結果をラップするエンベロープはすでにあるため、この場合はクエリ パラメータとしてenvelope=trueを指定すると、既存のエンベロープにstatusフィールドのみが追加されます。

デフォルトでは、Cloud Manager が返すJSONから余計な空白は削除されます。 pretty-printed JSONをリクエストするには、リクエストにpretty=trueクエリ パラメータを追加します。

curl --user '{PUBLIC-KEY}:{PRIVATE-KEY}' --digest \
--header 'Accept: application/json' \
--include \
--request GET "https://cloud.mongodb.com/api/public/v1.0?pretty=true"

注意

このドキュメントのすべての例は、わかりやすくするためにpretty-printed JSONを示していますが、一部のサンプルURLにはこの追加のクエリパラメータが含まれていない場合があります

応答では、次のような標準のHTTP応答コードが使用されます。

コード
意味
ノート
200
OK
リクエストは成功しました。 これは、 GETリクエストが成功した場合の一般的な応答です。
201
作成済み
新しいリソースが作成されました。 これは、 POSTリクエストが成功した場合の一般的な応答です。
202
承認済み
非同期操作のリクエストが受け入れられました。
400
無効なリクエスト
クライアント リクエストで問題が発生しました。
401
許可されていない
認証は必要ですが、リクエストに含まれていませんでした。 Typically this means that the digest authentication information was omitted from the request, the provided credentials are incorrect, or the user associated with the given API key is not allowed to access the requested resource.
403
Forbidden
指定されたリソースへのアクセスは許可されていません。
404
見つかりません
要求されたリソースが存在しない。
405
メソッドは許可されていません

HTTPメソッドは指定されたリソースではサポートされていません。 各リソースがサポートするのはHTTPメソッドのサブセットのみであることに注意してください。

たとえば、ルートリソースをDELETEすることはできません。

409
競合

これは通常、そのプロパティの同じ値を持つ既存のエンティティがすでに存在する場合に一意なエンティティのプロパティを作成または変更するためのリクエストに対する応答です。

たとえば、既存のプロジェクトと同じ名前のプロジェクトを作成しようとすると、リクエストは失敗します。

5x
さまざまなサーバーエラー
予期しない問題が発生しました。 後でもう一度お試しください。Cloud Manager サポートへの通知を検討してください。

リクエストの結果としてエラーが発生した場合、レスポンス本文には、何が起こるかを示す追加の詳細が記載されたJSONドキュメントが含まれます。 ドキュメントには、次の 5 つのフィールドが含まれています。

フィールド
データ型
定義
detail
string
APIリクエスト エラーの、人間が判読可能な説明。
error
integer
errorCode
string
Cloud Manager 管理 API エラー コード に示される、 API リクエスト エラーを表す名前付き定数。
parameters
文字列の配列
APIリクエストで渡されるパラメータのリスト。
reason
string

Cloud Manager は、誤った形式のリクエストに対して次のレスポンス本体を返します。

1{
2 "detail" : "Cannot find resource /api/public/v1.0/softwareComponents/version.",
3 "error" : 404,
4 "errorCode" : "RESOURCE_NOT_FOUND",
5 "parameters" : [ "/api/public/v1.0/softwareComponents/version" ],
6 "reason" : "Not Found"
7}

コードのリストを確認するには、「 Cloud Manager Administration API エラー コード 」を参照してください。

Cloud Manager APIは、リクエストを認証するために 2 つの方法( APIキーまたはサービス アカウント)のいずれかを使用します。これにより、ユーザー名とパスワードとして機能するキーとアクセス トークンがネットワーク経由で送信されることがなくなります。 使用方法の詳細については、「 プログラムによるCloud Managerへのアクセス 」を参照してください。

API キー
サービス アカウント
業界標準の OAuth2.0 プロトコル、 クライアント認証情報フロー を使用してCloud Managerに認証する新しい方法。現在はプレビュー段階です。
APIキーには、公開キーと秘密キーの 2 つの部分があります。この 2 つの部分が、 APICloud ManagerCloud ManagerにAPIリクエストを行う際に、ユーザー名およびパスワードと同じ機能を果たします。
サービス アカウントを使用すると、権限を管理し、アクセス トークンを作成できます。 サービス アカウントには、アクセス トークンを作成するためのユーザー名とパスワードとして機能するクライアントIDとシークレットがあります。 アクセス トークンを使用すると、 CloudAPI Cloud ManagerManagerにAPIリクエストを行うことができます。
Cloud Managerは、 noance と呼ばれる一意の値を使用して、公開キーと秘密キーをハッシュします。HTTPダイジェスト仕様に従って短時間のみ有効です。これはリプレイ攻撃を防ぐためのもので、期間をキャッシュして永久に使用することはできません。
サービス アカウントを作成したら、そのクライアントIDとシークレットを使用してアクセス トークンを生成し、 APIリクエストを認証します。アクセス トークンは、OAuth 2.0 仕様に従って 1 時間( 3600 秒)のみ有効です。アクセス トークンの有効期限が切れると、リプレイ攻撃を防止できます。この場合、リークされたアクセス トークンは時間制限なしで使用できます。
Cloud Managerロールは、 APIキーが実行できる操作を制限します。APIキーで、エラーなくAPIエンドポイントを呼び出せるようにするには、ユーザーの場合と同様にAPIキーにロールを付与する必要があります。
Cloud Managerロールは、サービス アカウントがアクセス トークンを使用して実行できる操作を制限します。アクセス トークンで、エラーなくAPIエンドポイントを呼び出せるようにするには、ユーザーの場合と同様に、サービス アカウントにロールを付与する必要があります。
Cloud Managerは多くのリソースをプロジェクトにバインドします。 多くのAPIリソースURLは /api/public/v1.0/groups/<PROJECT-ID>/の形式に従います。これらのリソースの場合、 APIキーはプロジェクトをホストする組織のメンバーである必要があります。それ以外の場合、 Cloud Managerは401 エラーで応答します。
Cloud Managerは多くのリソースをプロジェクトにバインドします。 多くのAPIリソースURLは /api/public/v1.0/groups/<PROJECT-ID>/の形式に従います。これらのリソースでは、サービス アカウントはプロジェクトをホストする組織のメンバーである必要があります。 それ以外の場合、 Cloud Managerは401 エラーで応答します。
<span tabindex=\" \" class=\" \">API キーは 1 つの組織のみに属しますが、その組織内の任意の数のプロジェクトに <span tabindex=\" \" class=\" \">API キーによるアクセスを許可できます。
各サービス アカウントは 1 つの組織にのみ属しますが、その組織内の任意の数のプロジェクトへのアクセスをサービスアカウントに許可できます。

一部のリソース メソッドはさらに多くのセキュリティを必要とし、リストされている IP アドレスからのみリソースへのアクセスを許可する アクセス リスト によって追加で保護されています。各ユーザーは、リソースへのアクセスを許可するIPアドレスの独自のアクセス リストを構成します。

オートメーション構成リソース最新プランのオートメーションステータスの取得リソースは、プロジェクトの配置を変更し、配置ステータスを取得するためのエンドポイントを提供します。 新しいオートメーション構成を Cloud Manager に送信することで配置を変更できます。 オートメーション構成では、配置する MongoDB プロセスを説明して構成します。 Cloud Manager では、これを配置の「ターゲット 状態」と呼びます。 APIを通じて新しいオートメーション構成を送信すると、オートメーションはシステムの現在の状態を目的の状態に一致するように調整します。

重要

APIには、同時変更を防ぐための保護はありません。 2 人の管理者がそれぞれ現在のバージョンに基づく構成で開始し、独自の変更を加えてから変更を送信すると、後の変更が成功します。

特定のリソースには、レート制限が適用されます。

レートが制限されているリソースの場合、Cloud Manager はプロジェクト ごとに 1 分あたり最大 100 個のリクエストを許可します。 公開APIキーは Cloud Manager ユーザーに割り当てられますが、そのユーザーは複数のプロジェクトにアクセスできることに注意してください。

A と B の 2 人のユーザーを考えてみましょう。

ユーザー A はプロジェクト X に属し、ユーザー B はプロジェクト X と Y に属しています。

  1. 午前 1 時 00分に、ユーザー A はプロジェクト X のレート制限されたリソースに 50 回のリクエストを送信し、すべてが 1 時 00 分、20 時までに完了します。

  2. 午前 1 時 00分: 30 分に、ユーザー B はプロジェクト X のレート制限されたリソースに対して 60 回のリクエストを実行しようとします。

    ユーザー A はプロジェクト X の 1 時 00 分以内に 50 個のリクエストをすでに使用しているため、ユーザー B が試みた最後の 10 個のリクエストは拒否されます。 ただし、各プロジェクトが個別のリクエスト カウンターを保持しているため、ユーザー B はプロジェクト Y のレート制限されたリソースにリクエストを行うことができます。

  3. 午後 1 時 01 分になると、レート制限に使用されるリクエスト カウンターが 1 分ごとにリセットされるため、プロジェクト X へのリクエストが続行される可能性があります。

レート制限を超えると、 APIHTTP 429 Too Many Requests応答コードを返します。

Cloud Manager のパブリック API で利用可能なすべてのリソースの完全なリファレンスについては、「 Cloud Manager 管理 API リソース 」を参照してください。

戻る

API