| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388 |
- //------------------------------------------------------------
- // Copyright (c) Microsoft Corporation. All rights reserved.
- //------------------------------------------------------------
- namespace System.Xml
- {
- using System.IO;
- using System.Text;
- class XmlSigningNodeWriter : XmlNodeWriter
- {
- XmlNodeWriter writer;
- XmlCanonicalWriter signingWriter;
- byte[] chars;
- byte[] base64Chars;
- bool text;
- public XmlSigningNodeWriter(bool text)
- {
- this.text = text;
- }
- public void SetOutput(XmlNodeWriter writer, Stream stream, bool includeComments, string[] inclusivePrefixes)
- {
- this.writer = writer;
- if (signingWriter == null)
- signingWriter = new XmlCanonicalWriter();
- this.signingWriter.SetOutput(stream, includeComments, inclusivePrefixes);
- this.chars = new byte[XmlConverter.MaxPrimitiveChars];
- this.base64Chars = null;
- }
- public XmlNodeWriter NodeWriter
- {
- get
- {
- return writer;
- }
- set
- {
- writer = value;
- }
- }
- public XmlCanonicalWriter CanonicalWriter
- {
- get
- {
- return signingWriter;
- }
- }
- public override void Flush()
- {
- writer.Flush();
- signingWriter.Flush();
- }
- public override void Close()
- {
- writer.Close();
- signingWriter.Close();
- }
- public override void WriteDeclaration()
- {
- writer.WriteDeclaration();
- signingWriter.WriteDeclaration();
- }
- public override void WriteComment(string text)
- {
- writer.WriteComment(text);
- signingWriter.WriteComment(text);
- }
- public override void WriteCData(string text)
- {
- writer.WriteCData(text);
- signingWriter.WriteEscapedText(text);
- }
- public override void WriteStartElement(string prefix, string localName)
- {
- writer.WriteStartElement(prefix, localName);
- signingWriter.WriteStartElement(prefix, localName);
- }
- public override void WriteStartElement(byte[] prefixBuffer, int prefixOffset, int prefixLength,
- byte[] localNameBuffer, int localNameOffset, int localNameLength)
- {
- writer.WriteStartElement(prefixBuffer, prefixOffset, prefixLength, localNameBuffer, localNameOffset, localNameLength);
- signingWriter.WriteStartElement(prefixBuffer, prefixOffset, prefixLength, localNameBuffer, localNameOffset, localNameLength);
- }
- public override void WriteStartElement(string prefix, XmlDictionaryString localName)
- {
- writer.WriteStartElement(prefix, localName);
- signingWriter.WriteStartElement(prefix, localName.Value);
- }
- public override void WriteEndStartElement(bool isEmpty)
- {
- writer.WriteEndStartElement(isEmpty);
- signingWriter.WriteEndStartElement(isEmpty);
- }
- public override void WriteEndElement(string prefix, string localName)
- {
- writer.WriteEndElement(prefix, localName);
- signingWriter.WriteEndElement(prefix, localName);
- }
- public override void WriteXmlnsAttribute(string prefix, string ns)
- {
- writer.WriteXmlnsAttribute(prefix, ns);
- signingWriter.WriteXmlnsAttribute(prefix, ns);
- }
- public override void WriteXmlnsAttribute(byte[] prefixBuffer, int prefixOffset, int prefixLength,
- byte[] nsBuffer, int nsOffset, int nsLength)
- {
- writer.WriteXmlnsAttribute(prefixBuffer, prefixOffset, prefixLength, nsBuffer, nsOffset, nsLength);
- signingWriter.WriteXmlnsAttribute(prefixBuffer, prefixOffset, prefixLength, nsBuffer, nsOffset, nsLength);
- }
- public override void WriteXmlnsAttribute(string prefix, XmlDictionaryString ns)
- {
- writer.WriteXmlnsAttribute(prefix, ns);
- signingWriter.WriteXmlnsAttribute(prefix, ns.Value);
- }
- public override void WriteStartAttribute(string prefix, string localName)
- {
- writer.WriteStartAttribute(prefix, localName);
- signingWriter.WriteStartAttribute(prefix, localName);
- }
- public override void WriteStartAttribute(byte[] prefixBuffer, int prefixOffset, int prefixLength,
- byte[] localNameBuffer, int localNameOffset, int localNameLength)
- {
- writer.WriteStartAttribute(prefixBuffer, prefixOffset, prefixLength, localNameBuffer, localNameOffset, localNameLength);
- signingWriter.WriteStartAttribute(prefixBuffer, prefixOffset, prefixLength, localNameBuffer, localNameOffset, localNameLength);
- }
- public override void WriteStartAttribute(string prefix, XmlDictionaryString localName)
- {
- writer.WriteStartAttribute(prefix, localName);
- signingWriter.WriteStartAttribute(prefix, localName.Value);
- }
- public override void WriteEndAttribute()
- {
- writer.WriteEndAttribute();
- signingWriter.WriteEndAttribute();
- }
- public override void WriteCharEntity(int ch)
- {
- writer.WriteCharEntity(ch);
- signingWriter.WriteCharEntity(ch);
- }
- public override void WriteEscapedText(string value)
- {
- writer.WriteEscapedText(value);
- signingWriter.WriteEscapedText(value);
- }
- public override void WriteEscapedText(char[] chars, int offset, int count)
- {
- writer.WriteEscapedText(chars, offset, count);
- signingWriter.WriteEscapedText(chars, offset, count);
- }
- public override void WriteEscapedText(XmlDictionaryString value)
- {
- writer.WriteEscapedText(value);
- signingWriter.WriteEscapedText(value.Value);
- }
- public override void WriteEscapedText(byte[] chars, int offset, int count)
- {
- writer.WriteEscapedText(chars, offset, count);
- signingWriter.WriteEscapedText(chars, offset, count);
- }
- public override void WriteText(string value)
- {
- writer.WriteText(value);
- signingWriter.WriteText(value);
- }
- public override void WriteText(char[] chars, int offset, int count)
- {
- writer.WriteText(chars, offset, count);
- signingWriter.WriteText(chars, offset, count);
- }
- public override void WriteText(byte[] chars, int offset, int count)
- {
- writer.WriteText(chars, offset, count);
- signingWriter.WriteText(chars, offset, count);
- }
- public override void WriteText(XmlDictionaryString value)
- {
- writer.WriteText(value);
- signingWriter.WriteText(value.Value);
- }
- public override void WriteInt32Text(int value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteInt32Text(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteInt64Text(Int64 value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteInt64Text(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteBoolText(bool value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteBoolText(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteUInt64Text(UInt64 value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteUInt64Text(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteFloatText(float value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteFloatText(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteDoubleText(double value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteDoubleText(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteDecimalText(decimal value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteDecimalText(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteDateTimeText(DateTime value)
- {
- int count = XmlConverter.ToChars(value, chars, 0);
- if (text)
- writer.WriteText(chars, 0, count);
- else
- writer.WriteDateTimeText(value);
- signingWriter.WriteText(chars, 0, count);
- }
- public override void WriteUniqueIdText(UniqueId value)
- {
- string s = XmlConverter.ToString(value);
- if (text)
- writer.WriteText(s);
- else
- writer.WriteUniqueIdText(value);
- signingWriter.WriteText(s);
- }
- public override void WriteTimeSpanText(TimeSpan value)
- {
- string s = XmlConverter.ToString(value);
- if (text)
- writer.WriteText(s);
- else
- writer.WriteTimeSpanText(value);
- signingWriter.WriteText(s);
- }
- public override void WriteGuidText(Guid value)
- {
- string s = XmlConverter.ToString(value);
- if (text)
- writer.WriteText(s);
- else
- writer.WriteGuidText(value);
- signingWriter.WriteText(s);
- }
- public override void WriteStartListText()
- {
- writer.WriteStartListText();
- }
- public override void WriteListSeparator()
- {
- writer.WriteListSeparator();
- signingWriter.WriteText(' ');
- }
- public override void WriteEndListText()
- {
- writer.WriteEndListText();
- }
- public override void WriteBase64Text(byte[] trailBytes, int trailByteCount, byte[] buffer, int offset, int count)
- {
- if (trailByteCount > 0)
- WriteBase64Text(trailBytes, 0, trailByteCount);
- WriteBase64Text(buffer, offset, count);
- if (!text)
- {
- writer.WriteBase64Text(trailBytes, trailByteCount, buffer, offset, count);
- }
- }
- void WriteBase64Text(byte[] buffer, int offset, int count)
- {
- if (base64Chars == null)
- base64Chars = new byte[512];
- Base64Encoding encoding = XmlConverter.Base64Encoding;
- while (count >= 3)
- {
- int byteCount = Math.Min(base64Chars.Length / 4 * 3, count - count % 3);
- int charCount = byteCount / 3 * 4;
- encoding.GetChars(buffer, offset, byteCount, base64Chars, 0);
- signingWriter.WriteText(base64Chars, 0, charCount);
- if (text)
- {
- writer.WriteText(base64Chars, 0, charCount);
- }
- offset += byteCount;
- count -= byteCount;
- }
- if (count > 0)
- {
- encoding.GetChars(buffer, offset, count, base64Chars, 0);
- signingWriter.WriteText(base64Chars, 0, 4);
- if (text)
- {
- writer.WriteText(base64Chars, 0, 4);
- }
- }
- }
- public override void WriteQualifiedName(string prefix, XmlDictionaryString localName)
- {
- writer.WriteQualifiedName(prefix, localName);
- if (prefix.Length != 0)
- {
- signingWriter.WriteText(prefix);
- signingWriter.WriteText(":");
- }
- signingWriter.WriteText(localName.Value);
- }
- }
- }
|