質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.32%
AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

78閲覧

userInfoエンドポイントでのカスタム属性の取得について(Amazon Cognito)

takabooo

総合スコア24

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2025/03/18 05:28

実現したいこと

AWSのCognitoで、任意のユーザーにカスタム属性を設定しました(genderに対して、「1」という値を設定)。このとき、AWSの以下のURLにあるように、GET /oauth2/userInfo にリクエストしても、カスタム属性が取得できません。subやemailなどの情報は取得できます。userInfoエンドポイントにてカスタム属性を取得するには何か特別な設定が必要なのでしょうか。よろしくお願いいたします。

https://docs.aws.amazon.com/ja_jp/cognito/latest/developerguide/userinfo-endpoint.html

発生している問題・分からないこと

GET /oauth2/userInfoにリクエストを送っても、カスタム属性が参照できない。レスポンスは帰ってきているので、access_token等の設定は間違っていないと考えています。

該当のソースコード

ACCESS_TOKEN=<<x-amzn-oidc-accesstokenの値>> COGNITO_URL=<<Cognitoドメイン>> curl -H "Authorization: Bearer ${ACCESS_TOKEN}" \ ${COGNITO_URL}/oauth2/userInfo

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

AWSのuserInfoエンドポイントのページの解説を見た

補足

特になし

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

恐らくですが、そのエンドポイントが返すのはOIDCの仕様に基づいた項目のみで、カスタム属性はデフォルトでは含まれないのではないでしょうか。

単にカスタム属性を取得したいという目的ならCognitoのGetUserAPIを使用して取得できます

あくまでOIDCのフローとして/oauth2/userInfoから取得したいということなら、Lambdaトリガーで属性をカスタマイズしてあげるなどが必要そうです。
トークン生成前の Lambda トリガー
(自分でやったことがないので、うまくいかなかったらすみません…)

投稿2025/03/18 07:24

yu_1985

総合スコア7619

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

takabooo

2025/03/18 10:58

回答ありがとうございます。 @aws-sdk/client-cognito-identity-provider を使ってみたところ、カスタム属性も取得でそうでした。ありがとうございます。たすかりました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.32%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問