Merge pull request #1304 from slluis/mac-proxy-autoconfig
[mono.git] / mcs / class / System.IdentityModel / System.IdentityModel.Tokens / X509SigningCredentials.cs
1 //
2 // X509SigningCredentials.cs
3 //
4 // Author:
5 //   Noesis Labs (Ryan.Melena@noesislabs.com)
6 //
7 // Copyright (C) 2014 Noesis Labs, LLC  https://noesislabs.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 #if NET_4_5
29
30 using System;
31 using System.Security.Cryptography.X509Certificates;
32
33 namespace System.IdentityModel.Tokens
34 {
35         public class X509SigningCredentials : SigningCredentials
36         {
37                 public X509Certificate2 Certificate { get; private set; }
38
39                 public X509SigningCredentials (X509Certificate2 certificate)
40                         : this (certificate, X509SigningCredentials.GetSecurityKeyIdentifier (certificate), SecurityAlgorithms.RsaSha256Signature, SecurityAlgorithms.Sha256Digest)
41                 { }
42
43                 public X509SigningCredentials (X509Certificate2 certificate, SecurityKeyIdentifier ski)
44                         : this (certificate, ski, SecurityAlgorithms.RsaSha256Signature, SecurityAlgorithms.Sha256Digest)
45                 { }
46
47                 public X509SigningCredentials (X509Certificate2 certificate, string signatureAlgorithm, string digestAlgorithm)
48                         : this (certificate, X509SigningCredentials.GetSecurityKeyIdentifier (certificate), signatureAlgorithm, digestAlgorithm)
49                 { }
50
51                 public X509SigningCredentials (X509Certificate2 certificate, SecurityKeyIdentifier ski, string signatureAlgorithm, string digestAlgorithm)
52                         : base (new X509SecurityToken (certificate).SecurityKeys[0], signatureAlgorithm, digestAlgorithm, ski)
53                 {
54                         Certificate = certificate;
55                 }
56
57                 private static SecurityKeyIdentifier GetSecurityKeyIdentifier (X509Certificate2 certificate) {
58                         return new SecurityKeyIdentifier (new X509SecurityToken (certificate).CreateKeyIdentifierClause<X509RawDataKeyIdentifierClause> ());
59                 }
60         }
61 }
62 #endif