Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataWeb / Server / System / Data / Services / Serializers / BatchWriter.cs / 1305376 / BatchWriter.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // //// Provides a base class for DataWeb services. // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services.Serializers { #region Namespaces. using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; #endregion Namespaces. ////// Static helper class to write responses for batch requests /// internal static class BatchWriter { ////// Writes the start of the changeset response /// /// writer to which the response needs to be written /// batch boundary /// changeset boundary internal static void WriteStartBatchBoundary(StreamWriter writer, string batchBoundary, string changesetBoundary) { WriterStartBoundary(writer, batchBoundary); writer.WriteLine( "{0}: {1}; {2}={3}", XmlConstants.HttpContentType, XmlConstants.MimeMultiPartMixed, XmlConstants.HttpMultipartBoundary, changesetBoundary); writer.WriteLine(); // NewLine to seperate the header from message } ///Write the boundary and header information. /// writer to which the response needs to be written /// host containing the value of the response headers /// content-id string that needs to be written /// boundary string that needs to be written internal static void WriteBoundaryAndHeaders(StreamWriter writer, IDataServiceHost2 host, string contentId, string boundary) { Debug.Assert(writer != null, "writer != null"); Debug.Assert(host != null, "host != null"); Debug.Assert(boundary != null, "boundary != null"); WriterStartBoundary(writer, boundary); // First write the headers to indicate that the payload below is a http request WriteHeaderValue(writer, XmlConstants.HttpContentType, XmlConstants.MimeApplicationHttp); WriteHeaderValue(writer, XmlConstants.HttpContentTransferEncoding, XmlConstants.BatchRequestContentTransferEncoding); writer.WriteLine(); // NewLine to seperate the batch headers from http headers // In error cases, we create a dummy host, which has no request header information. // Hence we need to handle the case here. writer.WriteLine("{0} {1} {2}", XmlConstants.HttpVersionInBatching, host.ResponseStatusCode, WebUtil.GetStatusCodeText(host.ResponseStatusCode)); if (null != contentId) { WriteHeaderValue(writer, XmlConstants.HttpContentID, contentId); } System.Net.WebHeaderCollection responseHeaders = host.ResponseHeaders; foreach (string header in responseHeaders.AllKeys) { WriteHeaderValue(writer, header, responseHeaders[header]); } writer.WriteLine(); // NewLine to seperate the header from message } ////// Write the end boundary /// /// writer to which the response needs to be written /// end boundary string. internal static void WriteEndBoundary(StreamWriter writer, string boundary) { writer.WriteLine("--{0}--", boundary); } ////// Write the start boundary /// /// writer to which the response needs to be written /// boundary string. private static void WriterStartBoundary(StreamWriter writer, string boundary) { writer.WriteLine("--{0}", boundary); } ////// Write the header name and value /// /// writer to which the response needs to be written /// name of the header whose value needs to be written. /// value of the header that needs to be written. private static void WriteHeaderValue(StreamWriter writer, string headerName, object headerValue) { if (headerValue != null) { string text = Convert.ToString(headerValue, System.Globalization.CultureInfo.InvariantCulture); if (!String.IsNullOrEmpty(text)) { writer.WriteLine("{0}: {1}", headerName, text); } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // //// Provides a base class for DataWeb services. // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services.Serializers { #region Namespaces. using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; #endregion Namespaces. ////// Static helper class to write responses for batch requests /// internal static class BatchWriter { ////// Writes the start of the changeset response /// /// writer to which the response needs to be written /// batch boundary /// changeset boundary internal static void WriteStartBatchBoundary(StreamWriter writer, string batchBoundary, string changesetBoundary) { WriterStartBoundary(writer, batchBoundary); writer.WriteLine( "{0}: {1}; {2}={3}", XmlConstants.HttpContentType, XmlConstants.MimeMultiPartMixed, XmlConstants.HttpMultipartBoundary, changesetBoundary); writer.WriteLine(); // NewLine to seperate the header from message } ///Write the boundary and header information. /// writer to which the response needs to be written /// host containing the value of the response headers /// content-id string that needs to be written /// boundary string that needs to be written internal static void WriteBoundaryAndHeaders(StreamWriter writer, IDataServiceHost2 host, string contentId, string boundary) { Debug.Assert(writer != null, "writer != null"); Debug.Assert(host != null, "host != null"); Debug.Assert(boundary != null, "boundary != null"); WriterStartBoundary(writer, boundary); // First write the headers to indicate that the payload below is a http request WriteHeaderValue(writer, XmlConstants.HttpContentType, XmlConstants.MimeApplicationHttp); WriteHeaderValue(writer, XmlConstants.HttpContentTransferEncoding, XmlConstants.BatchRequestContentTransferEncoding); writer.WriteLine(); // NewLine to seperate the batch headers from http headers // In error cases, we create a dummy host, which has no request header information. // Hence we need to handle the case here. writer.WriteLine("{0} {1} {2}", XmlConstants.HttpVersionInBatching, host.ResponseStatusCode, WebUtil.GetStatusCodeText(host.ResponseStatusCode)); if (null != contentId) { WriteHeaderValue(writer, XmlConstants.HttpContentID, contentId); } System.Net.WebHeaderCollection responseHeaders = host.ResponseHeaders; foreach (string header in responseHeaders.AllKeys) { WriteHeaderValue(writer, header, responseHeaders[header]); } writer.WriteLine(); // NewLine to seperate the header from message } ////// Write the end boundary /// /// writer to which the response needs to be written /// end boundary string. internal static void WriteEndBoundary(StreamWriter writer, string boundary) { writer.WriteLine("--{0}--", boundary); } ////// Write the start boundary /// /// writer to which the response needs to be written /// boundary string. private static void WriterStartBoundary(StreamWriter writer, string boundary) { writer.WriteLine("--{0}", boundary); } ////// Write the header name and value /// /// writer to which the response needs to be written /// name of the header whose value needs to be written. /// value of the header that needs to be written. private static void WriteHeaderValue(StreamWriter writer, string headerName, object headerValue) { if (headerValue != null) { string text = Convert.ToString(headerValue, System.Globalization.CultureInfo.InvariantCulture); if (!String.IsNullOrEmpty(text)) { writer.WriteLine("{0}: {1}", headerName, text); } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- Serializer.cs
- HtmlSelectionListAdapter.cs
- MissingMethodException.cs
- InputProcessorProfiles.cs
- DataGridViewLinkCell.cs
- PasswordPropertyTextAttribute.cs
- EntityClassGenerator.cs
- XmlCodeExporter.cs
- InputReport.cs
- HwndTarget.cs
- ExtenderControl.cs
- Point3DAnimation.cs
- Interlocked.cs
- Overlapped.cs
- Border.cs
- ApplicationSecurityManager.cs
- ClickablePoint.cs
- KnownTypeAttribute.cs
- BidOverLoads.cs
- TypeLoadException.cs
- LinkUtilities.cs
- BitmapEffectState.cs
- MimeReturn.cs
- CodeTryCatchFinallyStatement.cs
- TakeOrSkipQueryOperator.cs
- _CacheStreams.cs
- __ConsoleStream.cs
- TableAdapterManagerNameHandler.cs
- ExpressionBindingCollection.cs
- XmlObjectSerializerReadContextComplex.cs
- RenderData.cs
- ToolStripDesigner.cs
- QilVisitor.cs
- ActiveXContainer.cs
- LinkedResourceCollection.cs
- IriParsingElement.cs
- SQLMembershipProvider.cs
- OleDbStruct.cs
- TableLayoutPanelCellPosition.cs
- DefaultProxySection.cs
- HWStack.cs
- XmlCompatibilityReader.cs
- PropertyChangeTracker.cs
- SafeEventHandle.cs
- IntSecurity.cs
- XmlCharCheckingReader.cs
- WindowsRichEditRange.cs
- DataGridCaption.cs
- PageThemeParser.cs
- COM2TypeInfoProcessor.cs
- counter.cs
- GridLength.cs
- ObjectAnimationBase.cs
- Switch.cs
- RectAnimationClockResource.cs
- XPathExpr.cs
- EventlogProvider.cs
- HttpModuleCollection.cs
- ConstraintConverter.cs
- DataGridViewLinkCell.cs
- SafeRightsManagementQueryHandle.cs
- ObjectKeyFrameCollection.cs
- MinMaxParagraphWidth.cs
- LinqDataSourceValidationException.cs
- RepeaterItem.cs
- XmlValidatingReaderImpl.cs
- DataControlField.cs
- DataGridDetailsPresenter.cs
- SequenceDesignerAccessibleObject.cs
- XpsDigitalSignature.cs
- TextAction.cs
- ObjectAnimationBase.cs
- InternalsVisibleToAttribute.cs
- DetailsViewModeEventArgs.cs
- NavigationProperty.cs
- RadioButtonRenderer.cs
- LocalClientSecuritySettings.cs
- MenuItem.cs
- ConnectionProviderAttribute.cs
- dtdvalidator.cs
- XmlCharType.cs
- TypeUtil.cs
- EventLogPermissionHolder.cs
- ServiceModelEnhancedConfigurationElementCollection.cs
- PropertySourceInfo.cs
- DataPointer.cs
- HtmlInputButton.cs
- CollectionViewGroupInternal.cs
- MaskedTextProvider.cs
- QilExpression.cs
- MDIWindowDialog.cs
- DBNull.cs
- DetailsViewModeEventArgs.cs
- XpsFontSubsetter.cs
- FocusChangedEventArgs.cs
- ImageDrawing.cs
- TreeViewCancelEvent.cs
- WebHttpBindingCollectionElement.cs
- WebPartManager.cs
- EditorOptionAttribute.cs