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を有効化
- EMQXダッシュボードで、System -> SSO に移動します。
- OIDCカードのEnableボタンをクリックします。
ステップ2:Microsoft Entra IDにアプリケーションを登録
管理者としてMS Azureポータルにログインします。
Microsoft Entra ID -> Enterprise Applications -> New Applicationに進み、Create your own applicationをクリックします。

アプリケーション名(例:
EMQX Dashboard)を入力し、Register an application to integrate with Microsoft Entra ID (App you're developing) を選択して、Createをクリックします。
Register an applicationページで、サポートするアカウントの種類を選択し、EMQXダッシュボードのステップ1で提供された情報を使ってRedirect URLを設定します:
- Redirect URL:
Webを選択し、ダッシュボードで提供されたSign-in Redirect URI(例:http://localhost:18083/api/v5/sso/oidc/callback)を入力します。
- Redirect URL:
Certificates and Secrets -> Client secretsタブに移動し、New client secretをクリックします。説明を入力し、有効期限を選択してAddをクリックします。生成されたシークレット値をコピーしてください。これはステップ3で必要になります。
ステップ3:EMQXダッシュボードの設定を完了
設定ページで以下の情報を入力します:
Provider:
Genericのままにします。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に対応します。

Client Secret:ステップ2で生成したシークレット値を使用します。
Dashboard Address:ユーザーがダッシュボードにアクセスするベースURLを入力します(例:
http://localhost:18083)。このアドレスはIdP側の設定で使用するSSO AddressおよびMetadata Addressの生成に自動的に組み合わされます。
Updateをクリックして設定を完了します。
Oktaとの連携によるSSOの設定
このセクションでは、Oktaをアイデンティティプロバイダー(IdP)として使用し、SSOを設定する方法を案内します。Okta側とEMQXダッシュボード側の両方で設定を完了する必要があります。
ステップ1:EMQXダッシュボードでOIDCを有効化
- EMQXダッシュボードで、System -> SSO に移動します。
- OIDCカードのEnableボタンをクリックします。
ステップ2:OktaのアプリケーションカタログにOIDCアプリケーションを追加
管理者としてOktaにログインし、Okta Admin Consoleにアクセスします。
Applications -> Applicationsページに移動し、Create App integrationボタンをクリックします。ポップアップでサインイン方法として
OIDC - OpenID Connectを選択します。Application typeとして
Web Applicationを選択し、Nextをクリックします。General Settingsタブでアプリケーション名(例:
EMQX Dashboard)を入力し、Nextをクリックします。LOGINタブで、EMQXダッシュボードから提供された情報を使って設定します:
- Sign-in redirect URIs:ダッシュボードのOIDC Settingsページで提供されたSign-in Redirect URI(例:
http://localhost:18083/api/v5/sso/oidc/callback)を入力します。 - その他の設定は任意で、必要に応じて調整してください。
- Sign-in redirect URIs:ダッシュボードのOIDC Settingsページで提供されたSign-in Redirect URI(例:
設定内容を確認し、Saveをクリックします。
詳細はOktaドキュメントをご参照ください。
ステップ3:EMQXダッシュボードの設定を完了
- OIDC Settingsページで以下の情報を入力します:
- Provider:
Oktaを選択するか、他のプロバイダーの場合は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の生成に自動的に組み合わされます。
- Provider:
- Updateをクリックして設定を完了します。
詳細設定
Advanced Settingsセクションでは、EMQXがOIDCプロバイダーからユーザー情報を取得する方法や認証動作を細かく調整できます。
| フィールド名 | 説明 | デフォルト値 |
|---|---|---|
| Scopes | 認証時に要求するOIDCスコープ。これらのスコープによりIdPが返すユーザー情報が決まります。OIDC認証には最低でもopenidスコープが必要です。 | openid |
| Name Variable | OIDCユーザー属性をEMQXダッシュボードのユーザー名にマッピングするためのテンプレート。IdPから返されるクレームを参照可能です。 | ${sub} |
| Name Variable Source | ダッシュボードのユーザー名を構築するためにユーザー情報を抽出するソースを指定します。選択肢: User Info Endpoint: /userinfoエンドポイントから返されるユーザー情報を使用。ID Token:認証時に返されるIDトークン内のクレームを使用。 | User Info Endpoint |
| Role Source | ダッシュボードユーザーのロールを構築するためにユーザー情報を抽出するソースを指定します。選択肢は上記と同様です。 | User Info Endpoint |
| Role Expression | jq式でOIDCユーザー属性をEMQXダッシュボードのユーザーロールにマッピングします。プログラムはIdPから返されるクレームを参照可能で、必ず1つの文字列を返す必要があります。有効なロールは以下です:"viewer" "administrator" それ以外の結果の場合、ユーザーは作成されません。このフィールドが未設定の場合、EMQXはユーザーをviewerロールで作成するか、既存ユーザーの場合は既存のロールを維持します。 | 未設定 |
| Namespace Source | ダッシュボードユーザーのマルチテナンシーネームスペースを構築するためにユーザー情報を抽出するソースを指定します。選択肢は上記と同様です。 | User Info Endpoint |
| Namespace Expression | jq式で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プロバイダーのログインページに遷移し、ユーザーに割り当てられた認証情報でログインできます。


認証に成功すると、EMQXは自動的にダッシュボードユーザーを追加します。追加されたユーザーはUsersで管理でき、ロールや権限の割り当てが可能です。
ログアウト
ユーザーはダッシュボードの上部ナビゲーションバーにあるユーザー名をクリックし、ドロップダウンメニューのLogoutボタンをクリックしてログアウトできます。なお、これはダッシュボードからのログアウトのみであることにご注意ください。