9.5 Configuring an Application in Azure to Represent PlateSpin Migrate

PlateSpin Migrate uses the Microsoft Azure API to automate workload migrations to Azure. You need to create an Azure application ID for PlateSpin Migrate to use when it uses the Azure API for replicating and migrating workloads to your Azure account.

NOTE:For migrations to Azure Stack, you must not create an Azure application ID for PlateSpin Migrate. Instead, use the following ID as the Azure application ID for PlateSpin Migrate:

872cd9fa-d31f-45e0-9eab-6e460a02d1f1

When you register an application, Azure creates a central identity for it in Azure Active Directory and assigns it an Application ID. The registration stores basic information that Migrate uses to authenticate to and use Azure APIs. It also records delegated permissions that Migrate needs when it accesses the APIs on behalf of the Contributor user for the subscription.

NOTE:For more information about application registration and permissions. see the following Microsoft resources:

9.5.1 Registering an Application in Azure

To register an application in Azure for PlateSpin Migrate to use:

  1. Use the Azure Global Portal to log in to your Azure account as a user with rights necessary to create and manage applications.

  2. In the Portal sidebar, select Azure Active Directory, then in the left pane under Manage, select App registrations.

  3. Register PlateSpin Migrate for your account:

    1. On the App registrations page, click New Registration in the command bar.

    2. On the Register an application page, provide the following information:

      Register an application

      Name

      Specify friendly name for the application, such as PlateSpin Migrate Integration.

      The name must be unique in your Azure Active Directory. This is the name that appears in the Applications list.

      Supported account types

      Select Accounts in any organizational directory.

      This option enables the application for user accounts in your default directory in Azure Active Directory.

      Redirect URI

      Specify Web, then leave the Redirect URI field empty.

    3. Read the Microsoft Platform Policies, then click Register.

      The working pane opens to the Overview page of the newly registered application.

  4. On the Overview page of the new application, copy the Application (client) ID value to the clipboard and paste it in a text document where you can access it when you set up the target cloud platforms for subscriptions in this account.

    An Application (client) ID is a value in the format of: abc12b34-c5df-6e78-f9a0-bc123456d789.

    You must provide the Application (client) ID when you add a Microsoft Azure Location as a migration target in PlateSpin Migrate.

  5. Configure Authentication settings for the application that you registered in Step 3.

    The Public Client setting allows the Migrate server to authenticate programmatically to Azure when it uses the Azure APIs.

    1. Continuing on the Overview page of the new application, in the left pane under Manage, select Authentication.

      To access the Overview page: In the Portal sidebar, select Azure Active Directory, select Manage > App registrations, then under Owned applications, select the application by its name.

    2. On the Authentication page, scroll down to Advanced Settings > Default Client Type.

    3. Click Yes to treat the application as a public client.

    4. In the command bar, click Save.

    5. Dismiss the confirmation message for the updated Authentication settings.

    6. In the left pane, click Overview to return to the Overview page for the application.

  6. Configure API permissions for the application that you registered in Step 3.

    1. Continuing on the Overview page for the new application, in the left pane under Manage, select API permissions. You can also click View API Permissions on the Overview page.

      To access the Overview page: In the Portal sidebar, select Azure Active Directory, select Manage > App registrations, then under Owned applications, select the application by its name.

    2. Microsoft Graph:Modify this default permission to add the User.ReadBasic.All permission.

      User.Read grants permission to read the profile of the signed-in user. User.ReadBasic.All constrains application access to a limited set of properties known as the basic profile (display name, given name, mail, photo, surname, and user principal name).

      1. On the API Permissions page, click Microsoft Graph.

        Its current permission type is Delegated and the permission granted is User.Read.

      2. On the Request API Permissions page under Select Permissions, scroll to the User section and select User.ReadBasic.All.

      3. On the bottom of the page, click Update Permissions.

      4. Dismiss the confirmation message for the updated permissions.

      5. On the API Permissions page, visually verify that Microsoft Graph now has Delegated permissions for User.Read and UserReadBasic.All.

    3. Azure Service Management:Add a new API permission for Azure Service Management.

      Migrate uses the Azure Resource Manager Authentication API to access subscriptions, which requires the following permissions for the registered application: Azure Service Management, Delegated Permissions, and user_impersonation.

      1. On the API Permissions page, click Add a Permission.

      2. On the Request API Permissions page, provide the following information:

        Request API Permissions

        API Category

        Select Microsoft APIs.

        API

        Select Azure Service Management.

        Type of Permissions

        Select Delegated Permissions.

        When PlateSpin Migrate accesses Azure APIs, the permissions are delegated to an authorized Contributor User that PlateSpin Migrate logs in as to perform migration actions. See Configuring a Contributor User for PlateSpin Migrate to Use.

        Permissions

        Select user_impersonation.

      3. At the bottom of the page, click Add permissions.

      4. Dismiss the confirmation message for the newly added permissions.

      5. On the API Permissions page, visually verify that Azure Service Management is listed in the API permissions list with Delegated permissions for user_impersonation.

        Although permissions are configured, they are not yet effective for the application. An Azure global administrator must grant admin consent for the permissions in the Default Directory to ensure that consent is not required when PlateSpin Migrate accesses Azure APIs.

  7. [Azure Global Administrator rights for the Default Directory are required for this step.] Grant admin consent for the Default Directory for the requested permissions.

    Do one of the following:

    • If you have admin rights, you can grant consent now from the API Permissions page. Continue with Grant Admin Consent from App Registrations.

    • If you are not currently logged in as a user with admin rights, the option to grant admin consent is disabled on the API Permissions page.

      Use either of these methods to grant consent:

9.5.2 Granting Admin Consent for Application Permissions

A user with Azure Global Administrator rights for the Default Directory must grant consent for the permissions you request for the registered application that PlateSpin Migrate will use. The consent on behalf of all users will ensure that consent is not required when PlateSpin Migrate accesses Azure APIs. After consent is granted, the application is ready for use by PlateSpin Migrate.

IMPORTANT:Ensure that you are logged in with an Azure user account that has Global Administrator rights for the Default Directory where the application will be used.

9.5.3 Verifying Admin Consent for the Application

To verify the application and its permissions:

  1. In Portal sidebar, select Azure Active Directory, then select Manage > Enterprise Applications.

  2. Locate and select the new application that you created in Step 3.

  3. Under Security, click Permissions.

  4. Verify that required permissions are listed in the Admin Consent section and that consent is granted for the Default Directory.

    The permissions should match the permissions you configured in Step 6 of Registering an Application in Azure.