/xmlbench/trunk

To get this branch, use:
bzr branch http://darksoft.org/webbzr/xmlbench/trunk

« back to all changes in this revision

Viewing changes to security/mono-dom.cs

  • Committer: Suren A. Chilingaryan
  • Date: 2009-10-08 03:17:59 UTC
  • Revision ID: csa@dside.dyndns.org-20091008031759-u5ys779huye7feni
LibXML Pull Parser, FAXPP Parser, Mono security benchmark, multiple fixes

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
using System;
 
2
using System.IO;
 
3
using System.Xml;
 
4
using System.Security.Cryptography;
 
5
using System.Security.Cryptography.Xml;
 
6
using System.Security.Cryptography.X509Certificates;
 
7
 
 
8
using XMLBench;
 
9
 
 
10
namespace XMLBench {
 
11
 public class MonoBench : XMLBench {
 
12
  XmlDocument doc;
 
13
 
 
14
  RSACryptoServiceProvider rsa;
 
15
  TripleDESCryptoServiceProvider des;
 
16
 
 
17
  EncryptedKey symkey;
 
18
  EncryptedData encData;
 
19
  Reference reference;
 
20
  
 
21
  override public void InitXML_Security() {
 
22
    des =  new TripleDESCryptoServiceProvider();
 
23
 
 
24
/*
 
25
    
 
26
    X509Certificate2 x509 = new X509Certificate2("../ssl/test.crt");
 
27
    rsa = (RSACryptoServiceProvider)x509.PublicKey.Key;
 
28
    Have not found to load separate PEM encoded private key, to do later
 
29
    using openssl.cs
 
30
*/
 
31
    
 
32
        // Automatically generates key, could by exchanged, using FromXmlString
 
33
    rsa = new RSACryptoServiceProvider();
 
34
        // false/true selects if privat key should be exported as well
 
35
    //Console.WriteLine(rsa.ToXmlString(false));
 
36
    
 
37
 
 
38
    KeyInfoName keyinfo = new KeyInfoName();
 
39
    keyinfo.Value = "session";
 
40
 
 
41
    symkey = new EncryptedKey();
 
42
    symkey.CipherData = new CipherData(EncryptedXml.EncryptKey(des.Key, rsa, false));
 
43
    symkey.EncryptionMethod = new EncryptionMethod(EncryptedXml.XmlEncRSA15Url);
 
44
//  symkey.KeyInfo = new KeyInfo();
 
45
    symkey.KeyInfo.AddClause(keyinfo);
 
46
 
 
47
    encData = new EncryptedData();
 
48
    encData.EncryptionMethod = new EncryptionMethod(EncryptedXml.XmlEncTripleDESUrl);
 
49
    encData.Type = EncryptedXml.XmlEncElementUrl;
 
50
    encData.KeyInfo.AddClause(new KeyInfoEncryptedKey(symkey));
 
51
 
 
52
    XmlDsigEnvelopedSignatureTransform env = new XmlDsigEnvelopedSignatureTransform();
 
53
    reference = new Reference("");
 
54
    reference.AddTransform(env);
 
55
 
 
56
  }
 
57
 
 
58
  override public void ParseXML(Stream xml, int iters, int iter) {
 
59
    XmlTextReader reader = new XmlTextReader(xml);
 
60
    doc = new XmlDocument();
 
61
    doc.Load(reader);
 
62
  }
 
63
 
 
64
  override public void SignXML(Stream xml, int iters, int iter) {
 
65
    SignedXml signedXml = new SignedXml(doc);
 
66
    signedXml.SigningKey = rsa;
 
67
    signedXml.AddReference(reference);
 
68
    signedXml.ComputeSignature();
 
69
    
 
70
    doc.DocumentElement.AppendChild(signedXml.GetXml());
 
71
 
 
72
/*
 
73
    doc.DocumentElement.FirstChild.AppendChild(doc.CreateNode(XmlNodeType.Element, "", "a", ""));
 
74
    doc.DocumentElement.AppendChild(doc.CreateNode(XmlNodeType.Element, "", "a", ""));
 
75
    
 
76
    if (iter==0) {
 
77
        StringWriter mem = new StringWriter();
 
78
        XmlTextWriter w = new XmlTextWriter(mem);
 
79
        doc.WriteTo(w);
 
80
        Console.WriteLine(mem);
 
81
    }
 
82
*/    
 
83
  }
 
84
 
 
85
  override public void VerifyXML(Stream xml, int iters, int iter) {
 
86
    SignedXml signedXml = new SignedXml(doc);
 
87
    XmlNodeList nodeList = doc.GetElementsByTagName("Signature");
 
88
    signedXml.LoadXml((XmlElement)nodeList[0]);
 
89
    if (!signedXml.CheckSignature(rsa)) {
 
90
        Console.WriteLine("Validation Failed");
 
91
    }
 
92
  }
 
93
    
 
94
  override public void EncryptXML(Stream xml, int iters, int iter) {
 
95
/*
 
96
        Use default symmetric algorithm
 
97
        xmlEnc.AddKeyNameMapping("session", rsa);
 
98
        EncryptedData encData = xmlEnc.Encrypt(doc.DocumentElement, "session");
 
99
*/
 
100
 
 
101
    EncryptedXml xmlEnc = new EncryptedXml(doc);
 
102
    encData.CipherData.CipherValue = xmlEnc.EncryptData(doc.DocumentElement, des, false);
 
103
    EncryptedXml.ReplaceElement(doc.DocumentElement, encData, false);
 
104
 
 
105
/*
 
106
    if (iter==0) {
 
107
        StringWriter mem = new StringWriter();
 
108
        XmlTextWriter w = new XmlTextWriter(mem);
 
109
        doc.WriteTo(w);
 
110
        Console.WriteLine(mem);
 
111
    }
 
112
*/
 
113
  }
 
114
 
 
115
  override public void DecryptXML(Stream xml, int iters, int iter) {
 
116
    EncryptedXml xmlEnc = new EncryptedXml(doc);
 
117
    xmlEnc.AddKeyNameMapping("session", rsa);
 
118
    xmlEnc.DecryptDocument();
 
119
 
 
120
/*
 
121
    if (iter==0) {
 
122
        StringWriter mem = new StringWriter();
 
123
        XmlTextWriter w = new XmlTextWriter(mem);
 
124
        doc.WriteTo(w);
 
125
        Console.WriteLine(mem);
 
126
    }
 
127
*/
 
128
  }
 
129
    
 
130
 }
 
131
 
 
132
 public class Mono {
 
133
    public static void Main(string[] args) {
 
134
        XMLBench bench = new MonoBench();
 
135
        bench.Bench(args);
 
136
    }
 
137
 }
 
138
}