Object Storage は、ファイル、データベース、またはアーカイブが必要な他のデータセットであるデジタルオブジェクトの 永続ストレージを提供します。オブジェクトはコンテナと呼ばれる名前付きの場所に格納されます。コンテナはネストすることが でき、オブジェクトは階層的に格納できます。
このセクションでは、ウィジェットまたはオペレータで使用できる WireCloud によって提供されるObjectStorage API のリファレンス・ドキュメントを提供します。この API を使用できるようにするには、この API の要件をウィジェット/オペレータの記述ファイルに追加する必要があります。この API の使用方法に関する詳細なドキュメント および例については、Using Object Storage チュートリアルを参照してください。
KeystoneAPI¶
次のコンストラクタを使用して、新しい KeystoneAPI をインスタンス化できます :
KeystoneAPI(url[, options]);
url: キーストーン・サーバのURLですoptions:token(String): Keystone サーバへのリクエストを認証するために使用するトークンです。(オプション)use_user_fiware_token(Boolean): KeystoneAPI が、FIWARE の IdM サーバから現在のユーザに対して WireCloud で取得したトークンを使用するようにします。tokenオプションよりも優先されます。(オプション)
token および use_user_fiware_token オプションは任意です。KeystoneAPI コンストラクタに渡されると、
これらの値は内部的に格納され、メソッドの呼び出し時にデフォルト値として使用されます。いずれの場合でも、
これらのオプションはデフォルト値を使用しない KeystoneAPI メソッドに渡すこともできます。
getTenants¶
認証されたユーザに、使用可能な Keystone サーバ内のすべてのテナントを一覧表示します。
getTenants([options]);
onSuccess コールバックは、最初の引数としてテナントのリストを受け取ります。
getAuthToken¶
Object Storage API へのアクセスを許可する認証トークンを取得します。
getAuthToken([options]);
その他のオプション :
tenantName(String): 生成されたトークンに関連付けるテナントの名前。tenantIdとtenantNameの両方の属性はオプションですが、一緒に指定することはできませんtenantId(String): 生成されたトークンに関連付けるテナントの id。tenantIdとtenantNameの両方の属性はオプションですが、一緒に指定することはできません
onSuccess コールバックは、最初の引数として認証トークンの情報を受け取ることになります。
ObjectStorageAPI¶
新しい ObjectStorageAPI は、次のコンストラクタを使用して、インスタンス化できます :
ObjectStorageAPI(url[, options]);
url: Object Storage サーバの URL ですoptions:token(String): Object Storage サーバへの認証リクエストのためにデフォルトで使用するトークンです
すべての ObjectStorageAPI メソッドは、少なくとも次のオプションをサポートします :
token(String): 認証リクエストに使用するトークン
および、次のコールバックがあります :
onSuccessは、リクエストが正常に終了すると呼び出されます。このコールバックに渡されるパラメータは、 呼び出されるメソッドによって異なりますonFailureは、リクエストがエラーで終了したときに呼び出されますonCompleteは、リクエストが成功したかどうかにかかわらず、リクエストが完了したときに呼び出されます
createContainer¶
他のコンテナやオブジェクトを格納できるコンテナを作成します。
createContainer(container[, options]);
containerは、作成するコンテナの名前です
listContainer¶
コンテナの内容のリストを返します。
listContainer(container[, options]);
containerは、リストするコンテナの名前です
deleteContainer¶
指定したコンテナをストレージ・システムから削除します。
deleteContainer(container[, options]);
containerは、削除するコンテナの名前です
getFile¶
ストレージ・システムから指定されたオブジェクトを取得します。
getFile(container, file_name[, options])
containerは、ファイルが存在するコンテナの名前ですfile_nameは、ダウンロードするファイルの名前です
その他のオプション :
response_type(String, default : "blob") : 有効な値はすべてresponseTypeオプションでサポートされています。 "" を除きます。詳細はリクエスト・オプション のセクションを参照してください
uploadFile¶
バイナリオブジェクトを指定された場所に格納します。
uploadFile(container, file[, options]);
その他のオプション :
file_name: ファイルのアップロードに使用する名前。このオプションは、fileの引き数としてBlobを渡す場合に必要です。このオプションは、そのname属性から名前を取得するときにFileインスタンスを渡すときには 必要ありません。とにかく、このオプションで渡された名前は、Fileインスタンスのname属性よりも優先されます
deleteFile¶
指定されたオブジェクトをストレージシステムから削除します。
deleteFile(container, file_name[, options]);
containerは、ファイルが削除されるコンテナの名前ですfile_nameは、削除するファイルの名前です