This is an auto-generated translation

OpenID Connect SSO の概要

OpenID Connect (OIDC) は OAuth 2.0 ベースの認証プロトコルで、大手テクノロジー企業で採用されています。

OIDC の詳細

ベーシック SSO

選択した機能に関係なく、ベーシック SSO の設定要件は同じです。ロイヤルティまたはクレジット カードの実装を追加すると、追加情報が必要になります。

設定要件

テンプレートサイトへの OIDC SSO アクセスを適切に設定するには以下が必要です。

  • API (authorize、token、userProfile, JWKS)
  • ClientId
  • クライアントシークレット
  • ResponseMode
  • isNounceEnabled
  • customerDetailsAPIKey (利用可能な場合)

認証フロー

OIDC Authorization flows

認証エンドポイント

GET /authorize エンドポイントは認証と承認に使用されます。この関数は、次のような場合、クライアントに認可許可または認可コードを返します。logged-in. ブラウザのリダイレクトです。

リクエストパラメーター

パラメーター説明データタイプサンプル値必須/必須ではない
client_idクライアントを識別します。ID プロバイダー (IDP) に事前に登録されている値と一致する必要があります。手動クライアント登録時、または Dynamic Client Registration API 経由で取得されます。文字列 必須
nonceリプレイ攻撃を軽減するために使用されます。この値は ID トークンで返されます。文字列 必須
prompt検証に必要なインタラクションのタイプ。Empty "の場合、認証されていなければログインする必要があります。none」の場合、IDPはログインを要求しませんが、ログインしていれば認証コードを返し、ログインしていなければエラーを返します。文字列有効な値 :
なしOR空
必須ではない
redirect_uri認証コードまたはトークンを送信するコールバックの場所。クライアント登録時に IDP に事前登録された値と一致する必要があります。文字列 必須
response_typecode (IDP) の値。文字列 必須
response_mode承認レスポンスを返す方法。文字列有効な値 :
query
必須ではない
scopeプロフィールの詳細を取得するために使用されるアクセストークン。認証リクエストに必要です。文字列OpenID、profile、email必須
stateインタラクションの状態。この値はトークンで返され、ユーザーがクリックスルーし、認証して本来興味のあるページに戻ることを可能にします。値には英数字、カンマ、ピリオド、アンダースコア、ハイフンを含めることができます。文字列 必須
ui_localesユーザーインターフェースに使用される言語とスクリプト。文字列en_CA, fr_CA必須ではない
audience意図した受取人文字列パートナーによる定義必須ではない

レスポンスパラメーター

パラメーター説明データタイプ必須/必須ではない
codeクライアントを識別する認証コード。IDP に事前に登録されている値と一致する必要があります。手動クライアント登録時、または Dynamic Client Registration API 経由で取得されます。文字列必須
stateインタラクションの状態。この値はトークンで返され、ユーザーがクリックスルーし、認証して本来興味のあるページに戻ることを可能にします。値には英数字、カンマ、ピリオド、アンダースコア、ハイフンを含めることができます。文字列必須

認証URLのサンプル

https://example.com/authorize?client_id={clientID}&response_type=code&state=d6b93799-404b-4205-9bb3-c579b1180428&scope=openid email profile&nounce=234567687867&redirect_uri=https://{ExpediaDomain}/sso/auth

コールバックURLのサンプル

https://{ExpediaDomain}/sso/auth?code=12345678&state=d6b93799-404b-4205-9bb3-c579b1180428

トークンのエンドポイント

POST /tokenエンドポイントは、認可グラントまたはコードを提示してアクセストークンとIDトークンを取得するために使用されるバックエンドAPI呼び出しです。

リクエストパラメーター

パラメーター説明データタイプ必須/必須ではない
grant_typeトークンの作成を承認するために IDP が使用するメカニズム。値 : authorization_code文字列必須
redirect_uri承認が送信されたコールバックの場所を指定します。この値は、元の authorization_code の生成に使われた redirect_uri と一致する必要があります。一致しない場合、トークンエンドポイントでエラーが発生します。文字列必須
code/authorize 呼び出しレスポンスで受信したクライアント識別コード。文字列必須

リクエストヘッダー

フィールド説明データタイプサンプル値必須/必須ではない
accept「application/json」とする必要があります。文字列application/json必須
authorizationクライアント ID とシークレットを Base64 でエンコードします。HTTP 承認ヘッダーにエンコードされた情報を使用します。文字列Basic<Base64 でエンコードされたクライアント ID とシークレット>必須
Content-Type「application/x-www-form-urlencoded」にする必要があります。文字列application/x-www-form-urlencoded必須

レスポンスパラメーター

フィールド説明データタイプ
access_tokenアクセストークン文字列
token_typeトークンの対象者文字列
expires_inアクセストークンの有効期限 (秒)整数型
scopeアクセストークンに含まれるスコープ文字列
id_tokenOpenID スコープが許可されている場合に返される識別子文字列

ID_token

ID_token は JSON Web トークン (JWT) で、クレームと呼ばれる認証情報の断片を含んでいます。以下の表のように、エクスペディアのテンプレートソリューションではクレームとして headerpayloadsignature を使用しています。

ヘッダークレーム

フィールド説明データタイプ必須/必須ではない
alg使用されるデジタル署名アルゴリズムを特定 (常に RS256)文字列必須ではない
kidキー ID : ID トークンの検証に使用される公開鍵を特定 (対応する公開鍵は、JSON Web Key Set (JWKS) 経由で見つけることができます)文字列必須

ペイロードクレーム

フィールド説明データタイプ必須/必須ではない
amr認証方法の識別子となる文字列の JSON 配列配列必須ではない
audこの ID トークンの対象者を特定 (アプリケーションの OAuth 2.0 クライアント ID のいずれか)文字列必須
auth_timeエンドユーザーが認証された時刻 (Unix時間 (秒) で表される)整数型必須ではない
expID トークンの有効期限 (Unix時間 (秒) で表される)整数型必須
iatID トークンが発行された時刻 (Unix時間 (秒) で表される)整数型必須ではない
idpID プロバイダーのインジケーター文字列必須
issこの ID トークンを発行した承認サーバーの URL文字列必須ではない
jtiデバッグと失効を目的とした、この ID トークンの一意の識別子文字列必須
sub承認呼び出しの対象 (ユーザー) の一意の識別子文字列必須ではない
verID トークンのセマンティックバージョン整数型必須

署名クレーム

署名の検証:署名は、JWKS endpoint およびアルゴリズムに対応する適切な鍵(client_id を使用して取得)に対して検証されます。

サンプル・トークンCURL

curl --location 'https://example.com/token’ \
--header 'Content-Type: application/x-www-form-urlencoded' \
--header 'Authorization: Basic {encoded ClientID:clientSecret}' \
--data-urlencode 'grant_type=authorization_code' \
--data-urlencode 'redirect_uri=https://{ExpediaDomain}/sso/auth’ \
--data-urlencode 'code={Authorization code after login as part of callback to Expedia /sso/auth endpoint}'

トークンレスポンスのサンプル

{
    "access_token": "eyJhbGciOi.JSUzI1NiIsImtpZCI6Ilk1MkFDVXd3QV9SUzI1NiIsInBp.LmF0bSI6ImlrY20ifQ",
    "id_token": "eyJhbGciOiJSUzI1NiIsImtpZCI6.IllEQnJQdlllYlRwa1laODZoaGk1MkFDVX.d3QV9SUzI1NiJ9",
    "token_type": "Bearer",
    "expires_in": 1799
}

ユーザー情報エンドポイント

GET /userinfoエンドポイントは、提供されたアクセストークンに基づいて認証されたユーザーに関するクレームを返すバックエンドAPI呼び出しです。

リクエストヘッダ

フィールド説明データタイプサンプル値必須/必須ではない
ClientIdクライアントを識別します。ID プロバイダー (IDP) に事前に登録されている値と一致する必要があります。手動クライアント登録時、または Dynamic Client Registration API 経由で取得されます。文字列 必須
Authorizationユーザーを認証するためのクレデンシャルまたはトークンを送信するために使用されるHTTPヘッダー。文字列ベアラーaccess_token]必須

レスポンス

フィールド説明データタイプサンプル値必須/必須ではない
membershipIdお客様の口座を一意に識別する識別子文字列 必須
optIn顧客がマーケティングメールの受信を許可しているかどうかのブール値フラグBoolean (ブール型)真/偽必須ではない
languageIdユーザーの希望言語文字列Ja, fr必須ではない
channelTypeユーザーがアプリケーションとやりとりするさまざまなプラットフォーム文字列ウェブ、モバイル、タブレット必須ではない
firstNameお客様のお名前文字列 必須
middleNameお客様のミドルネーム文字列 必須ではない
lastNameお客様の姓文字列 必須ではない
emailお客様のEメールアドレス文字列 必須ではない
programAccountLoyalty-relatedインフォメーションprogramAccountオブジェクトの詳細については、以下のAdd loyalty ->programAccount セクションを参照してください。必須ではない
CardDetailsお客様のクレジットカード情報CardDetailsオブジェクトの詳細については、以下のRestrict payment card ->Payload details セクションを参照してください。必須ではない

サンプルユーザー情報CURL

curl --location 'https://example.com/userinfo' \
--header 'client_id: {clientId}' \
--header 'Authorization: Bearer {acess_token from token endpoint}'

Userinfoレスポンスのサンプル

{
  "membershipId": "12345678",
  "languageID": "en",
  "middleName": "MiddleName",
  "lastName": "LastName",
  "firstName": "FirstName",
  "email": "test@expediagroup.com",
  "programAccount": {
    "programId": "Gold",
    "loyaltyAccountBalance": {
      "value": "10000",
      "currency": "Points"
    }
  }
}

ロイヤルティの追加

テンプレートサイトの一部として、顧客が旅行の購入でロイヤルティポイントを獲得できる機能を含めることができます。テンプレートでは、必要に応じて顧客が貯めたロイヤルティポイントを利用して旅行を購入できるようにすることもできます。

多くの値と同様に、標準実装と同じ設定要件が適用されます。異なるものだけをここに掲載します。

標準のuser information に加え、ロイヤルティ プログラムのセットアップには以下の値が含まれます。

programAccount

フィールド説明データ型必須/必須ではない
programId顧客が参加しているロイヤルティプログラムの識別子、またはロイヤルティプログラムに関連付けられているステータス名文字列必須
loyaltyAccountNumber顧客のロイヤルティアカウント番号 (ロイヤルティオペレーションにセカンダリ識別子 (一意の membershipId 以外) が必要な場合にのみ入力する必要があります)文字列必須ではない
lastFourDigitsOfCreditCard顧客が予約に使用したクレジットカードの下 4 桁整数型必須ではない
accountNameプログラム名 (ステータス名と異なる場合)文字列必須ではない
loyaltyConversionRatio支払いにおける獲得ポイント率 (例 : $1 = 1 ポイント)倍精度型必須ではない
loyaltyAccountBalance顧客が獲得したロイヤルティポイントの現在の残高金額
(オブジェクトの詳細については、以下の金額のセクションを参照してください。)
必須ではない

金額

フィールド説明データ型必須/必須ではない
valueロイヤルティ残高 (loyaltyAccountBalance の下にネスト)ロング必須
currencyロイヤルティプログラムで使用される獲得通貨 (例 : さまざまな通貨、ポイント、マイル) (loyaltyAccountBalance の下にネスト)文字列必須

支払いカードの制限

顧客が組織のクレジットカードを使用して予約するのを義務付けるようサイトを設定できます。すべてのテンプレートソリューションですべての主要なクレジットカードまたはデビットカード、および (米国では) PayPal を受け付けることができるため、これは必須ではありません。

クレジットカードの安全性と保管

組織のカスタムクレジット カードを使用して購入することを義務付けた場合でも、心配は無用です。クレジットカードは次のように扱われます。

  • 顧客のエクスペディアプロフィールにリンクされた、トークン化された形式でカード情報が保存されます。暗号化されていない状態で保存されることは決してありません。
  • 人間は暗号化されていないカードデータにアクセスできず、安全な IAM ログイン情報を使用しないと復号化できなくなっています。
  • カードがチェックアウトページにプリロードされると、カード番号ではなくカードの説明のみが表示されます。
  • 保存されたカードで予約を完了する場合、顧客はカードのセキュリティコードを入力する必要があります。

設定要件

標準実装の設定要件に加え、クレジットカードが追加されると以下が必要になります。

  • AuthnRequest パラメーターに使用するエンドポイント
  • 署名検証用の公開鍵

エクスペディアでは自社の秘密鍵を使用して AuthnRequest ペイロードに署名し、貴社側で署名検証を実行してもらうためにエクスペディアの公開鍵を使用します。

ペイロードの詳細

顧客がサイトにログインすると、クレジットカード SSO では、標準実装で説明されている属性とともに、セキュアなエクスペディア SSO エンドポイントに 2 つの取引パラメーターを送信します。

  • ユーザー情報 API : 署名され暗号化されたアサーションを持つ、エンコードされ署名されたレスポンスペイロード。
  • RelayState : ランディングページ URL へのディープリンク。
Information

注意

ロイヤルティポイントを獲得するようにテンプレートサイトが設定されている場合は、ProgramAccount 情報も必要です。

ペイロードには次のクレジットカードの詳細も含まれます。

フィールド説明必須/必須ではない
cardNumber請求対象のクレジットカードの番号必須
cardType使用されるカードの種類 (例 : Visa、MasterCard、American Express)必須
expirationDate使用されるクレジットカードの有効期限必須
BillingAddress使用されたカードと関連付けられているクレジットカード登録住所必須
addressCategoryCode自宅や会社などの請求先の住所の種類 (BillingAddress の下にネスト)必須
firstAddressLineクレジットカード登録住所の 1 行目 (BillingAddress の下にネスト)必須
secondAddressLineクレジットカード登録住所の 2 行目 (BillingAddress の下にネスト)必須ではない
thirdAddressLineクレジットカード登録住所の 3 行目 (BillingAddress の下にネスト)必須ではない
cityNameクレジットカード登録住所の市町村 (BillingAddress の下にネスト)必須
provinceNameクレジットカード登録住所の都道府県 (BillingAddress の下にネスト)必須
postalCodeクレジットカード登録住所の郵便番号 (BillingAddress の下にネスト)必須
countryCodeクレジットカード登録住所の国コード (BillingAddress の下にネスト)必須
このページは役に立ちましたか ?
このコンテンツに改善が必要な点があれば、
サービス向上にご協力いただきありがとうございます。