この記事では、Smallstep SSH と Microsoft Entra ID の両方で実行して、自動ユーザー プロビジョニングを構成するために必要な手順について説明します。 構成すると、Microsoft Entra ID で、Microsoft Entra プロビジョニング サービスを使用して、Smallstep SSH に対するユーザーとグループのプロビジョニングおよびプロビジョニング解除が自動的に行われます。 このサービスの機能、しくみ、よく寄せられる質問の重要な詳細については、「Microsoft Entra IDを使用して SaaS アプリケーションへのユーザー プロビジョニングとプロビジョニング解除を自動化する」を参照してください。
サポートされている機能
- Smallstep SSH でユーザーを作成する
- アクセスが不要になった場合に Smallstep SSH のユーザーを削除する
- Microsoft Entra ID と Smallstep SSH の間でユーザー属性の同期を維持します。
- Smallstep SSH でグループとグループ メンバーシップをプロビジョニングする
- Smallstep SSH へのシングル サインオン (推奨)
[前提条件]
この記事で説明するシナリオでは、次の前提条件が既にあることを前提としています。
- アクティブなサブスクリプションを持つ Microsoft Entra ユーザー アカウント。 まだアカウントがない場合は、無料でアカウントを作成することができます。
- 次のいずれかのロール:
- Smallstep SSH アカウント。
手順 1: プロビジョニングデプロイメントを計画する
- プロビジョニング サービスのしくみを確認します。
- プロビジョニングの対象範囲にいるユーザーを決定します。
- Microsoft Entra ID と Smallstep SSH の間でマップするデータを決定します。
手順 2: Microsoft Entra ID を使ったプロビジョニングをサポートするように Smallstep SSH を構成する
Smallstep SSH アカウントにログインします。
[Users](ユーザー) タブに移動し、ID プロバイダーとして Microsoft Entra ID を選択します。
次のページで、Microsoft Entra テナント ID と許可リストを指定して OIDC を構成します。
[SCIM Details](SCIM の詳細) で、SCIM のテナント URL とシークレット トークンをコピーして保存します。 これらの値は、Smallstep SSH アプリケーションの [プロビジョニング] タブの [ テナント URL ] フィールドと [ シークレット トークン ] フィールドに入力されます。
注意! Active Directory グループを介して、Smallstep マネージド ホストへのアクセスを許可する必要があります。 たとえば、SSH ユーザー用と sudo ユーザー用のグループがそれぞれある場合があります。 アクセス制御の詳細については、「Microsoft Entra Quickstart」と「Host Quickstart Guide」を参照してください。
手順 3: Microsoft Entra アプリケーション ギャラリーから Smallstep SSH を追加する
Microsoft Entra アプリケーション ギャラリーから Smallstep SSH を追加して、Smallstep SSH へのプロビジョニングの管理を開始します。 SSO のために以前 Smallstep SSH を設定している場合は、同じアプリケーションを使用できます。 ただし、最初に統合をテストするときは、別のアプリを作成することをお勧めします。 ギャラリー からアプリケーションを追加する方法の詳細については、を参照してください。
手順 4: プロビジョニングのスコープに含まれるユーザーを定義する
Microsoft Entra プロビジョニング サービスを使用すると、アプリケーションへの割り当てに基づいて、またはユーザーまたはグループの属性に基づいてプロビジョニングされるユーザーをスコープできます。 割り当てに基づいてアプリにプロビジョニングされるユーザーのスコープを設定する場合は、 手順を使用してユーザーとグループをアプリケーションに割り当てることができます。 ユーザーまたはグループの属性のみに基づいてプロビジョニングする対象を決定する場合、スコープフィルターを使用できます。
小規模から始めます。 すべてのユーザーとグループにロールアウトする前に、少数のユーザーとグループでテストします。 プロビジョニングのスコープが割り当てられたユーザーとグループに設定されている場合は、1 つまたは 2 つのユーザーまたはグループをアプリに割り当てることで、これを制御できます。 スコープがすべてのユーザーとグループに設定されている場合は、 属性ベースのスコープ フィルターを指定できます。
追加のロールが必要な場合は、 アプリケーション マニフェストを更新 して新しいロールを追加できます。
手順 5: Smallstep SSH への自動ユーザー プロビジョニングを構成する
このセクションでは、Microsoft Entra ID でのユーザー割り当てやグループ割り当てに基づいて、Smallstep SSH でユーザーが作成、更新、無効化されるように Microsoft Entra プロビジョニング サービスを構成する手順について説明します。
Microsoft Entra ID で Smallstep SSH の自動ユーザー プロビジョニングを構成するには:
クラウド アプリケーション管理者以上として Microsoft Entra 管理センターにサインインします。
Entra ID>企業向けアプリケーションを参照する
アプリケーションの一覧で [Smallstep SSH] を選択します。
[プロビジョニング] タブを選択します。
[プロビジョニング モード] を [自動] に設定します。
[管理者資格情報] セクションで、Smallstep SSH の [テナントの URL] と [シークレット トークン] を入力します。 [ テスト接続] を選択して、Microsoft Entra ID が Smallstep SSH に接続できることを確認します。 接続できない場合は、使用している Smallstep SSH アカウントに管理者アクセス許可があることを確認してから、もう一度試します。
[ 通知メール ] フィールドに、プロビジョニング エラー通知を受け取るユーザーまたはグループのメール アドレスを入力し、[ エラーが発生したときに電子メール通知を送信 する] チェック ボックスをオンにします。
保存 を選択します。
[マッピング] セクションの [Synchronize Microsoft Entra Users to Smallstep SSH](Microsoft Entra ユーザーを Smallstep SSH に同期する) を選択します。
[属性マッピング] セクションで、Microsoft Entra ID から Smallstep SSH に同期されるユーザー属性を確認します。 [Matching](照合) プロパティとして選択されている属性は、更新処理で Smallstep SSH のユーザー アカウントとの照合に使用されます。 一致するターゲット属性を変更する場合は、Smallstep SSH API がその属性に基づくユーザーのフィルター処理をサポートしていることを確認する必要があります。 [保存] ボタンをクリックして変更をコミットします。
特性 タイプ フィルター処理のサポート ユーザー名 糸 ✓ 活動中 ブール値 表示名 糸 emails[type eq "仕事"].value 糸 名前.名 糸 名前.姓 糸 [マッピング] セクションで、[Synchronize Microsoft Entra groups to Smallstep SSH] (Microsoft Entra グループを Smallstep SSH に同期する) を選択します。
[属性マッピング] セクションで、Microsoft Entra ID から Smallstep SSH に同期されるグループ属性を確認します。 [Matching](照合) プロパティとして選択されている属性は、更新処理で Smallstep SSH のグループとの照合に使用されます。 [保存] ボタンをクリックして変更をコミットします。
特性 タイプ フィルター処理のサポート 表示名 糸 ✓ メンバー リファレンス スコープ フィルターを構成するには、スコープ フィルターに関する記事に記載されている次の手順 を参照してください。
Smallstep SSH に対して Microsoft Entra プロビジョニング サービスを有効にするために、[設定] セクションの [プロビジョニングの状態] を [オン] に変更します。
[設定] セクションの [スコープ] で目的の値を選択して、Smallstep SSH にプロビジョニングするユーザーやグループを定義します。
プロビジョニングの準備ができたら、 [保存] を選択します。
この操作により、[設定] セクションの [スコープ] で定義されているすべてのユーザーとグループの初期同期サイクルが開始されます。 最初のサイクルは、Microsoft Entra プロビジョニング サービスが実行されている限り、約 40 分ごとに発生する後続のサイクルよりも実行に時間がかかります。
手順 6: デプロイを監視する
プロビジョニングを構成したら、次のリソースを使用してデプロイを監視します。
- プロビジョニング ログを使用して、どのユーザーが正常にプロビジョニングされたか、または正常にプロビジョニングされなかったかを判断する
- 進行状況バーを確認して、プロビジョニング サイクルの状態と完了までの近さを確認します
- プロビジョニング構成が異常な状態にあると思われる場合、アプリケーションは検疫に入ります。 検疫状態についての詳細は、アプリケーションプロビジョニングの隔離状態に関する記事をご覧ください。