EncryptedKeyIdentifierClause.cs 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. //
  2. // EncryptedKeyIdentifierClause.cs
  3. //
  4. // Author:
  5. // Atsushi Enomoto <[email protected]>
  6. //
  7. // Copyright (C) 2006 Novell, Inc. http://www.novell.com
  8. //
  9. // Permission is hereby granted, free of charge, to any person obtaining
  10. // a copy of this software and associated documentation files (the
  11. // "Software"), to deal in the Software without restriction, including
  12. // without limitation the rights to use, copy, modify, merge, publish,
  13. // distribute, sublicense, and/or sell copies of the Software, and to
  14. // permit persons to whom the Software is furnished to do so, subject to
  15. // the following conditions:
  16. //
  17. // The above copyright notice and this permission notice shall be
  18. // included in all copies or substantial portions of the Software.
  19. //
  20. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  21. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  22. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  23. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  24. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  25. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  26. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  27. //
  28. using System;
  29. using System.Collections.Generic;
  30. using System.Xml;
  31. using System.IdentityModel.Policy;
  32. namespace System.IdentityModel.Tokens
  33. {
  34. public sealed class EncryptedKeyIdentifierClause : BinaryKeyIdentifierClause
  35. {
  36. public EncryptedKeyIdentifierClause (
  37. byte [] encryptedKey, string encryptionMethod)
  38. : this (encryptedKey, encryptionMethod, null)
  39. {
  40. }
  41. public EncryptedKeyIdentifierClause (
  42. byte [] encryptedKey, string encryptionMethod,
  43. SecurityKeyIdentifier identifier)
  44. : this (encryptedKey, encryptionMethod, identifier, null)
  45. {
  46. }
  47. public EncryptedKeyIdentifierClause (
  48. byte [] encryptedKey, string encryptionMethod,
  49. SecurityKeyIdentifier identifier, string carriedKeyName)
  50. : this (encryptedKey, encryptionMethod, identifier, carriedKeyName, null, 0)
  51. {
  52. }
  53. public EncryptedKeyIdentifierClause (
  54. byte [] encryptedKey, string encryptionMethod,
  55. SecurityKeyIdentifier identifier, string carriedKeyName,
  56. byte [] derivationNonce, int derivationLength)
  57. : base (encryptionMethod, encryptedKey, true, derivationNonce, derivationLength)
  58. {
  59. this.carried_key_name = carriedKeyName;
  60. this.identifier = identifier;
  61. this.enc_method = encryptionMethod;
  62. }
  63. string carried_key_name, enc_method;
  64. SecurityKeyIdentifier identifier;
  65. public string CarriedKeyName {
  66. get { return carried_key_name; }
  67. }
  68. public string EncryptionMethod {
  69. get { return enc_method; }
  70. }
  71. public SecurityKeyIdentifier EncryptingKeyIdentifier {
  72. get { return identifier; }
  73. }
  74. public byte [] GetEncryptedKey ()
  75. {
  76. return GetBuffer ();
  77. }
  78. public bool Matches (byte [] encryptedKey, string encryptionMethod, string carriedKeyName)
  79. {
  80. if (encryptedKey == null)
  81. throw new ArgumentNullException ("encryptedKey");
  82. byte [] buf = GetRawBuffer ();
  83. if (encryptionMethod != this.enc_method ||
  84. carriedKeyName != this.carried_key_name ||
  85. encryptedKey.Length != buf.Length)
  86. return false;
  87. for (int i = 0; i < buf.Length; i++)
  88. if (encryptedKey [i] != buf [i])
  89. return false;
  90. return true;
  91. }
  92. public override bool Matches (SecurityKeyIdentifierClause clause)
  93. {
  94. EncryptedKeyIdentifierClause e =
  95. clause as EncryptedKeyIdentifierClause;
  96. return e != null && Matches (e.GetRawBuffer (), e.EncryptionMethod, e.CarriedKeyName);
  97. }
  98. [MonoTODO]
  99. public override string ToString ()
  100. {
  101. return base.ToString ();
  102. }
  103. }
  104. }