Does GDPR apply to me?
Important
Visual Studio App Center is scheduled for retirement on March 31, 2025. While you can continue to use Visual Studio App Center until it is fully retired, there are several recommended alternatives that you may consider migrating to.
The goal of this guide is to help you determine whether and where you may have collected personal information about your end users using App Center. The document is divided by App Center service, mapped to scenarios.
If one of these scenarios applies, and one of your users requests to exercise a Data Subject Right, then you can look at the corresponding section to export or delete your end-user data.
Install IDs aren't personal information on their own. However they can be when mapped to personal info, which can be used to identify an end user.
A common way to map IDs is to track users when they log in into your app, linking their credentials to their install ID.
If you're using Analytics Custom Events in App Center Analytics, events are a potential place where you could have added personal information, including:
- Event name
- Event property key
- Event property value
Personal information can be introduced via event property values. For example, you could create an event called "Login" that captures email addresses in the property value field.
Map<String, String> properties = new HashMap<>();
properties.put("email_address", "blXXX@microsoft.com");
properties.put("phone_number","555-123-XXX");
Analytics.trackEvent("Login", properties);
These two cases are less probable because they're statically defined by the developer once. However, there are also places where you may have added personal information. See the examples below.
Event name:
Analytics.trackEvent("blXXX@microsoft.com", properties);
Event property key:
Map<String, String> properties = new HashMap<>();
properties.put("blXXX@microsoft.com", "microsoft_address");
properties.put("555-123-XXX", "washington_state");
Analytics.trackEvent("Origin", properties);
If you use the SDK to transmit crash information, you may have added your user’s data in a text attachment for a crash.
When throwing an exception, you may have included a user's personal information in the exception message.
When writing an annotation on the portal or via API, you may have written a user’s personal information in annotations.
If you're using App Center Errors, error properties are a potential place where you may have added personal information.
The most common scenario is having personal information in the Error Property Value. For example:
try
{
// your code here.
}
catch (Exception exception)
{
var properties = new Dictionary<string, string>
{
{ "email_address", "blXXX@microsoft.com"},
{ "phone_number", "555-123-XXX"}
};
Crashes.TrackError(exception, properties);
}
This is a less common case because they're static, defined by the developer once.
Personal information in the error property key:
try
{
// your code here.
}
catch (Exception exception)
{
var properties = new Dictionary<string, string>
{
{ "blXXX@microsoft.com", "@microsoft.com" },
{ "555-123-XXX", "Washington number" }
};
Crashes.TrackError(exception, properties);
}