1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
//------------------------------------------------------------------------------
// <copyright file="HomogenizingCryptoServiceWrapper.cs" company="Microsoft">
// Copyright (c) Microsoft Corporation. All rights reserved.
// </copyright>
//------------------------------------------------------------------------------
namespace System.Web.Security.Cryptography {
using System;
using System.Configuration;
using System.Security.Cryptography;
// Wraps an ICryptoService instance and homogenizes any exceptions that might occur.
internal sealed class HomogenizingCryptoServiceWrapper : ICryptoService {
public HomogenizingCryptoServiceWrapper(ICryptoService wrapped) {
WrappedCryptoService = wrapped;
}
internal ICryptoService WrappedCryptoService {
get;
private set;
}
private static byte[] HomogenizeErrors(Func<byte[], byte[]> func, byte[] input) {
// If the underlying method returns null or throws an exception, the
// error will be homogenized as a single CryptographicException.
byte[] output = null;
bool allowExceptionToBubble = false;
try {
output = func(input);
return output;
}
catch (ConfigurationException) {
// ConfigurationException isn't a side channel; it means the application is misconfigured.
// We need to bubble this up so that the developer can react to it.
allowExceptionToBubble = true;
throw;
}
finally {
if (output == null && !allowExceptionToBubble) {
throw new CryptographicException();
}
}
}
public byte[] Protect(byte[] clearData) {
return HomogenizeErrors(WrappedCryptoService.Protect, clearData);
}
public byte[] Unprotect(byte[] protectedData) {
return HomogenizeErrors(WrappedCryptoService.Unprotect, protectedData);
}
}
}
|