Adsf

Understanding Microsoft Entra ID Application & Service Principal Management: Restore or Remove Recently Deleted Applications

 

Understanding Microsoft Entra ID Application & Service Principal Management: Restore or Remove Recently Deleted Applications

Introduction

Managing applications in Microsoft Entra ID (formerly Azure AD) is crucial for enterprise developers and SaaS providers. Applications registered on the Microsoft identity platform rely on two key components: Application Objects and Service Principal Objects. This blog will explore these concepts, their relationship, and the steps to restore or remove recently deleted applications, including enterprise applications and app registrations.

Understanding Application Objects and Service Principal Objects

Application Registration in Microsoft Entra ID

To enable identity and access management through Microsoft Entra ID, every application must be registered with a Microsoft Entra tenant. This process creates a foundational identity configuration that allows the application to integrate with Microsoft Entra ID for authentication and authorization. During registration, you define whether the application will operate within a single tenant or across multiple tenants, and you can optionally specify a redirect URI for authentication responses.

Key Outcomes of Application Registration

  1. Globally Unique Instance:  Upon successful registration, a globally unique application object is created within the home tenant (the tenant where the app is registered). This object includes a unique App ID (also known as the client ID) used to identify the application.
  2. Configuration Options: After registration, you can:
    • Add secrets or certificates to secure communication.
    • Define API permissions and scopes.
    • Customize branding, such as the sign-in dialog and logos.
     3. Service Principal Creation:
    • For applications registered directly through the Microsoft Entra admin center, both an application object and a service principal are created automatically in the home tenant.
    • When using Microsoft Graph APIs for registration, creating the service principal is a separate step.

The Application Object: Blueprint of the Application

The application object represents a single, global definition of the application and resides exclusively in the home tenant. It serves as the blueprint for creating service principal objects, which are tenant-specific implementations.

Characteristics of an Application Object

  • Static Configuration: Certain properties, like App ID and permissions, are inherited by all service principal objects derived from the application object.
  • Global Scope: The application object applies universally, regardless of the number of tenants where the app is used.

Key Roles of the Application Object

  • Token Issuance: Defines how the app issues tokens for authentication.
  • Resource Access: Lists the resources the app can access.
  • App Actions: Specifies what the app can do, such as read or modify data.

You can manage application objects via the App Registrations page in the Microsoft Entra admin center or programmatically through Microsoft Graph APIs.

The Service Principal Object: Tenant-Specific Representation

A service principal is the local, tenant-specific representation of the global application object. It acts as the identity of the application in a specific tenant, allowing it to access resources within that tenant.

Types of Service Principals

  1. Application Service Principal:

    • Created for each tenant where the app is used.
    • Represents a specific instance of the application.
    • Inherits key properties from the application object.

     2. Managed Identity Service Principal:

    • Automatically created when an Azure resource is assigned a managed identity.
    • Provides secure access to resources without needing credentials.
    • Cannot be modified directly.
Note: Managed identities are soft-deleted and remain in the recycle bin for up to 30 days after deletion. While you can view the soft-deleted managed identity service principal during this period, it cannot be restored or permanently deleted manually. The managed identity service principal is automatically and permanently deleted after the 30-day window.

    3. Legacy Service Principal:

    • Represents apps created before the introduction of app registrations or legacy systems.
    • Typically lacks an associated application object.

Responsibilities of Service Principals

  • Authentication: Authenticates the app when it attempts to sign in to the tenant.
  • Authorization: Enforces access policies and permissions for the app.
  • Custom Configuration: Allows tenant-specific settings like user assignments and Conditional Access policies.

Relationship Between Application Objects and Service Principals

The relationship between an application object and service principals is central to the multi-tenant architecture of Microsoft Entra ID:

  • One-to-One with Software Application: Each application object corresponds to a single software application.
  • One-to-Many with Service Principals: A single application object can have multiple service principals, one for each tenant where the app is used.

Example: Single vs. Multi-Tenant Applications

  1. Single-Tenant Application:
    • Has only one service principal in its home tenant.
    • Intended for use within the home tenant only.
  2. Multi-Tenant Application:
    • The home tenant hosts the application object and a service principal.
    • Additional service principals are created in each tenant where the app is used, upon admin or user consent.

Viewing and Managing Application and Service Principal Objects

    Application Objects

You can view and manage application objects in the App Registrations section of the Microsoft Entra admin center. Actions include:

  • Editing app configurations.
  • Managing secrets and certificates.
  • Reviewing API permissions.

    Service Principals

Service principals can be managed from the Enterprise Applications page. Available actions include:

  • Viewing permissions and consent history.
  • Assigning users or groups to the application.
  • Configuring Conditional Access policies.

Practical Use Case: Token Issuance and Access Permissions

Consider an HR management system used by multiple companies:

1. Home Tenant (Adatum):

  • The application is registered, creating the application object.
  • A service principal is also created for the application in Adatum.

2. Consumer Tenants (Contoso, Fabrikam):

  • Service principals are created in these tenants when admins grant consent for the app.
  • Each service principal has tenant-specific permissions based on the granted scopes.

If the application is deleted in Adatum, the service principal in Adatum is also deleted, but the service principals in Contoso and Fabrikam remain intact.

Entra ID application's application object and corresponding service principal objects

Application Interaction with Microsoft Entra ID

To enable seamless identity and access management, applications must be registered with Microsoft Entra ID. This registration process involves creating an application object and a corresponding service principal in the application's home tenant. Managing applications in Microsoft Entra ID includes creating, configuring, monitoring, and maintaining these applications within a secure cloud environment.

When an application is registered in a Microsoft Entra tenant, users assigned to the application can securely access it. Microsoft Entra ID supports the registration and management of various types of applications, enabling flexibility for different business scenarios. These include preintegrated applications, custom-developed applications, and on-premises applications.

Application Types in Microsoft Entra ID

1.Preintegrated Applications

Microsoft Entra ID provides a gallery of preintegrated applications (referred to as "Cloud Applications"), which can be configured with minimal effort. These applications are preconfigured for seamless integration, and Microsoft provides detailed guides for setup. Using preintegrated applications reduces complexity and accelerates deployment.

Example:

To add a preintegrated application to your tenant, navigate to the Microsoft Entra admin center, select an application from the gallery, and follow the configuration steps outlined in its documentation.

Sign in to the Microsoft Entra admin center and navigate to Identity > Applications > Enterprise Applications. Use the search bar to locate the application you want to add. Note that only applications published in the Microsoft Entra application gallery can be added directly. 

Entra ID Enterprise Applications

Let's add an application from the Enterprise Application Gallery, specifically Workday, to enable SAML-based Single Sign-On (SSO) between the application and Microsoft Entra ID.

Note: We will not configure SSO at this stage, as this is solely to demonstrate the application integration process.

Entra ID Add Enterprise Application

The application has now been successfully added to our Microsoft Entra ID tenant, and we can view its properties and settings for further configuration.

Entra ID Workday Application
Now, if we navigate to the App Registrations section, we can see that the Workday application has been created and is linked to the corresponding Workday Enterprise Application Service Principal.

Entra ID Workday App registration

Create Your Own Application

If the application you’re looking for is not available, you can select 
Create your own application from the top menu to register a custom application.

Entra ID Create your own application

2. Custom-Developed Applications

If you develop your own business application, you can register it with Microsoft Entra ID to leverage its robust security features, such as Single Sign-On (SSO) and Conditional Access.

  • Registration Options:
    • App Registrations: Directly register your app and define its configuration.
    • Enterprise Applications: Use the Create your own application link to register and manage your app.(Mentioned previously)
  • Considerations for Integration: Evaluate how your application handles authentication and ensure it supports protocols like OpenID Connect or OAuth 2.0 for smooth integration with Microsoft Entra ID.
  • Making Your App Available to Others: If you want to share your custom application with other organizations, you can submit it to the Microsoft Entra gallery, making it accessible to a broader audience.

Steps to Register an Application

Sign in to the Microsoft Entra admin center and navigate to Identity > Applications > App Registrations
Entra ID App Registration
Select New Registration and configure: App name
Alternatively, you can go to Enterprise Applications, select Create your own application, and then choose Register an application to integrate the app you are developing with Microsoft Entra ID.
Entra ID App registration using Enterprise Application Menu
Tenant scope: Single-tenant or multi-tenant
Redirect URIs
Entra ID App Registration setup
After registration: Configure app/client ID, secrets, and certificates.
Define permissions and scopes for APIs.
Entra ID Registered Application

When you select the service principal object for an application, you will be redirected to the Enterprise Applications section in Microsoft Entra ID, where the corresponding service principal is managed.
The screenshot below illustrates the service principal created for this specific application.
Entra ID Service Principal Applicaton
Going back to App Registration for this particular application you can create Secrets, and certificates .This section you can find in the below screenshot
Entra ID Application secrets, and certificates Configuration

API Permission configuration section you can find in the below screenshot
Entra ID Application API Permissions Configuration
Outcome: A globally unique application object is created, along with its corresponding service principal in the home tenant.

3. On-Premises Applications

Organizations with on-premises applications can also benefit from Microsoft Entra ID's capabilities by connecting these applications through the Microsoft Entra Application Proxy or you can use Entra Private Access.

Managing Application Lifecycle: Deletion and Restoration

Soft Deletion of Applications

When an application is deleted, it moves to a soft-deleted state and is retained in the recycle bin for 30 days. This ensures accidental deletions can be recovered.

Note: Non-admin users are limited to 250 Microsoft Entra resources (active and deleted). Ensure you permanently delete unused objects to avoid exceeding this limit.

Let’s delete an application from the App Registrations section, which has a corresponding Service Principal in Enterprise Applications. During the deletion process, a warning message will appear, indicating that the application will no longer be able to sign in users or access protected resources, as it is used for Single Sign-On (SSO) with the Box application.

Entra ID Box App Deletion

Box Application Service Principal deleted from Enterprise Applications

Box Application Service Principal deleted

Consequences of Deletion

  1. Deleting an application object removes:
    1. The application object itself.
    2. The service principal in the home tenant.
  2. For multi-tenant applications:
    1. Service principals in other tenants remain unaffected.
  3. Conditional Access policies, provisioning data, and app proxy configurations associated with the service principal must be reconfigured upon recovery.

Restoring a Deleted Application

You can restore applications from the recycle bin during the 30-day soft-deletion window.

Steps to Restore an Application

  1. Sign in to the Microsoft Entra admin center.
  2. Navigate to Identity > Applications > App registrations > Deleted Applications.
  3. Search for the application and select Restore App Registration. In our case will restore Box Application for testing.
Entra ID Restore App Registration

The Box application and its associated Service Principal have been successfully restored.
Restored Box Application

Box Application Restored
Validate the restored app’s settings and reconfigure:
  1. Conditional Access policies (If required)
  2. App proxy configurations (If required)

Using PowerShell for Restoration

Run the following commands to restore a deleted application: You need to sign in as at least a Cloud Application Administrator.

Connect-MgGraph -Scopes "Application.ReadWrite.All"

Get-MgDirectoryDeletedItem -DirectoryObjectId <Object id>

Restore-MgDirectoryDeletedItem -DirectoryObjectId <Object id>

Entra ID Application PowerShell for Restoration

If the application has been deleted for more than 30 days, you will encounter the following error when attempting to restore it.

Restore Error: The application cannot be restored as it was deleted more than 30 days ago

Permanent Deletion

Soft-deleted applications can be permanently deleted via the Entra admin center or PowerShell:

The screenshot below displays the available options.

Entra ID Application Permanent Deletion

Remove-MgDirectoryDeletedItem -DirectoryObjectId <Object id>

Soft-deleted applications Permanent deletion using PowerShell


The previously selected application has been permanently deleted

Application has been permanently deleted
Caution: Permanent deletion is irreversible. Ensure you no longer need the application or service principal.

Remove an application authored by another organization

When viewing App Registrations in the context of a tenant, some applications listed under the All Apps tab are from external tenants and were added to your tenant during the consent process. These applications are represented solely by a service principal object in your tenant, without a corresponding application object.

To remove an application's access to your directory after consent has been granted, the service principal must be deleted. This action requires administrative privileges, such as the Privileged Role Administrator role.

Deleting Enterprise Applications: Key Considerations

  1. Suspended State:
    1. When you delete an enterprise application, it enters a suspended state and moves to the recycle bin for 30 days.
    2. During this period, the application can be restored if needed.
    3. After 30 days, deleted applications are permanently removed.
  2. Prerequisites for Deletion:
    1. A Microsoft Entra user account
    2. One of the following roles:
      1. Cloud Application Administrator
      2. Application Administrator
      3. Owner of the service principal
  3. The enterprise application must already exist in your tenant.

Steps to Delete an Enterprise Application Using Entra ID Portal

In our testing, we will use the Quest On Demand - Migration - Mailbox Migration service principal, which was created as part of the Quest Mailbox Migration tool's integration with our Microsoft Entra ID tenant. This is a multi-tenant application registered on the Quest Entra ID tenant, meaning it does not have an app registration created in our tenant. This scenario aligns with the example we previously discussed for the HR application.

To proceed:

Navigate to Microsoft Entra Enterprise Applications.

Select the Quest application: Quest On Demand - Migration - Mailbox Migration.

Quest On Demand - Migration - Mailbox Migration App


Go to Properties and delete the application.

Entra Enterprise Applications Properties
Deletion Confirmation

Entra Enterprise Applications Deletion Confirm


Application has been deleted

Entra ID Enterprise Applications

Note: Deleted service principals can't be viewed through the Microsoft Entra admin center.

Steps to Delete an Enterprise Application Using Microsoft Graph PowerShell

Connect to Microsoft Graph PowerShell and sign in as at least a Cloud Application Administrator:

Connect-MgGraph -Scopes 'Application.ReadWrite.All'

Get the list of enterprise applications in your tenant.

Get-MgServicePrincipal

Record the object ID of the enterprise app you want to delete.

Delete the enterprise application.

Remove-MgServicePrincipal -ServicePrincipalId 'ObjectID'

Delete Enterprise Application Using Microsoft Graph PowerShell

Steps to Restore an Enterprise Application Using Microsoft Graph PowerShell

We will now restore the deleted application using the below Microsoft Graph Powershell

Restore-MgDirectoryDeletedItem -DirectoryObjectId <id>

Restore an Enterprise Application Using Microsoft Graph PowerShell

We successfully restored two applications that were previously deleted:
  • One application deleted via the Microsoft Entra ID portal.
  • Another application deleted using Microsoft Graph PowerShell.
Both applications were restored using Microsoft Graph PowerShell.

The screenshot below shows the restored applications (service principals).
Entra ID Restored Applications


Restore enterprise applications using Microsoft Graph PowerShell
Note: The deleted service principal for this application can only be restored using Microsoft Graph PowerShell.

Warning: Permanently deleting an enterprise application is an irreversible action. Any present configurations on the app will be completely lost. Carefully review the details of the enterprise application to be sure you still want to hard delete it.

To permanently delete the soft deleted enterprise application, run the following command:

Remove-MgDirectoryDeletedItem -DirectoryObjectId <id>

Note: You can't configure the periodicity of hard deletion


Things to Note:
  1. A maximum of 100 users and service principals can be assigned as owners of a single application.
  2. Each user, group, or service principal can have up to 1,500 app role assignments. This limit applies collectively across all app roles, not to the number of assignments for a single app role.
  3. A user can configure credentials for up to 48 applications using password-based single sign-on (SSO). This limit applies only when the user is directly assigned to the application, not when assigned through a group.
  4. A group can also configure credentials for up to 48 applications using password-based SSO.
  5. The application manifest supports a maximum of 1,200 entries.
  6. Assigning groups to an application is supported; however, nested groups within the directly assigned group will not have access to the application.


Conclusion

Managing applications in Microsoft Entra ID is essential for ensuring secure, efficient, and scalable identity and access management across cloud and on-premises environments. By understanding the relationship between application objects and service principals, as well as leveraging tools like the Microsoft Entra admin center and Microsoft Graph PowerShell, administrators can effectively handle tasks such as application registration, deletion, restoration, and integration.

Whether working with preintegrated applications, custom-developed solutions, or on-premises apps, Microsoft Entra ID offers robust features to meet diverse organizational needs. By following best practices, you can streamline application management, maintain compliance, and enhance the overall security posture of your tenant.

This comprehensive approach empowers IT teams to maximize the benefits of Microsoft Entra ID, ensuring seamless application experiences for users while maintaining administrative control and security.



Post a Comment

0 Comments

Add

Ad Code