Skip to content

OIDCベースのSSOの設定

このページでは、OpenID Connect(OIDC)プロトコルに基づくシングルサインオン(SSO)の設定と使用方法について説明します。

前提条件

シングルサインオン(SSO)の基本概念に慣れていることを推奨します。

対応するOIDCプロバイダー

EMQXダッシュボードは、OIDCプロトコルをサポートするアイデンティティサービスと連携して、OIDCベースのSSOを実現できます。例として以下があります:

Microsoft Entra IDとの連携によるSSOの設定

このセクションでは、Microsoft Entra IDをアイデンティティプロバイダー(IdP)として使用し、SSOを設定する方法を案内します。Microsoft側とEMQXダッシュボード側の両方で設定を完了する必要があります。

ステップ1:EMQXダッシュボードでOIDCを有効化

  1. EMQXダッシュボードで、System -> SSO に移動します。
  2. OIDCカードのEnableボタンをクリックします。

ステップ2:Microsoft Entra IDにアプリケーションを登録

  1. 管理者としてMS Azureポータルにログインします。

  2. Microsoft Entra ID -> Enterprise Applications -> New Applicationに進み、Create your own applicationをクリックします。

    Microsoft Entra IDで独自アプリケーションを作成
  3. アプリケーション名(例:EMQX Dashboard)を入力し、Register an application to integrate with Microsoft Entra ID (App you're developing) を選択して、Createをクリックします。

    Microsoft Entra ID OIDCアプリケーションのパラメータ
  4. Register an applicationページで、サポートするアカウントの種類を選択し、EMQXダッシュボードのステップ1で提供された情報を使ってRedirect URLを設定します:

    • Redirect URLWebを選択し、ダッシュボードで提供されたSign-in Redirect URI(例:http://localhost:18083/api/v5/sso/oidc/callback)を入力します。
  5. Certificates and Secrets -> Client secretsタブに移動し、New client secretをクリックします。説明を入力し、有効期限を選択してAddをクリックします。生成されたシークレット値をコピーしてください。これはステップ3で必要になります。

ステップ3:EMQXダッシュボードの設定を完了

  1. 設定ページで以下の情報を入力します:

    • ProviderGenericのままにします。

    • Issuer URL:これはOpenID Connect metadata documentに対応し、ステップ2のアプリケーション概要ページのEndpointsタブで確認できます。ただし、/.well-known/openid-configurationの部分はEMQXが自動で付加するため含めません。例:https://login.microsoftonline.com/<tenant_id>/v2.0<tenant_id>はディレクトリ(テナント)ID)。

    • Client IDステップ2のアプリケーション概要ページにあるApplication (client) IDに対応します。

      Microsoft Entra ID OIDCアプリ設定
    • Client Secretステップ2で生成したシークレット値を使用します。

    • Dashboard Address:ユーザーがダッシュボードにアクセスするベースURLを入力します(例:http://localhost:18083)。このアドレスはIdP側の設定で使用するSSO AddressおよびMetadata Addressの生成に自動的に組み合わされます。

      Microsoft Entra ID OIDCダッシュボード設定
  2. Updateをクリックして設定を完了します。

Oktaとの連携によるSSOの設定

このセクションでは、Oktaをアイデンティティプロバイダー(IdP)として使用し、SSOを設定する方法を案内します。Okta側とEMQXダッシュボード側の両方で設定を完了する必要があります。

ステップ1:EMQXダッシュボードでOIDCを有効化

  1. EMQXダッシュボードで、System -> SSO に移動します。
  2. OIDCカードのEnableボタンをクリックします。

ステップ2:OktaのアプリケーションカタログにOIDCアプリケーションを追加

  1. 管理者としてOktaにログインし、Okta Admin Consoleにアクセスします。

  2. Applications -> Applicationsページに移動し、Create App integrationボタンをクリックします。ポップアップでサインイン方法としてOIDC - OpenID Connectを選択します。

  3. Application typeとしてWeb Applicationを選択し、Nextをクリックします。

  4. General Settingsタブでアプリケーション名(例:EMQX Dashboard)を入力し、Nextをクリックします。

  5. LOGINタブで、EMQXダッシュボードから提供された情報を使って設定します:

    • Sign-in redirect URIs:ダッシュボードのOIDC Settingsページで提供されたSign-in Redirect URI(例:http://localhost:18083/api/v5/sso/oidc/callback)を入力します。
    • その他の設定は任意で、必要に応じて調整してください。
  6. 設定内容を確認し、Saveをクリックします。

詳細はOktaドキュメントをご参照ください。

ステップ3:EMQXダッシュボードの設定を完了

  1. OIDC Settingsページで以下の情報を入力します:
    • ProviderOktaを選択するか、他のプロバイダーの場合はGenericを選択します。
    • Issuer URL:Oktaの認可サーバーのURL(例:https://example-org.okta.com)。
    • Client IDステップ2で作成したアプリケーションからコピーします。
    • Client Secretステップ2で作成したアプリケーションからコピーします。
    • Dashboard Address:ユーザーがダッシュボードにアクセスするベースURL(例:http://localhost:18083)。IdP側設定用のSSO AddressおよびMetadata Addressの生成に自動的に組み合わされます。
  2. Updateをクリックして設定を完了します。

詳細設定

Advanced Settingsセクションでは、EMQXがOIDCプロバイダーからユーザー情報を取得する方法や認証動作を細かく調整できます。

フィールド名説明デフォルト値
Scopes認証時に要求するOIDCスコープ。これらのスコープによりIdPが返すユーザー情報が決まります。OIDC認証には最低でもopenidスコープが必要です。openid
Name VariableOIDCユーザー属性をEMQXダッシュボードのユーザー名にマッピングするためのテンプレート。IdPから返されるクレームを参照可能です。${sub}
Name Variable Sourceダッシュボードのユーザー名を構築するためにユーザー情報を抽出するソースを指定します。選択肢:
User Info Endpoint/userinfoエンドポイントから返されるユーザー情報を使用。
ID Token:認証時に返されるIDトークン内のクレームを使用。
User Info Endpoint
Role Sourceダッシュボードユーザーのロールを構築するためにユーザー情報を抽出するソースを指定します。選択肢は上記と同様です。User Info Endpoint
Role Expressionjq式でOIDCユーザー属性をEMQXダッシュボードのユーザーロールにマッピングします。プログラムはIdPから返されるクレームを参照可能で、必ず1つの文字列を返す必要があります。有効なロールは以下です:
"viewer"
"administrator"
それ以外の結果の場合、ユーザーは作成されません。このフィールドが未設定の場合、EMQXはユーザーをviewerロールで作成するか、既存ユーザーの場合は既存のロールを維持します。
未設定
Namespace Sourceダッシュボードユーザーのマルチテナンシーネームスペースを構築するためにユーザー情報を抽出するソースを指定します。選択肢は上記と同様です。User Info Endpoint
Namespace Expressionjq式でOIDCユーザー属性をEMQXダッシュボードのユーザーネームスペースにマッピングします。式はIdPから返されるクレームを参照可能で、必ず1つの値を返す必要があります。値は既存のネームスペース名の文字列か、グローバルネームスペースを示すnullでなければなりません。それ以外の結果の場合、ユーザーは作成されません。このフィールドが未設定の場合、EMQXはユーザーをグローバルネームスペースに配置するか、既存ユーザーの場合は既存のネームスペースを維持します。未設定
Session ExpiryユーザーがOIDCでログイン後、ダッシュボードのセッションが有効である期間(秒単位)です。30
Enable PKCE認可コードフローのセキュリティを強化するProof Key for Code Exchange(PKCE)を有効にします。無効
Preferred Authentication Methodsトークンエンドポイントと通信する際に使用するクライアント認証方法を定義します。複数の方法を設定可能で、順番に試行されます。client_secret_post, client_secret_basic, none
Fallback Methodsプロバイダーのメタデータに明示的な署名アルゴリズムがない場合にIDトークンの検証に使用するフォールバック署名アルゴリズムを指定します。RS256
JSON Web Key (JWK)IdPがJWKSエンドポイントを提供しない場合にトークン署名の検証に使用するオプションの静的JSON Web Key設定です。None

ログインとユーザー管理

OIDC SSOを有効化すると、EMQXダッシュボードのログインページにSSOオプションが表示されます。OIDCボタンをクリックすると、OIDCプロバイダーのログインページに遷移し、ユーザーに割り当てられた認証情報でログインできます。

OIDCログイン画面Oktaログイン画面

認証に成功すると、EMQXは自動的にダッシュボードユーザーを追加します。追加されたユーザーはUsersで管理でき、ロールや権限の割り当てが可能です。

ログアウト

ユーザーはダッシュボードの上部ナビゲーションバーにあるユーザー名をクリックし、ドロップダウンメニューのLogoutボタンをクリックしてログアウトできます。なお、これはダッシュボードからのログアウトのみであることにご注意ください。