クラウドBOT RESTful API リファレンス (4.3)

Download OpenAPI specification:Download

クラウドBOT RESTful APIのリファレンスです。
APIを利用するには、公開IDの設定とアクセストークンの発行が必要です。
クラウドBOTダッシュボード > 開発者向けページから設定してください。
https://console.c-bot.pro/development

リクエストペイロードおよびレスポンスにマルチバイト文字が含まれる場合はUTF-8として扱います。
リクエストペイロード容量が4MBを超えるリクエストは拒否されます。

契約一覧

API機能が有効な契約の一覧を参照します。
使用するアクセストークンに「参照」権限が付与されている必要があります。

query Parameters
properties
string
Example: properties=plan,owner

追加で取得するプロパティ名集合
以下のプロパティ名を,(カンマ)区切りで列記する
plan: プラン名
owner: 契約オーナー
timezone: タイムゾーン
location: ロケーション
name: 契約名
organization: 組織名(個人名)
postcode: 郵便番号
address: 住所
phone: 電話番号
department: 部署名
username: 担当者名
(public_id, public_pathプロパティは必ず取得します)

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
{
  • "code": 200,
  • "contracts": [
    ]
}

BOT一覧

API公開されているBOTの一覧を参照します。
使用するアクセストークンに「参照」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

query Parameters
properties
string
Example: properties=icon,created,last_modified,creator

追加で取得するプロパティ名集合
以下のプロパティ名を,(カンマ)区切りで列記する
icon: アイコン画像
created: 作成日
last_modified: 更新日
creator: 作成者
(id, name, descriptionプロパティは必ず取得します)

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
{
  • "code": 200,
  • "bots": [
    ]
}

BOT詳細

BOTの詳細を参照します。
使用するアクセストークンに「参照」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

bot_id
required
string

BOT ID

query Parameters
properties
string
Example: properties=icon,created,last_modified,creator,input,output

追加で取得するプロパティ名集合
以下のプロパティ名を,(カンマ)区切りで列記する
icon: アイコン画像
created: 作成日
last_modified: 更新日
creator: 作成者
input: 入力値定義
outout: 出力値定義
(id, name, descriptionプロパティは必ず取得します)

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
{
  • "code": 200,
  • "id": "add_item",
  • "name": "商品追加BOT",
  • "description": "商品を登録するBOTです。",
  • "icon": "",
  • "created": "2020-04-07T06:29:41Z",
  • "last_modified": "2020-04-07T09:41:44Z",
  • "creator": "example@example.com",
  • "input": {
    },
  • "output": {
    }
}

BOT実行

任意のBOTを実行します。
使用するアクセストークンに「実行」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

bot_id
required
string

BOT ID

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Request Body schema: application/json
timeout
integer [ 0 .. 25000 ]

BOT実行の終了を待機するミリ秒数(未指定の場合は0)
リクエストによってBOTが実行を開始した後、このミリ秒数を経過すると実行が終了していなくてもレスポンスを返します(レスポンスコード202)

callback_endpoint
string <uri>

BOT実行完了時に、このエンドポイント宛に実行結果がPOSTされます。(未指定の場合はコールバック無し)
エンドポイントは、必ずhttps://から始まる必要があります。
エンドポイントの実装要件は「クラウドBOT RESTful API Callback Endpoint 実装要件」を参照してください。

callback_tries
integer [ 0 .. 5 ]

コールバックPOSTの試行回数です。callback_endpointが200系以外のステータスコードをレスポンスした場合またはレスポンスヘッダに正しいアクセストークンが設定されていなかった場合に、指定回数まで試行します。0を指定した場合はコールバックPOSTは行われません。

object (datalist_input)

入力値を表すオブジェクトです。(未指定の場合はBOTのデフォルト値が使用されます)
入力値を指定したいデータ名,グループ名を任意数設定します。

Responses

Request samples

Content type
application/json
Example
{
  • "timeout": 20000,
  • "input": {
    }
}

Response samples

Content type
application/json
{
  • "code": 201,
  • "job_id": "00000000-0000-0000-0000-000000000000",
  • "bot_id": "get_items",
  • "bot_name": "商品取得BOT",
  • "status": 0,
  • "start_time": "2019-12-02T05:30:13Z",
  • "elapsed_time": 6,
  • "output": {
    }
}

BOTジョブ一覧

BOTのジョブ一覧を参照します。
使用するアクセストークンに「参照」権限が付与されている必要があります。

レスポンスサイズが4MBを超える場合は400エラーをレスポンスします。

path Parameters
public_id
required
string

APIの公開ID

bot_id
required
string

BOT ID

query Parameters
properties
string
Example: properties=output

追加で取得するプロパティ名集合
以下のプロパティ名を,(カンマ)区切りで列記する
output: 出力値オブジェクト
(job_id,bot_id,bot_name,status,start_time,elapsed_timeプロパティは必ず取得します)

limit
integer >= 0
Example: limit=10

アイテムの取得件数上限

datetime_from
string <date-time>
Example: datetime_from=2019-01-01T00:00:00Z

指定した日時(ISO 8601)以降に開始したジョブに限定する

datetime_to
string <date-time>
Example: datetime_to=2019-01-01T00:00:00Z

指定した日時(ISO 8601)以前に開始したジョブに限定する

id_from
string
Example: id_from=00000000-0000-0000-0000-000000000000

指定したジョブID以降に開始したジョブに限定する

id_to
string
Example: id_to=00000000-0000-0000-0000-000000000000

指定したジョブID以前に開始したジョブに限定する

statuses
integer
Example: statuses=1

指定したステータスのジョブに限定する。
ステータス(0:正常終了 1:エラー 2:実行中)
,(カンマ)区切りで複数指定可能(statuses=0,1)

sort_order
string
Default: "desc"
Enum: "asc" "desc"
Example: sort_order=asc

ソート順

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
{
  • "code": 200,
  • "jobs": [
    ]
}

ジョブ参照

任意のジョブの結果を参照します。
使用するアクセストークンに「参照」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

job_id
required
string

ジョブID

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
Example
{
  • "code": 200,
  • "job_id": "00000000-0000-0000-0000-000000000000",
  • "bot_id": "get_items",
  • "bot_name": "商品取得BOT",
  • "status": 0,
  • "start_time": "2019-12-02T06:04:21Z",
  • "elapsed_time": 6,
  • "output": {
    }
}

ジョブ中断

任意の実行中ジョブを中断します。
使用するアクセストークンに「中断」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

job_id
required
string

ジョブID

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
{
  • "code": 200,
  • "job_id": "00000000-0000-0000-0000-000000000000",
  • "bot_id": "get_items",
  • "bot_name": "商品取得BOT",
  • "status": 1,
  • "start_time": "2019-12-02T06:15:33Z",
  • "elapsed_time": 3
}

BOT購読一覧 (REST Hooks)

BOT購読の一覧を参照します。
使用するアクセストークンに「参照」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

bot_id
required
string

BOT ID

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
{}

BOT購読 (REST Hooks)

BOTの購読を開始します。
購読を開始すると、BOT操作に連動してWebhookやMailhookを受けることができるようになります。
使用するアクセストークンに「参照」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

bot_id
required
string

BOT ID

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Request Body schema: application/json
event
required
string
Enum: "onended" "onsucceeded" "onfailed" "oncannotexecute"

購読するイベント
onended: BOT実行終了
onsucceeded: BOT実行成功
onfailed: BOT実行失敗
oncannotexecute: BOT起動失敗

callback_type
string
Default: "webhook"
Enum: "webhook" "mailhook"

コールバックタイプ
webhook: イベントが発生すると、callback_endpoint宛にBOT実行結果がPOSTされます。
mailhook: イベントが発生すると、callback_emails宛にBOT実行結果が通知されます。

callback_endpoint
string <uri>

callback_typeが「webhook」の場合に指定します。
エンドポイントは、必ずhttps://から始まる必要があります。
エンドポイントの実装要件は「クラウドBOT RESTful API Callback Endpoint 実装要件」を参照してください。

object

callback_typeが「mailhook」の場合に指定します。
検証済みメールアドレスのみ指定できます。

Responses

Request samples

Content type
application/json
Example
{}

Response samples

Content type
application/json
{}

BOT購読解除 (REST Hooks)

BOTの購読を解除します
使用するアクセストークンに「参照」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

bot_id
required
string

BOT ID

subscribe_id
required
string

購読ID

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Responses

Response samples

Content type
application/json
{
  • "code": 200
}

ファイルダウンロード

ファイルをダウンロードします。
WSトークンが必要です。

path Parameters
key
required
string
Example: jobs/00000000-0000-0000-0000-000000000000/files/00000000-0000-0000-0000-000000000000

ダウンロード対象ファイルのref値
使用するWSトークンのkeysにこの値が含まれている必要があります。

query Parameters
ws_token
required
string
Example: ws_token=00000000-0000-0000-0000-000000000000

WSトークン
WSトークン発行時に指定されたexpireとtriesの有効期限内において複数回のダウンロードが可能です。

Responses

Response samples

Content type
application/octet-stream
File Data

ファイルアップロード

ファイルをアップロードします。
WSトークンが必要です。

アップロードしたファイルは契約の一時領域に格納され、ストレージ使用量に加算されます。
ファイルは6時間後に自動的に削除され、ストレージ使用量から減算されます。

query Parameters
ws_token
required
string
Example: ws_token=00000000-0000-0000-0000-000000000000

WSトークン
1つのWSトークンで複数回アップロードすることはできません。

header Parameters
content-type
required
string
Value: "text/plain"
x-cbot-encoding
string
Default: plain
Enum: "plain" "base64"

ファイルデータのエンコードタイプ

x-cbot-filename
required
string <= 64 characters

ファイル名(拡張子含む)

x-cbot-timestamp
string

ファイルの最終更新時刻(Unixタイムスタンプをミリ秒数で)
未指定の場合は現在時刻で記録されます。

Request Body schema: text/plain

ファイルデータ文字列
x-cbot-encodingリクエストヘッダがbase64の場合は、base64エンコードした文字列にします。

string

Responses

Request samples

Content type
text/plain
SGVsbG8sIHdvcmxkLg==

Response samples

Content type
application/json
{
  • "code": 200,
  • "ref": "temp/00000000-0000-0000-0000-000000000000"
}

WSトークン発行

WSトークンを発行します。
このトークンはファイルアップロード/ファイルダウンロードAPIを使用する際に必要です。
使用するアクセストークンに「参照」権限が付与されている必要があります。

path Parameters
public_id
required
string

APIの公開ID

header Parameters
content-type
required
string
Value: "application/json"
content-language
required
string
Enum: "ja" "en"
access-token
string

アクセストークン
トークン・シークレット認証の場合に必要です。

secret-key
string

シークレットキー
トークン・シークレット認証の場合に必要です。

authorization
string
Value: "Bearer {トークン}"

OAuthアクセストークン
OAuth認証の場合に必要です。
値はBearerスキームで記述します。

Request Body schema: application/json
scopes
required
Array of strings
Items Enum: "upload" "download"

このトークンで許可する操作名を配列で指定します。
ファイルダウンロード: download
ファイルアップロード: upload

keys
required
Array of strings

ファイルダウンロードを行う場合は、ダウンロード対象ファイルのref値を配列で指定します。
ファイルアップロードを行う場合は、次の配列を指定します。 ["temp/"]

expire
integer [ 0 .. 86400 ]
Default: 60

トークンの有効期限(秒)を指定します。
この指定はscopesに"download"を指定した場合のみ有効です。
scopesに"upload"を指定した場合は常に60秒です。

tries
integer [ 0 .. 1000 ]
Default: 1

keysに指定した各リソースへのアクセス可能回数を指定します。
この指定はscopesに"download"を指定した場合のみ有効です。0を指定した場合は無制限です。
scopesに"upload"を指定した場合は常に1です。

Responses

Request samples

Content type
application/json
Example
{
  • "scopes": [
    ],
  • "keys": [
    ],
  • "expire": 120,
  • "tries": 3
}

Response samples

Content type
application/json
{
  • "code": 200,
  • "ws_token": "00000000-0000-0000-0000-000000000000"
}