MembershipHelper.cs 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. //
  2. // System.Web.Security.MembershipHelper
  3. //
  4. // Authors:
  5. // Ben Maurer ([email protected])
  6. // Lluis Sanchez Gual ([email protected])
  7. //
  8. // (C) 2003 Ben Maurer
  9. // Copyright (C) 2005-2010 Novell, Inc (http://www.novell.com)
  10. //
  11. // Permission is hereby granted, free of charge, to any person obtaining
  12. // a copy of this software and associated documentation files (the
  13. // "Software"), to deal in the Software without restriction, including
  14. // without limitation the rights to use, copy, modify, merge, publish,
  15. // distribute, sublicense, and/or sell copies of the Software, and to
  16. // permit persons to whom the Software is furnished to do so, subject to
  17. // the following conditions:
  18. //
  19. // The above copyright notice and this permission notice shall be
  20. // included in all copies or substantial portions of the Software.
  21. //
  22. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  23. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  24. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  25. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  26. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  27. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  28. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  29. //
  30. using System.Configuration.Provider;
  31. using System.Security.Cryptography;
  32. using System.Web.Configuration;
  33. using System.Web.Util;
  34. namespace System.Web.Security
  35. {
  36. sealed class MembershipHelper
  37. #if NET_4_0
  38. : IMembershipHelper
  39. #endif
  40. {
  41. internal const int SALT_BYTES = 16;
  42. public int UserIsOnlineTimeWindow {
  43. get { return Membership.UserIsOnlineTimeWindow; }
  44. }
  45. public MembershipProviderCollection Providers {
  46. get { return Membership.Providers; }
  47. }
  48. static SymmetricAlgorithm GetAlgorithm ()
  49. {
  50. MachineKeySection section = MachineKeySection.Config;
  51. if (section.DecryptionKey.StartsWith ("AutoGenerate"))
  52. throw new ProviderException ("You must explicitly specify a decryption key in the <machineKey> section when using encrypted passwords.");
  53. SymmetricAlgorithm sa = section.GetDecryptionAlgorithm ();
  54. if (sa == null)
  55. throw new ProviderException (String.Format ("Unsupported decryption attribute '{0}' in <machineKey> configuration section", section.Decryption));
  56. sa.Key = section.GetDecryptionKey ();
  57. return sa;
  58. }
  59. public byte [] DecryptPassword (byte [] encodedPassword)
  60. {
  61. using (SymmetricAlgorithm sa = GetAlgorithm ()) {
  62. return MachineKeySectionUtils.Decrypt (sa, encodedPassword, 0, encodedPassword.Length);
  63. }
  64. }
  65. public byte[] EncryptPassword (byte[] password)
  66. {
  67. using (SymmetricAlgorithm sa = GetAlgorithm ()) {
  68. return MachineKeySectionUtils.Encrypt (sa, password);
  69. }
  70. }
  71. }
  72. }