使用 AWS CLI 的 Amazon IVS 聊天功能範例
下列程式碼範例示範如何使用 AWS Command Line Interface 搭配 Amazon IVS 聊天功能來執行動作,並實作常見案例。
Actions 是大型程式的程式碼摘錄,必須在內容中執行。雖然動作會告訴您如何呼叫個別服務函數,但您可以在其相關情境中查看內容中的動作。
每個範例均包含完整原始程式碼的連結,您可在連結中找到如何在內容中設定和執行程式碼的相關指示。
主題
動作
以下程式碼範例顯示如何使用 create-chat-token。
- AWS CLI
-
建立聊天字符
下列
create-chat-token範例會建立加密的聊天字符,此字符會用於建立與房間的個別 WebSocket 連線。字符有效期為一分鐘,而使用該字符建立的連線 (工作階段) 在指定的持續時間內保持有效。aws ivschat create-chat-token \ --roomIdentifier "arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6", \ --userId" "11231234" \ --capabilities "SEND_MESSAGE", \ --sessionDurationInMinutes"30輸出:
{ "token": "ACEGmnoq#1rstu2...BDFH3vxwy!4hlm!#5", "sessionExpirationTime": "2022-03-16T04:44:09+00:00" "state": "CREATING", "tokenExpirationTime": "2022-03-16T03:45:09+00:00" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的步驟 3:驗證和授權聊天用戶端。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 CreateChatToken
。
-
以下程式碼範例顯示如何使用 create-logging-configuration。
- AWS CLI
-
建立聊天 LoggingConfiguration 資源
下列
create-logging-configuration範例會建立 LoggingConfiguration 資源,此資源允許用戶端存放和記錄傳送的訊息。aws ivschat create-logging-configuration \ --destination-configurations3={bucketName=demo-logging-bucket}\ --name"test-logging-config"\ --tags"key1=value1, key2=value2"輸出:
{ "arn": "arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ", "createTime": "2022-09-14T17:48:00.653000+00:00", "destinationConfiguration": { "s3": { "bucketName": "demo-logging-bucket" } }, "id": "ABcdef34ghIJ", "name": "test-logging-config", "state": "ACTIVE", "tags": { "key1" : "value1", "key2" : "value2" }, "updateTime": "2022-09-14T17:48:01.104000+00:00" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 CreateLoggingConfiguration
。
-
以下程式碼範例顯示如何使用 create-room。
- AWS CLI
-
建立房間
下列
create-room範例會建立新的房間。aws ivschat create-room \ --name"test-room-1"\ --logging-configuration-identifiers"arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"\ --maximum-message-length256\ --maximum-message-rate-per-second5輸出:
{ "arn": "arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6", "id": "g1H2I3j4k5L6", "createTime": "2022-03-16T04:44:09+00:00", "loggingConfigurationIdentifiers": ["arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"], "maximumMessageLength": 256, "maximumMessageRatePerSecond": 5, "name": "test-room-1", "tags": {} "updateTime": "2022-03-16T07:22:09+00:00" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的步驟 2:建立聊天室。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 CreateRoom
。
-
以下程式碼範例顯示如何使用 delete-logging-configuration。
- AWS CLI
-
刪除聊天 LoggingConfiguration 資源
下列
delete-logging-configuration範例會刪除指定 ARN 的 LoggingConfiguration 資源。aws ivschat delete-logging-configuration \ --identifier"arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"此命令不會產生輸出。
如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 DeleteLoggingConfiguration
。
-
以下程式碼範例顯示如何使用 delete-message。
- AWS CLI
-
將訊息從指定的房間中刪除
下列
delete-message範例會將事件傳送至指定的房間,引導用戶端刪除指定的訊息:也就是將其從檢視中取消轉譯,以及從用戶端的聊天歷史記錄中將其刪除。aws ivschat delete-message \ --roomIdentifier"arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6"\ --id"ABC123def456"\ --reason"Message contains profanity"輸出:
{ "id": "12345689012" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 DeleteMessage
。
-
以下程式碼範例顯示如何使用 delete-room。
- AWS CLI
-
刪除房間
以下
delete-room範例會刪除指定的房間。已連線的用戶端已中斷連線。成功時,其會傳回具有空白回應內文的 HTTP 204。aws ivschat delete-room \ --identifier"arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6"此命令不會產生輸出。
如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 DeleteRoom
。
-
以下程式碼範例顯示如何使用 disconnect-user。
- AWS CLI
-
中斷使用者與房間的連線
下列
disconnect-user範例會中斷指定使用者與指定房間的所有連線。成功時,其會傳回具有空白回應內文的 HTTP 200。aws ivschat disconnect-user \ --roomIdentifier"arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6"\ --userId"ABC123def456"\ --reason"Violated terms of service"此命令不會產生輸出。
如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 DisconnectUser
。
-
以下程式碼範例顯示如何使用 get-logging-configuration。
- AWS CLI
-
取得 LoggingConfiguration 資源的相關資訊
下列
get-logging-configuration範例取得指定 ARN 的 LoggingConfiguration 資源相關資訊。aws ivschat get-logging-configuration \ --identifier"arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"輸出:
{ "arn": "arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ", "createTime": "2022-09-14T17:48:00.653000+00:00", "destinationConfiguration": { "s3": { "bucketName": "demo-logging-bucket" } }, "id": "ABcdef34ghIJ", "name": "test-logging-config", "state": "ACTIVE", "tags": { "key1" : "value1", "key2" : "value2" }, "updateTime": "2022-09-14T17:48:01.104000+00:00" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 GetLoggingConfiguration
。
-
以下程式碼範例顯示如何使用 get-room。
- AWS CLI
-
取得指定的房間
下列
get-room範例取得指定房間的相關資訊。aws ivschat get-room \ --identifier"arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6"輸出:
{ "arn": "arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6", "createTime": "2022-03-16T04:44:09+00:00", "id": "g1H2I3j4k5L6", "loggingConfigurationIdentifiers": ["arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"], "maximumMessageLength": 256, "maximumMessageRatePerSecond": 5, "name": "test-room-1", "tags": {}, "updateTime": "2022-03-16T07:22:09+00:00" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 GetRoom
。
-
以下程式碼範例顯示如何使用 list-logging-configurations。
- AWS CLI
-
取得 API 請求處理所在的 AWS 區域中,使用者的所有記錄組態的摘要資訊
下列
list-logging-configurations範例列出 API 請求處理所在的 AWS 區域中,使用者的所有 LoggingConfiguration 資源的相關資訊。aws ivschat list-logging-configurations \ --max-results2\ --next-token ""輸出:
{ "nextToken": "set-2", "loggingConfigurations": [ { "arn": "arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ", "createTime": "2022-09-14T17:48:00.653000+00:00", "destinationConfiguration": { "s3": { "bucketName": "demo-logging-bucket" } }, "id": "ABcdef34ghIJ", "name": "test-logging-config", "state": "ACTIVE", "tags": { "key1" : "value1", "key2" : "value2" }, "updateTime": "2022-09-14T17:48:01.104000+00:00" } ... ] }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 ListLoggingConfigurations
。
-
以下程式碼範例顯示如何使用 list-rooms。
- AWS CLI
-
取得目前區域中所有房間的摘要資訊
下列
list-rooms範例會取得請求處理所在 AWS 區域中所有房間的摘要資訊。結果會依 updateTime 的遞減順序排序。aws ivschat list-rooms \ --logging-configuration-identifier"arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"\ --max-results10\ --next-token ""輸出:
{ "nextToken": "page3", "rooms": [ { "arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6", "createTime": "2022-03-16T04:44:09+00:00", "id": "g1H2I3j4k5L6", "loggingConfigurationIdentifiers": ["arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"], "name": "test-room-1", "tags": {}, "updateTime": "2022-03-16T07:22:09+00:00" } ] }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 ListRooms
。
-
以下程式碼範例顯示如何使用 list-tags-for-resource。
- AWS CLI
-
列出 AWS 資源 (例如:房間) 的所有標籤
下列
list-tags-for-resource範例會列出指定資源 ARN (Amazon Resource Name) 的所有標籤。aws ivschat list-tags-for-resource \ --resource-arnarn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6輸出:
{ "tags": { "key1": "value1", "key2": "value2" } }如需詳細資訊,請參閱《Amazon 互動式影片服務 API 參考》中的 Tagging。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 ListTagsForResource
。
-
以下程式碼範例顯示如何使用 send-event。
- AWS CLI
-
將事件傳送至房間
下列
send-event範例會將指定的事件傳送至指定的房間。aws ivschat send-event \ --roomIdentifier"arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6"\ --eventName"SystemMessage"\ --attributes \ "msgType"="user-notification", \ "msgText"="This chat room will close in 15 minutes."輸出:
{ "id": "12345689012" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 SendEvent
。
-
以下程式碼範例顯示如何使用 tag-resource。
- AWS CLI
-
新增或更新 AWS 資源 (例如:房間) 的所有標籤
下列
tag-resource範例會新增或更新指定資源 ARN (Amazon Resource Name) 的標籤。成功時,其會傳回具有空白回應內文的 HTTP 200。aws ivschat tag-resource \ --resource-arnarn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6\ --tags"tagkey1=tagkeyvalue1, tagkey2=tagkeyvalue2"此命令不會產生輸出。
如需詳細資訊,請參閱《Amazon 互動式影片服務 API 參考》中的 Tagging。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 TagResource
。
-
以下程式碼範例顯示如何使用 untag-resource。
- AWS CLI
-
移除 AWS 資源 (例如:房間) 的標籤
下列
untag-resource範例會移除指定資源 ARN (Amazon Resource Name) 的指定標籤。成功時,其會傳回具有空白回應內文的 HTTP 200。aws ivschat untag-resource \ --resource-arnarn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6\ --tag-keys"tagkey1, tagkey2"此命令不會產生輸出。
如需詳細資訊,請參閱《Amazon 互動式影片服務 API 參考》中的 Tagging。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 UntagResource
。
-
以下程式碼範例顯示如何使用 update-logging-configuration。
- AWS CLI
-
更新房間的記錄組態
下列
update-logging-configuration範例會使用指定的資料更新 LoggingConfiguration 資源。aws ivschat update-logging-configuration \ --destination-configurations3={bucketName=demo-logging-bucket}\ --identifier"arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"\ --name"test-logging-config"輸出:
{ "arn": "arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ", "createTime": "2022-09-14T17:48:00.653000+00:00", "destinationConfiguration": { "s3": { "bucketName": "demo-logging-bucket" } }, "id": "ABcdef34ghIJ", "name": "test-logging-config", "state": "ACTIVE", "tags": { "key1" : "value1", "key2" : "value2" }, "updateTime": "2022-09-14T17:48:01.104000+00:00" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 UpdateLoggingConfiguration
。
-
以下程式碼範例顯示如何使用 update-room。
- AWS CLI
-
更新房間的組態
下列
update-room範例會使用指定的資料更新指定的房間組態。aws ivschat update-room \ --identifier"arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6"\ --logging-configuration-identifiers"arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"\ --name"chat-room-a"\ --maximum-message-length256\ --maximum-message-rate-per-second5輸出:
{ "arn": "arn:aws:ivschat:us-west-2:12345689012:room/g1H2I3j4k5L6", "createTime": "2022-03-16T04:44:09+00:00", "id": "g1H2I3j4k5L6", "loggingConfigurationIdentifiers": ["arn:aws:ivschat:us-west-2:123456789012:logging-configuration/ABcdef34ghIJ"], "maximumMessageLength": 256, "maximumMessageRatePerSecond": 5, "name": "chat-room-a", "tags": {}, "updateTime": "2022-03-16T07:22:09+00:00" }如需詳細資訊,請參閱《Amazon 互動式影片服務使用者指南》中的 Amazon IVS 聊天功能入門。
-
如需 API 詳細資訊,請參閱《AWS CLI 命令參考》中的 UpdateRoom
。
-