ChangeLog 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490
  1. 2008-02-27 Eyal Alaluf <[email protected]>
  2. * InternalEncryptedKeyIdentifierClause.cs IssuedTokenCommunicationObject.cs:
  3. Fix compilation warnings.
  4. 2007-04-17 Atsushi Enomoto <[email protected]>
  5. * IssuedSecurityTokenParameters.cs :
  6. implemented CreateRequestParameters().
  7. 2007-04-02 Atsushi Enomoto <[email protected]>
  8. * TlsClientSession.cs, TlsServerSession.cs,
  9. SslSecurityTokenProvider.cs : support mutual sslnego.
  10. * SslnegoCookieResolver.cs : .net seems to include X509Certificate
  11. information in the cookie.
  12. 2007-04-02 Atsushi Enomoto <[email protected]>
  13. * SecurityContextSecurityToken.cs : Cookie needs a setter.
  14. * SslnegoCookieResolver.cs : set Cookie so that it can be serialized.
  15. * SslSecurityTokenProvider.cs, SslSecurityTokenAuthenticator.cs :
  16. (At provider) check contextId returned by the server.
  17. Reverted ProofToken value (see comments).
  18. * CommunicationSecurityTokenAuthenticator.cs : it now implements
  19. IIssuanceSecurityTokenAuthenticator.
  20. 2007-03-30 Atsushi Enomoto <[email protected]>
  21. * AuthenticatorCommunicationObject.cs : added SecurityBindingElement.
  22. * SslSecurityTokenProvider.cs : a few updates, key is now from
  23. proof token.
  24. * SslSecurityTokenAuthenticator.cs :
  25. use LocalServiceSecuritySettings.IssuedCookieLifetime.
  26. * SpnegoSecurityTokenProvider.cs, SpnegoSecurityTokenAuthenticator.cs,
  27. SspiSession.cs : some ongoing updates
  28. as well as spnego (kerberos) negotiation handling.
  29. * TlsClientSession.cs : by specification it is P_SHA, not PRF
  30. (though not sure, as CombinedHash is for PRF).
  31. 2007-03-30 Atsushi Enomoto <[email protected]>
  32. * SslnegoCookieResolver.cs : ResolveCookie() should simply return
  33. entire SecurityContextToken parsed by dnse:Cookie binary.
  34. 2007-03-27 Atsushi Enomoto <[email protected]>
  35. * SslSecurityTokenAuthenticator.cs, SslSecurityTokenProvider.cs :
  36. Ongoing implementation. Applied some changes for SSPI support.
  37. WSSecurityTokenSerializer is implemented to return binary-secret-
  38. aware token, so just return it. Fixed some CK-HASH usage.
  39. * IssuedTokenCommunicationObject.cs :
  40. Applied some changes for SSPI support.
  41. * SpnegoSecurityTokenAuthenticator.cs, SpnegoSecurityTokenProvider.cs,
  42. SspiSession.cs : new ongoing implementation for SSPI negotiation.
  43. * SspiClientSecurityTokenAuthenticator.cs : spnego authenticator
  44. will go here (it is just a stub. Created when opening a channel).
  45. 2007-03-22 Atsushi Enomoto <[email protected]>
  46. * TlsClientSession.cs, SslSecurityTokenProvider.cs,
  47. SslSecurityTokenAuthenticator.cs : added hash calculation support,
  48. not working yet though (probably at service side).
  49. 2007-03-20 Atsushi Enomoto <[email protected]>
  50. * SslSecurityTokenAuthenticator.cs : don't reuse ContextId for SCT.
  51. Process ServerFinished before ApplicationData exchange.
  52. * TlsServerSession.cs : Fixed ClientKeyExchange stream processing.
  53. 2007-03-20 Atsushi Enomoto <[email protected]>
  54. * TlsClientSession.cs, TlsServerSession.cs :
  55. added ProcessApplicationData()
  56. * SslSecurityTokenAuthenticator.cs, SslSecurityTokenProvider.cs :
  57. process RequestedProofToken as raw TLS negotiation data.
  58. * SslnegoCookieResolver.cs : add comments on data format.
  59. 2007-03-19 Atsushi Enomoto <[email protected]>
  60. * TlsClientSession.cs : added CreateAuthHash(), used by authenticator.
  61. * SecurityContextSecurityToken.cs : support "probably correct" rawdata
  62. creation for cookie. It is not the secret key but some binary xml
  63. data.
  64. * SslnegoCookieResolver.cs : added CreateData() for creating
  65. binary-xmlized token cookie info.
  66. * SslSecurityTokenAuthenticator.cs : create session key (dummy for
  67. now) and use it instead of MasterSecret. Support t:Authenticator.
  68. 2007-03-13 Atsushi Enomoto <[email protected]>
  69. * SslSecurityTokenAuthenticator.cs, SslSecurityTokenProvider.cs :
  70. (The build should be fixed at this state.)
  71. Implemented RSTR consumption and RSTR collection creation (as the
  72. final stage at sslnego phase).
  73. Note that it is still not working, as our binary XmlDictionaryReader
  74. is not working fine (and still not sure if it will work when they
  75. are working fine, as currently there is no way to check if the
  76. byte array binary-serialized and encrypted in the dnse:Cookie is
  77. the actual symmetric key).
  78. 2007-03-13 Atsushi Enomoto <[email protected]>
  79. * SslSecurityTokenParameters.cs : support SecurityContextSecurityToken
  80. in CreateKeyIdentifierClause(). Comment out generic xml token
  81. support until we need it for sure.
  82. 2007-03-13 Atsushi Enomoto <[email protected]>
  83. * SecurityContextSecurityToken.cs : implemented almost all members.
  84. * X509SecurityTokenParameters.cs : added comment on wrong documentation.
  85. 2007-03-13 Atsushi Enomoto <[email protected]>
  86. * SslnegoCookieResolver.cs : new file. It contains the resolver for
  87. MS's non-standard encrypted sslnego shared key (dnse:Cookie), and
  88. more importantly, the description on its data format (which was
  89. almost unabled to be guessed, until I use non-protecting
  90. SecurityStateEncoder and dug in depth to Binary XmlDictionaryReader).
  91. 2007-03-13 Atsushi Enomoto <[email protected]>
  92. * TlsServerSession.cs, TlsClientSession.cs : complete every operations
  93. that depends on ReceiveRecord(). Added accessor to MasterSecret.
  94. 2007-03-09 Atsushi Enomoto <[email protected]>
  95. * TlsServerSession.cs : now ssl negotiation is functional enough to
  96. implement SecurityContextToken(Collection) transmit.
  97. * TlsClientSession.cs : cosmetic code consistency fix.
  98. 2007-03-09 Atsushi Enomoto <[email protected]>
  99. * TlsClientSession.cs, TlsServerSession.cs :
  100. okay, there is RecordProtocol, which makes things much easier and
  101. correct. Now client seems to be interoperable with .net.
  102. 2007-03-08 Atsushi Enomoto <[email protected]>
  103. * TlsClientSession.cs, TlsServerSession.cs :
  104. several fixes; Fixed content type processing (Handshake and
  105. ChangeCipherSpec). Fixed chunk output of handshake messages.
  106. Set server side key verifier.
  107. * SslSecurityTokenProvider.cs : use IssueReply for RSTR (fixed SOAP
  108. action mismatch).
  109. * SslSecurityTokenAuthenticator.cs : implemented most of TLS
  110. negotiation support, except for the final stage (still not clear
  111. what to do here).
  112. 2007-03-07 Atsushi Enomoto <[email protected]>
  113. * AuthenticatorCommunicationObject.cs,
  114. CommunicationSecurityTokenAuthenticator.cs,
  115. SecureConversationSecurityTokenAuthenticator.cs :
  116. new classes for negotiation-based token authenticators.
  117. * SslSecurityTokenAuthenticator.cs : now it is based on
  118. CommunicationSecurityTokenAuthenticator (like corresponding
  119. provider class).
  120. 2007-03-06 Atsushi Enomoto <[email protected]>
  121. * SecureConversationSecurityTokenParameters.cs :
  122. implemented protected properties.
  123. * X509SecurityTokenParameters.cs : added missing ToString().
  124. 2007-03-05 Atsushi Enomoto <[email protected]>
  125. * SslSecurityTokenProvider.cs : implemented some client negotiation
  126. based on Mono.Security.Protocols.Tls.* and WSTrust contracts.
  127. * TlsServerSession.cs, TlsClientSession.cs : session state transition
  128. manager (controls Tls Context).
  129. 2007-03-05 Atsushi Enomoto <[email protected]>
  130. * UserNameSecurityTokenParameters.cs,
  131. RsaSecurityTokenParameters.cs,
  132. IssuedSecurityTokenParameters.cs,
  133. SslSecurityTokenParameters.cs
  134. SspiSecurityTokenParameters.cs,
  135. KerberosSecurityTokenParameters.cs,
  136. SecureConversationSecurityTokenParameters.cs : updated
  137. InitializeSecurityTokenRequirement() based on updated MSDN docs.
  138. Implemented Ssl CreateKeyIdentifierClause().
  139. Implemented IssuedToken copy .ctor().
  140. 2007-03-01 Atsushi Enomoto <[email protected]>
  141. * ServiceModelSecurityTokenRequirement.cs,
  142. RecipientServiceModelSecurityTokenRequirement.cs,
  143. InitiatorServiceModelSecurityTokenRequirement.cs :
  144. implemented ToString().
  145. 2007-03-01 Atsushi Enomoto <[email protected]>
  146. * SslSecurityTokenParameters.cs : more initialization of requirement.
  147. * SslSecurityTokenAuthenticator.cs : new file.
  148. 2007-02-27 Atsushi Enomoto <[email protected]>
  149. * WrappedKeySecurityToken.cs : okkk, HMAC is extra. Just use SHA1,
  150. and not for raw key but for wrapped key.
  151. 2007-02-27 Atsushi Enomoto <[email protected]>
  152. * WrappedKeySecurityToken.cs :
  153. create HMACSHA1 always with the key to compute hash (I'm not sure
  154. it is correct; it is rather to adjust all hash consistent.)
  155. 2007-02-21 Atsushi Enomoto <[email protected]>
  156. * DerivedKeySecurityToken.cs : added ReferenceList for corresponding
  157. references to this key.
  158. 2007-02-21 Atsushi Enomoto <[email protected]>
  159. * DerivedKeySecurityToken.cs : new internal class to represent
  160. wssc:DerivedKeyToken.
  161. 2007-02-16 Atsushi Enomoto <[email protected]>
  162. * WrappedKeySecurityToken.cs : reverted previous change. Key hash
  163. could not be identical for the same key, but EncryptedKeySHA1 is
  164. based on the wrapped key. So, there is an issue that .NET returns
  165. different key than the one in the request message.
  166. 2007-02-15 Atsushi Enomoto <[email protected]>
  167. * WrappedKeySecurityToken.cs : SecurityKey should hold raw key, not
  168. wrapped one.
  169. 2007-02-06 Atsushi Enomoto <[email protected]>
  170. * WrappedKeySecurityToken.cs : it cannot resolve clauses from its
  171. .ctor() argument identifier clauses. Match EncrypedKeySHA1 clause
  172. if the hash values match.
  173. * InternalEncryptedKeyIdentifierClause.cs :
  174. derive from Binary clause.
  175. 2007-02-05 Atsushi Enomoto <[email protected]>
  176. * InternalEncryptedKeyIdentifierClause.cs : new file. It might not be
  177. required, but for now it is used to write embedded EncryptedKey in
  178. o:SecurityTokenReference.
  179. 2007-01-11 Atsushi Enomoto <[email protected]>
  180. * WrappedKeySecurityToken.cs : added internal ReferenceList, to
  181. output e:ReferenceList (kind of compromised solution; see comments).
  182. 2007-01-09 Atsushi Enomoto <[email protected]>
  183. * WrappedKeySecurityToken.cs : GetWrappedKey() return value should
  184. be the encrypted value of argument keyToWrap. Added several argument
  185. check.
  186. 2006-12-09 Atsushi Enomoto <[email protected]>
  187. * WrappedKeySecurityToken.cs : implemented missing members, except for
  188. incomplete MatchKeyIdentifierClause().
  189. * SecureConversationSecurityTokenParameters.cs : default
  190. ChannelProtectionRequirements should cover all body parts i.e.
  191. IsBodyIncluded should be true.
  192. 2006-12-06 Atsushi Enomoto <[email protected]>
  193. * SupportingTokenParameters.cs : implemented SetKeyDerivation().
  194. 2006-10-05 Atsushi Enomoto <[email protected]>
  195. * X509SecurityTokenParameters.cs : additional constructors.
  196. 2006-10-03 Atsushi Enomoto <[email protected]>
  197. * BinarySecretSecurityToken.cs : it does not seem that it uses
  198. urn:uuid:blah ("urn:" is extraneous).
  199. 2006-09-27 Atsushi Enomoto <[email protected]>
  200. * SecurityTokenParameters.cs : added internal properties to access
  201. protected properties.
  202. * UserNameSecurityTokenParameters.cs : it's done now.
  203. 2006-09-19 Atsushi Enomoto <[email protected]>
  204. * SecurityTokenParameters.cs : removed MonoTODOs.
  205. * X509SecurityTokenParameters.cs :
  206. InitializeSecurityTokenRequirement() is done.
  207. 2006-09-17 Atsushi Enomoto <[email protected]>
  208. * ProviderCommunicationObject.cs, IssuedTokenCommunicationObject.cs,
  209. SslSecurityTokenProvider.cs : both of issued token and ssl requires
  210. connection requirement, so commonize the check.
  211. 2006-09-15 Atsushi Enomoto <[email protected]>
  212. * X509SecurityTokenParameters.cs,
  213. SspiSecurityTokenParameters.cs,
  214. UserNameSecurityTokenParameters.cs,
  215. RsaSecurityTokenParameters.cs,
  216. IssuedSecurityTokenParameters.cs,
  217. SslSecurityTokenParameters.cs : implemented security feature
  218. declaration properties (HasAsymmetricKey etc.) and implemented
  219. some members.
  220. 2006-09-15 Atsushi Enomoto <[email protected]>
  221. * RsaSecurityTokenParameters.cs : TokenType fix.
  222. * ProviderCommunicationObject.cs,
  223. CommunicationSecurityTokenProvider.cs : an abstract token provider
  224. that implements ICommunicationObject, and the abstract communication
  225. object that is used in the provider.
  226. * SslSecurityTokenProvider.cs : a practical example of the above,
  227. not done yet though.
  228. * IssuedTokenCommunicationObject.cs, IssuedSecurityTokenProvider.cs :
  229. it is also significantly refactored like the above.
  230. The ICommunicationObject part of this provider class now just wraps
  231. the intermediate object.
  232. 2006-09-12 Atsushi Enomoto <[email protected]>
  233. * X509SecurityTokenParameters.cs : when token reference style is
  234. Internal, use LocalIdKeyIdentifierClause. The default for this type
  235. should be "Any".
  236. 2006-09-05 Atsushi Enomoto <[email protected]>
  237. * ServiceModelSecurityTokenRequirement.cs : implemented IsInitiator.
  238. * InitiatorServiceModelSecurityTokenRequirement.cs :
  239. initialize IsInitiator as true.
  240. 2006-09-05 Atsushi Enomoto <[email protected]>
  241. * SecurityContextSecurityTokenAuthenticator.cs,
  242. SspiSecurityToken.cs : new files.
  243. * SupportingTokenParameters.cs : copy ctor became private.
  244. 2006-08-30 Atsushi Enomoto <[email protected]>
  245. * X509SecurityTokenParameters.cs,
  246. UserNameSecurityTokenParameters.cs : implemented properties.
  247. * RsaSecurityTokenParameters.cs : new file.
  248. 2006-08-28 Atsushi Enomoto <[email protected]>
  249. * IssuedSecurityTokenProvider.cs : (GetToken) partly implemented
  250. response message consumption.
  251. 2006-08-28 Atsushi Enomoto <[email protected]>
  252. * X509SecurityTokenParameters.cs :
  253. implemented CreateKeyIdentifierClause().
  254. 2006-08-28 Atsushi Enomoto <[email protected]>
  255. * SupportingTokenParameters.cs : added some missing members.
  256. 2006-08-25 Atsushi Enomoto <[email protected]>
  257. * BinarySecretSecurityToken.cs : some .ctor() are protected.
  258. 2006-08-25 Atsushi Enomoto <[email protected]>
  259. * KerberosSecurityTokenParameters.cs : new test.
  260. 2006-08-25 Atsushi Enomoto <[email protected]>
  261. * InitiatorServiceModelSecurityTokenRequirement.cs,
  262. RecipientServiceModelSecurityTokenRequirement.cs :
  263. just use Properties to set and get each property.
  264. * SslSecurityTokenParameters.cs : fix ctor chain.
  265. hacky InitializeSecurityTokenRequirement implementation.
  266. 2006-08-24 Atsushi Enomoto <[email protected]>
  267. * SecureConversationSecurityTokenParameters.cs :
  268. fill SecurityAlgorithmSuite to the requirement.
  269. * SecurityTokenParameters.cs :
  270. added internal IssuerBindingContext property for
  271. SecurityBindingElement.SetIssuerBindingContextIfRequired().
  272. Use this context in CallInitializeSecurityTokenParameters().
  273. 2006-08-23 Atsushi Enomoto <[email protected]>
  274. * IssuedSecurityTokenParameters.cs : oops, oops. fix build.
  275. 2006-08-23 Atsushi Enomoto <[email protected]>
  276. * IssuedSecurityTokenParameters.cs : added missing members.
  277. * IssuedSecurityTokenProvider.cs : replacing broken data contract
  278. based contracts with message based contract.
  279. Support IssuerChannelBehaviors.
  280. * SecureConversationSecurityTokenParameters.cs :
  281. more InitializeSerurityTokenRequirement().
  282. 2006-08-23 Atsushi Enomoto <[email protected]>
  283. * SecurityContextSecurityTokenResolver.cs
  284. ISecurityContextSecurityTokenCache.cs
  285. SecurityContextSecurityToken.cs : new files.
  286. 2006-08-22 Atsushi Enomoto <[email protected]>
  287. * SecureConversationSecurityTokenParameters.cs :
  288. partially implemented InitializeSecurityTokenRequirement().
  289. * X509SecurityTokenParameters.cs : added X509ReferenceStyle.
  290. * SspiSecurityTokenParameters.cs : new file.
  291. 2006-08-22 Atsushi Enomoto <[email protected]>
  292. * SslSecurityTokenParameters.cs,
  293. SecureConversationSecurityTokenParameters.cs : new files.
  294. * SecurityTokenParameters.cs : added internal invoker for
  295. InitializeSecurityTokenRequirement().
  296. * IssuedSecurityTokenParameters.cs, X509SecurityTokenParameters.cs :
  297. implement InitializeSecurityTokenRequirement() (incomplete).
  298. * ServiceModelSecurityTokenRequirement.cs :
  299. MessageSecurityVersion is of type SecurityTokenVersion.
  300. 2006-08-17 Atsushi Enomoto <[email protected]>
  301. * ServiceModelSecurityTokenTypes.cs : new file.
  302. 2006-08-16 Atsushi Enomoto <[email protected]>
  303. * IssuedSecurityTokenProvider.cs :
  304. WST request and response types are renamed.
  305. 2006-08-14 Atsushi Enomoto <[email protected]>
  306. * IssuedSecurityTokenProvider.cs : use new WSTrust proxy (ClientBase)
  307. instead of ChannelFactory.
  308. * SecurityTokenParameters.cs : added internal helper method for
  309. CreateKeyIdentifierClause().
  310. * ServiceModelSecurityTokenRequirement.cs : in several properties,
  311. use TryGetProperty<T>() instead of having direct fields (so that
  312. only setting items to "Properties" also affects on those props).
  313. 2006-08-11 Atsushi Enomoto <[email protected]>
  314. * InitiatorServiceModelSecurityTokenRequirement.cs,
  315. RecipientServiceModelSecurityTokenRequirement.cs,
  316. ServiceModelSecurityTokenRequirement.cs : new files.
  317. 2006-08-07 Atsushi Enomoto <[email protected]>
  318. * IssuedSecurityTokenProvider.cs : moved some premise checks from
  319. GetTokenCore() to Open().
  320. 2006-08-04 Atsushi Enomoto <[email protected]>
  321. * WrappedKeySecurityToken.cs : new file.
  322. 2006-08-04 Atsushi Enomoto <[email protected]>
  323. * BinarySecretSecurityToken.cs : new file.
  324. 2006-08-03 Atsushi Enomoto <[email protected]>
  325. * UserNameSecurityTokenParameters.cs,
  326. X509SecurityTokenParameters.cs : new files.
  327. 2006-08-02 Atsushi Enomoto <[email protected]>
  328. * IssuedSecurityTokenProvider.cs : (GetTokenCore) some premise check.
  329. 2006-08-01 Atsushi Enomoto <[email protected]>
  330. * IssuedSecurityTokenProvider.cs : implemented some properties.
  331. * RenewedSecurityTokenHandler.cs, IssuedSecurityTokenHandler.cs,
  332. IIssuanceSecurityTokenAuthenticator.cs : new files.
  333. 2006-08-01 Atsushi Enomoto <[email protected]>
  334. * IssuedSecurityTokenProvider.cs, ClaimTypeRequirement.cs : new files.
  335. * IssuedSecurityTokenParameters.cs : added some missing members.
  336. 2006-07-21 Atsushi Enomoto <[email protected]>
  337. * SecurityTokenReferenceStyle.cs : moved from S.SM.Security namespace.
  338. 2006-07-21 Atsushi Enomoto <[email protected]>
  339. * IssuedSecurityTokenParameters.cs, SecurityTokenParameters.cs :
  340. new files.
  341. 2006-07-10 Atsushi Enomoto <[email protected]>
  342. * SupportingTokenParameters.cs : new file.