mirror of
				https://github.com/Kopano-dev/kopano-ol-extension.git
				synced 2023-10-10 11:37:40 +00:00 
			
		
		
		
	Fixes to URLs for SOAP and ActiveSync requests; additional logging in case of error
This commit is contained in:
		| @@ -84,11 +84,23 @@ namespace Acacia.ZPush.Connect.Soap | |||||||
|  |  | ||||||
|         #region Decoding |         #region Decoding | ||||||
|  |  | ||||||
|         public override object ParseResponse(Stream result) |         public override object ParseResponse(string url, Stream result) | ||||||
|         { |         { | ||||||
|             // Parse xml |             // Parse xml | ||||||
|             XmlDocument xml = new XmlDocument(); |             XmlDocument xml = new XmlDocument(); | ||||||
|             xml.Load(result); |             using (StreamReader reader = new StreamReader(result)) | ||||||
|  |             { | ||||||
|  |                 string text = reader.ReadToEnd(); | ||||||
|  |                 try | ||||||
|  |                 { | ||||||
|  |                     xml.LoadXml(text); | ||||||
|  |                 } | ||||||
|  |                 catch (Exception e) | ||||||
|  |                 { | ||||||
|  |                     Logger.Instance.Error(this, "Error in SOAP response:\nurl={0}\nresponse={1}", url, text); | ||||||
|  |                     throw e; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |  | ||||||
|             // Check if it's an error message |             // Check if it's an error message | ||||||
|             CheckFaultResponse(xml); |             CheckFaultResponse(xml); | ||||||
|   | |||||||
| @@ -136,7 +136,7 @@ namespace Acacia.ZPush.Connect | |||||||
|                     using (HttpContent responseContent = response.Content) |                     using (HttpContent responseContent = response.Content) | ||||||
|                     { |                     { | ||||||
|                         Logger.Instance.Trace(this, "Response: {0}", responseContent.ReadAsStringAsync().Result); |                         Logger.Instance.Trace(this, "Response: {0}", responseContent.ReadAsStringAsync().Result); | ||||||
|                         return request.ParseResponse(responseContent.ReadAsStreamAsync().Result); |                         return request.ParseResponse(url, responseContent.ReadAsStreamAsync().Result); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -288,8 +288,12 @@ namespace Acacia.ZPush.Connect | |||||||
|  |  | ||||||
|             public Response Execute(ActiveSync.RequestBase request) |             public Response Execute(ActiveSync.RequestBase request) | ||||||
|             { |             { | ||||||
|                 string url = string.Format(ACTIVESYNC_URL, _account.Account.ServerURL, _account.Account.DeviceId, |                 string url = string.Format(ACTIVESYNC_URL,  | ||||||
|                     request.Command, _account.Account.UserName, "WindowsOutlook"); |                     _account.Account.ServerURL, | ||||||
|  |                     Uri.EscapeDataString(_account.Account.DeviceId), | ||||||
|  |                     request.Command, | ||||||
|  |                     Uri.EscapeDataString(_account.Account.UserName),  | ||||||
|  |                     "WindowsOutlook"); | ||||||
|  |  | ||||||
|                 // Construct the body |                 // Construct the body | ||||||
|                 WBXMLDocument doc = new WBXMLDocument(); |                 WBXMLDocument doc = new WBXMLDocument(); | ||||||
|   | |||||||
| @@ -28,6 +28,6 @@ namespace Acacia.ZPush.Connect | |||||||
|     { |     { | ||||||
|         public abstract HttpContent GetContent(); |         public abstract HttpContent GetContent(); | ||||||
|  |  | ||||||
|         public abstract object ParseResponse(Stream result); |         public abstract object ParseResponse(string url, Stream result); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -49,7 +49,7 @@ namespace Acacia.ZPush.Connect | |||||||
|             string url = string.Format(ACTIVESYNC_URL, _connection.Account.Account.ServerURL, "webservice", |             string url = string.Format(ACTIVESYNC_URL, _connection.Account.Account.ServerURL, "webservice", | ||||||
|                     ServiceName, |                     ServiceName, | ||||||
|                     // TODO: this username is a bit of a quick hack.  |                     // TODO: this username is a bit of a quick hack.  | ||||||
|                     request.UserName ?? _connection.Account.Account.UserName, |                     Uri.EscapeDataString(request.UserName ?? _connection.Account.Account.UserName), | ||||||
|                     "webservice"); |                     "webservice"); | ||||||
|  |  | ||||||
|             // Set up the encoding |             // Set up the encoding | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user