Rocket.ChatにAPIで投稿するテスト(Postman)
トレーニング期間中で一時利用するチャットが欲しいなあと思い、Rocket.Chatを試してます。
チャットといえばAPIということで、外部からの自動投稿を試してみます。
目次
/api/v1/login
まず、チャンネルに投稿権限のあるユーザーを作って、そのユーザーのユーザー名とパスワードをパラメータでリクエストして、トークンとユーザーIDを取得する必要があります。
エンドポイントは、api/v1/loginでした。
Content-Typeをapplication/x-www-form-urlencodedにして実行しました。
userとpasswordは、ユーザー名とパスワードです。
メソッドはPOSTです。
レスポンスで、authTokenとuserIdが取得できました。
/api/v1/rooms.get
投稿パラメータに、rid(ルームID)が必要なので、APIで取得しました。
ルームというのは、一般的なチャットツールのチャンネルやチャネルと呼ばれるものと同じようです。
先ほど取得した、authTokenとuserIdをHeadersに設定しました。
レスポンスはルームの配列が返ってきて、そこにルームIDが含まれてました。
/api/v1/chat.sendMessage
いよいよ投稿です。
Headersには、rooms.getと同じ認証とフォーマットの情報を設定しました。
パラメータは rid(ルームID)と msg(メッセージ本文)でした。
改行はmsg内の \n で普通にできました。
投稿したトピックのスレッドを参照するツールとしても使えそうです。
もっと多機能な使い方ができそうですが。
ちなみに、Rocket.Chatのサーバーとして使っているEC2インスタンスで、/api/v1/login で取得したトークンを、そのEC2インスタンスから作成したAMIを元に起動したインスタンスでも、認証できました。
ちょっと調べてみると、トークンは無期限らしいです。
/api/v1/logout にリクエストするか、もう一度/api/v1/login リクエストするまでは有効らしいです。
これは本当かどうかわからないので、継続して使ってみます。
最後までお読みいただきましてありがとうございました!
「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。
「AWS認定資格試験テキスト AWS認定クラウドプラクティショナー 改訂第3版」という本を書きました。
「ポケットスタディ AWS認定 デベロッパーアソシエイト [DVA-C02対応] 」という本を書きました。
「要点整理から攻略するAWS認定ソリューションアーキテクト-アソシエイト」という本を書きました。
「AWSではじめるLinux入門ガイド」という本を書きました。
開発ベンダー5年、ユーザ企業システム部門通算9年、ITインストラクター5年目でプロトタイプビルダーもやりだしたSoftware Engineerです。
質問はコメントかSNSなどからお気軽にどうぞ。
出来る限りなるべく答えます。
このブログの内容/発言の一切は個人の見解であり、所属する組織とは関係ありません。
このブログは経験したことなどの共有を目的としており、手順や結果などを保証するものではありません。
ご参考にされる際は、読者様自身のご判断にてご対応をお願いいたします。
また、勉強会やイベントのレポートは自分が気になったことをメモしたり、聞いて思ったことを書いていますので、登壇者の意見や発表内容ではありません。
ad
ad
関連記事
-
-
AWS Client VPNの接続ログを確認しました
AWS Client VPNを設定しましたで証明書とかせっかく作ったので、いろい …
-
-
S3バケットポリシーで特定のVPCエンドポイント以外からのリクエストを拒否しつつメンテナンスはしたい
特定のVPCで実行されているEC2のアプリケーションからのリクエストだけを許可し …
-
-
Amazon BedrockがGAしたので触りました(boto3からも)
Amazon Bedrock Is Now Generally Availabl …
-
-
ユーザーガイドの方法でGithubからCodeCommitへリポジトリを移行する
GitリポジトリをAWS CodeCommitに移行するを参照しました。 環境 …
-
-
AWS Summit 2017 Tokyo Day2 開場~基調講演
昨年に引き続き今年もAWS Summit Tokyoへ行ってきました。 朝一の新 …
-
-
RedmineをELB(ALB)でAutoScalingグループへ負荷分散
高可用なRedmineを作るためのELBの設定です。 高可用なRedmine R …
-
-
Cloud9のデフォルト設定での権限確認(AWS managed temporary credentials)
Cloud9の環境を作成した際のデフォルトアクセス権限は、環境を作成したIAMユ …
-
-
Amazon SES(Simple Email Service)でメール受信時のアクションでLambdaを実行して渡されるデータを見てみる
Amazon SESで受信したメールをS3に保存して、S3のトリガーでLambd …
-
-
特定のIAMロールをLambda(Python)で削除する
やりたいこと 特定アカウントの特定の名前が含まれるIAMロールをまとめて削除した …
-
-
CloudFormationスタックポリシーでスタック更新を防止する
CloudFormationのスタックにスタックポリシーを設定することによって、 …




