チュートリアル: Azure Active Directory とアマゾン ウェブ サービスの統合

このチュートリアルでは、Azure Active Directory (Azure AD) とアマゾン ウェブ サービス (AWS) を統合する方法について説明します (従来のチュートリアル)。

この統合には次のような利点があります。

  • AWS にアクセスできるユーザーを Azure AD で管理できます。
  • ユーザーが自分の Azure AD アカウントでシングル サインオン (SSO) を使用して自動的に AWS にサインインできるように設定できます。
  • 1 つの中央サイト (Azure Portal) でアカウントを管理できます。

Diagram of Azure AD integration with AWS.

注意

1 つの AWS アプリを自分のすべての AWS アカウントに接続 "しない" ことをお勧めします。 代わりに、Azure AD SSO と AWS の統合を使用して、Azure AD で AWS アプリの複数のインスタンスに対して AWS アカウントの複数のインスタンスを構成することをお勧めします。

以下の理由から、1 つの AWS アプリを自分のすべての AWS アカウントに接続 "しない" ことをお勧めします。

  • AWS アカウントやそれに含まれるロールの数が増えてもこのモデルを拡張できないことが原因で、AWS アカウントとロールの数を少なくしている場合にのみ、このアプローチを使用してください。 このアプローチでは、Azure AD ユーザー プロビジョニングを使用した AWS ロールのインポート機能が使用されないため、ロールを手動で追加、更新、削除する必要があります。

  • アプリにすべてのロールを適用するには、Microsoft Graph エクスプローラーを使用する必要があります。 マニフェスト ファイル アプローチの使用はお勧めしません。

  • お客様からは、1 つの AWS アプリに対して約 1,200 のアプリ ロールを追加した後、そのアプリでさらに操作を行うと、サイズに関連したエラーがスローされるようになるという報告が寄せられています。 アプリケーション オブジェクトには厳密なサイズ制限があります。

  • ロールは、アカウントのいずれかに追加されたときに、手動で更新する必要があります。 残念ながら、これは "追加" アプローチではなく、"置換" アプローチとなります。 また、アカウント数が増加している場合、これはアカウントとロールの n × n の関係になります。

  • すべての AWS アカウントでは、同じフェデレーション メタデータ XML ファイルが使用されます。 証明書をロールオーバーする際、すべての AWS アカウントの証明書を同時に更新することは膨大な作業となる可能性があります。

前提条件

AWS と Azure AD の統合を構成するには、次のものが必要です。

  • Azure AD サブスクリプション。 Azure AD サブスクリプションがない場合は、1 か月の試用版を入手できます。
  • AWS での SSO が有効なサブスクリプション。

注意

必要な場合を除き、このチュートリアルの手順を運用環境でテストしないことをお勧めします。

シナリオの説明

このチュートリアルでは、テスト環境で Azure AD の SSO を構成してテストします。

AWS では、SP Initiated SSO と IDP-initiated SSO がサポートされます。

Azure AD への AWS の統合を構成するには、ギャラリーからマネージド SaaS (サービスとしてのソフトウェア) アプリの一覧に AWS を追加します。

  1. 職場または学校アカウントか、個人の Microsoft アカウントを使用して、Azure portal にサインインします。

  2. 左側のペインで、使用する Azure AD サービスを選択します。

  3. [エンタープライズ アプリケーション] に移動し、 [すべてのアプリケーション] を選択します。

  4. アプリケーションを追加するには、 [新しいアプリケーション] を選択します。

  5. [ギャラリーから追加する] セクションで、検索ボックスに「アマゾン ウェブ サービス」と入力します。

  6. 結果リストで [アマゾン ウェブ サービス] を選択し、そのアプリを追加します。 数秒で、お使いのテナントにアプリが追加されます。

  7. [プロパティ] ペインに移動し、 [オブジェクト ID] ボックスに表示されている値をコピーします。

    Screenshot of the Object ID box on the Properties pane.

Azure AD SSO の構成とテスト

このセクションでは、"Britta Simon" というテスト ユーザーに基づいて、AWS で Azure AD のシングル サインオンを構成し、テストします。

シングル サインオンを機能させるには、Azure AD ユーザーに対応する AWS ユーザーが Azure AD で認識されている必要があります。 言い換えると、Azure AD ユーザーと AWS の同じユーザーの間で、リンク関係が確立されている必要があります。

AWS で、Azure AD の [ユーザー名] の値を AWS の [Username](ユーザー名) の値として割り当てて、リンク関係を確立します。

AWS で Azure AD シングル サインオンを構成してテストするには、次を実行します。

  1. Azure AD SSO の構成 - ユーザーがこの機能を使用できるようにします。
  2. AWS SSO の構成 - アプリケーション側で SSO 設定を構成します。
  3. SSO をテスト して、構成が正しく機能することを確認します。

Azure AD SSO の構成

このセクションでは、次の手順を実行して Azure portal で Azure AD SSO を有効にし、AWS アプリケーションに SSO を構成します。

  1. Azure portal のアマゾン ウェブ サービス (AWS) アプリケーション統合ページの左側ペインで、 [シングル サインオン] を選択します。

    Screenshot of the

  2. [シングル サインオン方式の選択] ウィンドウで、 [SAML/WS-Fed] モードを選択して、シングル サインオンを有効にします。

    Screenshot of the

  3. [SAML によるシングル サインオンのセットアップ] ペインで [編集] ボタン (鉛筆アイコン) を選択します。

    Screenshot of the Edit button on the

  4. [基本的な SAML 構成] ペインが開きます。 アプリはあらかじめ Azure と統合されているため、このセクションはスキップします。 [保存] を選択します。

    AWS アプリケーションは、特定の形式の SAML アサーションを受け入れます。 これらの属性の値は、[アプリケーション統合] ページの [ユーザー属性と要求] セクションで管理できます。

  5. [SAML によるシングル サインオンのセットアップ] ペインで [編集] ボタンを選択します。

    Screenshot of the Edit button on the

  6. [ユーザー属性] ペインの [ユーザー要求] セクションで、次の表の値を使用して、SAML トークン属性を構成します。

    名前 ソース属性 名前空間
    RoleSessionName user.userprincipalname https://aws.amazon.com/SAML/Attributes
    Role user.assignedroles https://aws.amazon.com/SAML/Attributes
    SessionDuration "900 秒 (15 分) から 43,200 秒 (12 時間) までの値を指定します" https://aws.amazon.com/SAML/Attributes

    a. [新しい要求の追加] を選択した後、 [ユーザー要求の管理] ペインで、以下を実行します。

    Screenshot of

    Screenshot of the

    b. [名前] ボックスに、属性名を入力します。

    c. [名前空間] ボックスに、名前空間の値を入力します。

    d. [ソース][属性] を選択します。

    e. [ソース属性] ボックスの一覧から、属性を選択します。

    f. [OK] を選択し、 [保存] を選択します。

    注意

    Azure AD のロールの詳細については、アプリケーションへのアプリ ロールの追加とトークンでの受け取りに関する記事を参照してください。

  7. [SAML によるシングル サインオンのセットアップ] ページの [SAML 署名証明書] セクションで、 [ダウンロード] を選択してフェデレーション メタデータ XML ファイルをダウンロードし、コンピューターに保存します。

    Screenshot of the

AWS SSO の構成

  1. 新しいブラウザー ウィンドウで、管理者として自分の AWS 企業サイトにサインインします。

  2. AWS ホーム アイコンを選択します。

    Screenshot of the

  3. [AWS services](AWS サービス) ペインの [Security, Identity & Compliance](セキュリティ、ID、コンプライアンス) で、[IAM] (ID およびアクセス管理) を選択します。

    Screenshot of the

  4. 左側のペインで [Identity Providers](ID プロバイダー) を選択してから、 [Create Provider](プロバイダーの作成) を選択します。

    Screenshot of the

  5. [Configure Provider](プロバイダーの設定) ペインで、以下を実行します。

    Screenshot of the

    a. [Provider Type](プロバイダーの種類) ボックスの一覧から [SAML] を選択します。

    b. [Provider Name] (プロバイダー名) ボックスにプロバイダー名を入力します (例: WAAD)。

    c. [Metadata Document](メタデータ ドキュメント) ボックスの横にある [Choose File](ファイルの選択) を選択して、Azure portal にダウンロードしたフェデレーション メタデータ XML ファイルをアップロードします。

    d. [Next Step](次のステップ) を選択します。

  6. [Verify Provider Information](プロバイダー情報の検証) ペインで [Create](作成) を選択します。

    Screenshot of the

  7. 左側のペインで、 [Roles](ロール) を選択してから、 [Create role](ロールの作成) を選択します。

    Screenshot of the

    注意

    そのロール Amazon Resource Name (ARN) とインポートされるロールの SAML プロバイダー ARN を合わせた長さが 240 文字以下になるようにしてください。

  8. [Create role](ロールの作成) ページで、以下を実行します。

    Screenshot of the

    a. [信頼されたエンティティの種類を選択] で、 [SAML 2.0 フェデレーション] を選択します。

    b. [Choose a SAML 2.0 provider](SAML 2.0 プロバイダーを選択) で、先ほど作成した SAML プロバイダーを選択します (例: WAAD)。

    c. [Allow programmatic and AWS Management Console access] を選択します。

    d. Permissions(次へ: アクセス許可) をクリックします。

  9. 検索ボックスに「Administrator Access」と入力し、 [AdministratorAccess] チェック ボックスをオンにして、 [Next: Tags](次へ: タグ) を選択します。

    Screenshot of the

  10. [Add tags (optional)](タグの追加 (省略可能)) ペインで、以下を実行します。

    Screenshot of the

    a. [Key](キー) ボックスに、キー名を入力します (例: Azureadtest)。

    b. [Value (optional)](値 (省略可能)) ボックスに、<accountname-aws-admin> の形式でキー値を入力します。 アカウント名はすべて小文字にする必要があります。

    c. 確認\) をクリックします。

  11. [Review](確認) ペインで、以下を実行します。

    Screenshot of the Review pane, with the

    a. [Role name](ロール名) ボックスに、<accountname-aws-admin> の形式で値を入力します。

    b. [Role description](ロールの説明) ボックスに、ロール名に使用した値を入力します。

    c. [ロールの作成] を選択します。

    d. 必要な数のロールを作成し、それらを ID プロバイダーにマップします。

    注意

    同様に、それぞれ異なるポリシーが関連付けられている、accountname-finance-adminaccountname-read-only-useraccountname-devops-useraccountname-tpm-user など、その他のロールも作成できます。 各 AWS アカウントの要件に応じて、これらのロール ポリシーは後で変更することができます。 AWS アカウント全体で、ロールごとに同じポリシーを維持することをお勧めします。

  12. Amazon Elastic Compute Cloud (Amazon EC2) のプロパティ ペインまたは IAM ダッシュボード (次のスクリーンショットを参照) から、AWS アカウントのアカウント ID を必ずメモしておきます。

    Screenshot showing where the account ID is displayed on the

  13. Azure portal にサインインし、 [グループ] に移動します。

  14. 前に作成した IAM ロールと同じ名前で新しいグループを作成し、この各新しいグループの [オブジェクト ID] の値をメモします。

    Screenshot of the account details for a new group.

  15. 現在の AWS アカウントからサインアウトし、Azure AD による SSO を構成する別のアカウントにログインします。

  16. そのアカウントに作成したすべてのロールは、これらのアカウントの [Roles](ロール) の一覧に表示されます。

    Screenshot of the roles list, showing each role's name, description, and trusted entities.

次に、すべてのアカウントで、すべてのロールに関するロール ARN と信頼されたエンティティをすべて取得する必要があります。 これらを手動で Azure AD アプリケーションにマップする必要があります。 そのためには次を行います。

  1. 各ロールを選択して、そのロール ARN と信頼されたエンティティの値をコピーします。 これらは、Azure AD で作成するすべてのロールに必要になります。

    Screenshot of the Summary pane for the role ARNs and trusted entities.

  2. すべてのアカウントのすべてのロールに対して前の手順を繰り返し、これらを <Role ARN>,<Trusted entities> の形式でテキスト ファイルに保存します。

  3. Microsoft Graph Explorer を開き、以下を実行します。

    a. テナントのグローバル管理者または共同管理者の資格情報を使用して、Microsoft Graph Explorer サイトにサインインします。

    b. ロールを作成するための十分なアクセス許可が必要です。 [アクセス許可の変更] を選択します。

    Screenshot of the

    c. アクセス許可の一覧に、次のスクリーンショットに表示されているアクセス許可がまだない場合は、それぞれ選択した後、 [アクセス許可の変更] を選択します。

    Screenshot of the Microsoft Graph Explorer permissions list, with the appropriate permissions highlighted.

    d. 再度 Graph Explorer にサインインし、サイトの使用条件に同意します。

    e. ペインの上部で、メソッドとして [GET] を、バージョンとして [ベータ] を選択し、クエリ ボックスに次のいずれかを入力します。

    • テナントからすべてのサービス プリンシパルを取得するには、https://graph.microsoft.com/beta/servicePrincipals を使用します。
    • 複数のディレクトリを使用している場合は、https://graph.microsoft.com/beta/contoso.com/servicePrincipals を使用します。これには、プライマリ ドメインが含まれます。

    Screenshot of the Microsoft Graph Explorer query

    f. サービス プリンシパルの一覧から、変更する必要があるものを取得します。

    Ctrl + F キーを選択して、表示されているすべてのサービス プリンシパルについてアプリケーションを検索することもできます。 特定のサービス プリンシパルを取得するには、次に示すように、Azure AD プロパティ ペインから前にコピーしたサービス プリンシパル オブジェクト ID をクエリに含めます。

    https://graph.microsoft.com/beta/servicePrincipals/<objectID>

    Screenshot showing a service principal query that includes the object ID.

    g. サービス プリンシパル オブジェクトから appRoles プロパティを抽出します。

    Screenshot of the code for extracting the appRoles property from the service principal object.

    h. ここで、アプリケーションの新しいロールを生成する必要があります。

    i. 次の JSON コードは、appRoles オブジェクトの例です。 同様のオブジェクトを作成して、アプリケーションに必要なロールを追加します。

    {
    "appRoles": [
        {
            "allowedMemberTypes": [
                "User"
            ],
            "description": "msiam_access",
            "displayName": "msiam_access",
            "id": "7dfd756e-8c27-4472-b2b7-38c17fc5de5e",
            "isEnabled": true,
            "origin": "Application",
            "value": null
        },
        {
            "allowedMemberTypes": [
                "User"
            ],
            "description": "Admin,WAAD",
            "displayName": "Admin,WAAD",
            "id": "4aacf5a4-f38b-4861-b909-bae023e88dde",
            "isEnabled": true,
            "origin": "ServicePrincipal",
            "value": "arn:aws:iam::12345:role/Admin,arn:aws:iam::12345:saml-provider/WAAD"
        },
        {
            "allowedMemberTypes": [
                "User"
            ],
            "description": "Auditors,WAAD",
            "displayName": "Auditors,WAAD",
            "id": "bcad6926-67ec-445a-80f8-578032504c09",
            "isEnabled": true,
            "origin": "ServicePrincipal",
            "value": "arn:aws:iam::12345:role/Auditors,arn:aws:iam::12345:saml-provider/WAAD"
        }    ]
    }
    

    注意

    パッチ操作の場合、新しいロールを追加できるのは、msiam_access を追加した後のみです。 また、組織のニーズに応じて、必要な数のロールを追加することもできます。 Azure AD では、SAML 応答の要求値として、これらのロールの "" を送信します。

    j. Microsoft Graph Explorer で、メソッドを GET から PATCH に変更します。 前の例に示されているように appRoles プロパティを更新して、必要なロールが割り当てられるようにサービス プリンシパル オブジェクトを修正します。 [クエリの実行] をクリックして、パッチ操作を実行します。 成功メッセージによって、AWS アプリケーションのロールの作成を確認できます。

    Screenshot of the Microsoft Graph Explorer pane, with the method changed to PATCH.

  4. サービス プリンシパルでさらに多くのロールを修正したら、対応するロールにユーザーおよびグループを割り当てることができます。 これは、Azure portal で AWS アプリケーションに移動し、上部にある [ユーザーとグループ] タブを選択することによって行います。

  5. グループで特定のロールを割り当てることができるように、すべての AWS ロール用に新しいグループを作成することをお勧めします。 この 1 対 1 のマッピングは、1 つのグループが 1 つのロールに割り当てられることを意味します。 そのグループに属するメンバーを追加できます。

  6. グループを作成したら、グループを選択してアプリケーションに割り当てます。

    Screenshot of the

    注意

    グループを割り当てるときに、入れ子になったグループはサポートされていません。

  7. グループにロールを割り当てるには、ロールを選択し、 [割り当て] を選択します。

    Screenshot of the

    注意

    ロールを割り当てたら、Azure portal セッションを最新の情報に更新することによって、ロールを表示できます。

SSO のテスト

このセクションでは、Microsoft マイ アプリを使用して、Azure AD のシングル サインオン構成をテストします。

マイ アプリで [AWS] タイルを選択すると、AWS アプリケーション ページが開き、ロールを選択するオプションが表示されます。

Screenshot of the AWS page for testing SSO.

SAML 応答を確認し、クレームとして渡されるロールを参照することもできます。

Screenshot of the SAML response.

マイ アプリの詳細については、「マイ アプリ ポータルからアプリにサインインして開始する」を参照してください。

次のステップ

AWS を構成したら、組織の機密データを流出と侵入からリアルタイムで保護するセッション制御を適用することができます。 セッション制御は、条件付きアクセスを拡張したものです。 詳細については、Microsoft Defender for Cloud Apps でセッション制御を適用する方法に関するページをご覧ください。