From 05027c22f50ba7521039315fe6860c352e0375f1 Mon Sep 17 00:00:00 2001 From: Galdin Raphael Date: Thu, 13 Jun 2019 19:34:59 +0530 Subject: [PATCH] Mark csharp code-blocks as such (#12863) --- .../data-protection/configuration/non-di-scenarios.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/aspnetcore/security/data-protection/configuration/non-di-scenarios.md b/aspnetcore/security/data-protection/configuration/non-di-scenarios.md index 22fd5411bf..175e1d0cf7 100644 --- a/aspnetcore/security/data-protection/configuration/non-di-scenarios.md +++ b/aspnetcore/security/data-protection/configuration/non-di-scenarios.md @@ -14,7 +14,7 @@ The ASP.NET Core Data Protection system is normally [added to a service containe To support these scenarios, the [Microsoft.AspNetCore.DataProtection.Extensions](https://www.nuget.org/packages/Microsoft.AspNetCore.DataProtection.Extensions/) package provides a concrete type, [DataProtectionProvider](/dotnet/api/Microsoft.AspNetCore.DataProtection.DataProtectionProvider), which offers a simple way to use Data Protection without relying on DI. The `DataProtectionProvider` type implements [IDataProtectionProvider](/dotnet/api/microsoft.aspnetcore.dataprotection.idataprotectionprovider). Constructing `DataProtectionProvider` only requires providing a [DirectoryInfo](/dotnet/api/system.io.directoryinfo) instance to indicate where the provider's cryptographic keys should be stored, as seen in the following code sample: -[!code-none[](non-di-scenarios/_static/nodisample1.cs)] +[!code-csharp[](non-di-scenarios/_static/nodisample1.cs)] By default, the `DataProtectionProvider` concrete type doesn't encrypt raw key material before persisting it to the file system. This is to support scenarios where the developer points to a network share and the Data Protection system can't automatically deduce an appropriate at-rest key encryption mechanism. @@ -22,7 +22,7 @@ Additionally, the `DataProtectionProvider` concrete type doesn't [isolate apps]( The [DataProtectionProvider](/dotnet/api/microsoft.aspnetcore.dataprotection.dataprotectionprovider) constructor accepts an optional configuration callback that can be used to adjust the behaviors of the system. The sample below demonstrates restoring isolation with an explicit call to [SetApplicationName](/dotnet/api/microsoft.aspnetcore.dataprotection.dataprotectionbuilderextensions.setapplicationname). The sample also demonstrates configuring the system to automatically encrypt persisted keys using Windows DPAPI. If the directory points to a UNC share, you may wish to distribute a shared certificate across all relevant machines and to configure the system to use certificate-based encryption with a call to [ProtectKeysWithCertificate](/dotnet/api/microsoft.aspnetcore.dataprotection.dataprotectionbuilderextensions.protectkeyswithcertificate). -[!code-none[](non-di-scenarios/_static/nodisample2.cs)] +[!code-csharp[](non-di-scenarios/_static/nodisample2.cs)] > [!TIP] > Instances of the `DataProtectionProvider` concrete type are expensive to create. If an app maintains multiple instances of this type and if they're all using the same key storage directory, app performance might degrade. If you use the `DataProtectionProvider` type, we recommend that you create this type once and reuse it as much as possible. The `DataProtectionProvider` type and all [IDataProtector](/dotnet/api/microsoft.aspnetcore.dataprotection.idataprotector) instances created from it are thread-safe for multiple callers.