void processResponseError(GcmAsyncParameters asyncParam) { var result = new GcmMessageTransportResponse(); result.ResponseCode = GcmMessageTransportResponseCode.Error; if (asyncParam.WebResponse.StatusCode == HttpStatusCode.Unauthorized) { //401 bad auth token result.ResponseCode = GcmMessageTransportResponseCode.InvalidAuthToken; throw new GcmAuthenticationErrorTransportException(result); } else if (asyncParam.WebResponse.StatusCode == HttpStatusCode.BadRequest) { result.ResponseCode = GcmMessageTransportResponseCode.BadRequest; throw new GcmBadRequestTransportException(result); } else if (asyncParam.WebResponse.StatusCode == HttpStatusCode.InternalServerError) { result.ResponseCode = GcmMessageTransportResponseCode.InternalServiceError; throw new GcmMessageTransportException("Internal Service Error", result); } else if (asyncParam.WebResponse.StatusCode == HttpStatusCode.ServiceUnavailable) { //First try grabbing the retry-after header and parsing it. TimeSpan retryAfter = new TimeSpan(0, 0, 120); var wrRetryAfter = asyncParam.WebResponse.GetResponseHeader("Retry-After"); if (!string.IsNullOrEmpty(wrRetryAfter)) { DateTime wrRetryAfterDate = DateTime.UtcNow; if (DateTime.TryParse(wrRetryAfter, out wrRetryAfterDate)) { retryAfter = wrRetryAfterDate - DateTime.UtcNow; } else { int wrRetryAfterSeconds = 120; if (int.TryParse(wrRetryAfter, out wrRetryAfterSeconds)) { retryAfter = new TimeSpan(0, 0, wrRetryAfterSeconds); } } } //503 exponential backoff, get retry-after header result.ResponseCode = GcmMessageTransportResponseCode.ServiceUnavailable; throw new GcmServiceUnavailableTransportException(retryAfter, result); } asyncParam.WebResponse.Close(); throw new GcmMessageTransportException("Unknown Transport Error", result); }
void processResponseError(GcmAsyncParameters asyncParam) { var result = new GcmMessageTransportResponse(); result.ResponseCode = GcmMessageTransportResponseCode.Error; if (asyncParam == null || asyncParam.WebResponse == null) throw new GcmMessageTransportException("Unknown Transport Error", result); if (asyncParam.WebResponse.StatusCode == HttpStatusCode.Unauthorized) { //401 bad auth token result.ResponseCode = GcmMessageTransportResponseCode.InvalidAuthToken; throw new GcmAuthenticationErrorTransportException(result); } else if (asyncParam.WebResponse.StatusCode == HttpStatusCode.BadRequest) { result.ResponseCode = GcmMessageTransportResponseCode.BadRequest; throw new GcmBadRequestTransportException(result); } else if (asyncParam.WebResponse.StatusCode == HttpStatusCode.InternalServerError) { result.ResponseCode = GcmMessageTransportResponseCode.InternalServiceError; throw new GcmMessageTransportException("Internal Service Error", result); } else if (asyncParam.WebResponse.StatusCode == HttpStatusCode.ServiceUnavailable) { //First try grabbing the retry-after header and parsing it. TimeSpan retryAfter = new TimeSpan(0, 0, 120); var wrRetryAfter = asyncParam.WebResponse.GetResponseHeader("Retry-After"); if (!string.IsNullOrEmpty(wrRetryAfter)) { DateTime wrRetryAfterDate = DateTime.UtcNow; if (DateTime.TryParse(wrRetryAfter, out wrRetryAfterDate)) retryAfter = wrRetryAfterDate - DateTime.UtcNow; else { int wrRetryAfterSeconds = 120; if (int.TryParse(wrRetryAfter, out wrRetryAfterSeconds)) retryAfter = new TimeSpan(0, 0, wrRetryAfterSeconds); } } //503 exponential backoff, get retry-after header result.ResponseCode = GcmMessageTransportResponseCode.ServiceUnavailable; throw new GcmServiceUnavailableTransportException(retryAfter, result); } asyncParam.WebResponse.Close(); throw new GcmMessageTransportException("Unknown Transport Error", result); }
void processResponseOk(GcmAsyncParameters asyncParam) { var result = new GcmMessageTransportResponse() { ResponseCode = GcmMessageTransportResponseCode.Ok, Message = asyncParam.Message }; //Get the response body var json = new JObject(); var str = string.Empty; try { str = (new StreamReader(asyncParam.WebResponse.GetResponseStream())).ReadToEnd(); } catch { } try { json = JObject.Parse(str); } catch { } result.NumberOfCanonicalIds = json.Value<long>("canonical_ids"); result.NumberOfFailures = json.Value<long>("failure"); result.NumberOfSuccesses = json.Value<long>("success"); var jsonResults = json["results"] as JArray; if (jsonResults == null) jsonResults = new JArray(); foreach (var r in jsonResults) { var msgResult = new GcmMessageResult(); msgResult.MessageId = r.Value<string>("message_id"); msgResult.CanonicalRegistrationId = r.Value<string>("registration_id"); msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Ok; if (!string.IsNullOrEmpty(msgResult.CanonicalRegistrationId)) { msgResult.ResponseStatus = GcmMessageTransportResponseStatus.CanonicalRegistrationId; } else if (r["error"] != null) { var err = r.Value<string>("error") ?? ""; switch (err.ToLowerInvariant().Trim()) { case "ok": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Ok; break; case "missingregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MissingRegistrationId; break; case "unavailable": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Unavailable; break; case "notregistered": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.NotRegistered; break; case "invalidregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidRegistration; break; case "mismatchsenderid": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MismatchSenderId; break; case "messagetoobig": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MessageTooBig; break; case "invaliddatakey": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidDataKey; break; case "invalidttl": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidTtl; break; case "internalservererror": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InternalServerError; break; default: msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Error; break; } } result.Results.Add(msgResult); } asyncParam.WebResponse.Close(); int index = 0; var response = result; //Loop through every result in the response // We will raise events for each individual result so that the consumer of the library // can deal with individual registrationid's for the notification foreach (var r in response.Results) { var singleResultNotification = GcmNotification.ForSingleResult(response, index); if (r.ResponseStatus == GcmMessageTransportResponseStatus.Ok) { //It worked! Raise success asyncParam.Callback(this, new SendNotificationResult(singleResultNotification)); } else if (r.ResponseStatus == GcmMessageTransportResponseStatus.CanonicalRegistrationId) { //Swap Registrations Id's var newRegistrationId = r.CanonicalRegistrationId; var oldRegistrationId = string.Empty; if (singleResultNotification.RegistrationIds != null && singleResultNotification.RegistrationIds.Count > 0) oldRegistrationId = singleResultNotification.RegistrationIds[0]; asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, false, new DeviceSubscriptonExpiredException()) { OldSubscriptionId = oldRegistrationId, NewSubscriptionId = newRegistrationId, IsSubscriptionExpired = true }); } else if (r.ResponseStatus == GcmMessageTransportResponseStatus.Unavailable) { asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, true, new Exception("Unavailable Response Status"))); } else if (r.ResponseStatus == GcmMessageTransportResponseStatus.NotRegistered) { var oldRegistrationId = string.Empty; if (singleResultNotification.RegistrationIds != null && singleResultNotification.RegistrationIds.Count > 0) oldRegistrationId = singleResultNotification.RegistrationIds[0]; //Raise failure and device expired asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, false, new DeviceSubscriptonExpiredException()) { OldSubscriptionId = oldRegistrationId, IsSubscriptionExpired = true, SubscriptionExpiryUtc = DateTime.UtcNow }); } else { //Raise failure, for unknown reason asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, false, new GcmMessageTransportException(r.ResponseStatus.ToString(), response))); } index++; } Interlocked.Decrement(ref waitCounter); }
void processResponseOk(GcmAsyncParameters asyncParam) { var result = new GcmMessageTransportResponse() { ResponseCode = GcmMessageTransportResponseCode.Ok, Message = asyncParam.Message }; //Get the response body var json = new JObject(); var str = string.Empty; try { str = (new StreamReader(asyncParam.WebResponse.GetResponseStream())).ReadToEnd(); } catch { } try { json = JObject.Parse(str); } catch { } result.NumberOfCanonicalIds = json.Value <long>("canonical_ids"); result.NumberOfFailures = json.Value <long>("failure"); result.NumberOfSuccesses = json.Value <long>("success"); var jsonResults = json["results"] as JArray; if (jsonResults == null) { jsonResults = new JArray(); } foreach (var r in jsonResults) { var msgResult = new GcmMessageResult(); msgResult.MessageId = r.Value <string>("message_id"); msgResult.CanonicalRegistrationId = r.Value <string>("registration_id"); msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Ok; if (!string.IsNullOrEmpty(msgResult.CanonicalRegistrationId)) { msgResult.ResponseStatus = GcmMessageTransportResponseStatus.CanonicalRegistrationId; } else if (r["error"] != null) { var err = r.Value <string>("error") ?? ""; switch (err.ToLower().Trim()) { case "ok": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Ok; break; case "missingregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MissingRegistrationId; break; case "unavailable": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Unavailable; break; case "notregistered": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.NotRegistered; break; case "invalidregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidRegistration; break; case "mismatchsenderid": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MismatchSenderId; break; case "messagetoobig": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MessageTooBig; break; case "invaliddatakey": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidDataKey; break; case "invalidttl": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidTtl; break; case "internalservererror": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InternalServerError; break; default: msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Error; break; } } result.Results.Add(msgResult); } asyncParam.WebResponse.Close(); int index = 0; var response = result; //Loop through every result in the response // We will raise events for each individual result so that the consumer of the library // can deal with individual registrationid's for the notification foreach (var r in response.Results) { var singleResultNotification = GcmNotification.ForSingleResult(response, index); if (r.ResponseStatus == GcmMessageTransportResponseStatus.Ok) { //It worked! Raise success asyncParam.Callback(this, new SendNotificationResult(singleResultNotification)); } else if (r.ResponseStatus == GcmMessageTransportResponseStatus.CanonicalRegistrationId) { //Swap Registrations Id's var newRegistrationId = r.CanonicalRegistrationId; var oldRegistrationId = string.Empty; if (singleResultNotification.RegistrationIds != null && singleResultNotification.RegistrationIds.Count > 0) { oldRegistrationId = singleResultNotification.RegistrationIds[0]; } asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, false, new DeviceSubscriptonExpiredException()) { OldSubscriptionId = oldRegistrationId, NewSubscriptionId = newRegistrationId, IsSubscriptionExpired = true }); } else if (r.ResponseStatus == GcmMessageTransportResponseStatus.Unavailable) { asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, true, new Exception("Unavailable Response Status"))); } else if (r.ResponseStatus == GcmMessageTransportResponseStatus.NotRegistered) { var oldRegistrationId = string.Empty; if (singleResultNotification.RegistrationIds != null && singleResultNotification.RegistrationIds.Count > 0) { oldRegistrationId = singleResultNotification.RegistrationIds[0]; } //Raise failure and device expired asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, false, new DeviceSubscriptonExpiredException()) { OldSubscriptionId = oldRegistrationId, IsSubscriptionExpired = true, SubscriptionExpiryUtc = DateTime.UtcNow }); } else { //Raise failure, for unknown reason asyncParam.Callback(this, new SendNotificationResult(singleResultNotification, false, new GcmMessageTransportException(r.ResponseStatus.ToString(), response))); } index++; } Interlocked.Decrement(ref waitCounter); }
void processResponseOk(GcmAsyncParameters asyncParam) { var result = new GcmMessageTransportResponse() { ResponseCode = GcmMessageTransportResponseCode.Ok, Message = asyncParam.Message }; var updateClientAuth = asyncParam.WebResponse.GetResponseHeader("Update-Client-Auth"); if (!string.IsNullOrEmpty(updateClientAuth) && UpdateGoogleClientAuthToken != null) UpdateGoogleClientAuthToken(updateClientAuth); //Get the response body var json = new JObject(); try { json = JObject.Parse((new StreamReader(asyncParam.WebResponse.GetResponseStream())).ReadToEnd()); } catch { } result.NumberOfCanonicalIds = json.Value<long>("canonical_ids"); result.NumberOfFailures = json.Value<long>("failure"); result.NumberOfSuccesses = json.Value<long>("success"); var jsonResults = json["results"] as JArray; if (jsonResults == null) jsonResults = new JArray(); foreach (var r in json["results"]) { var msgResult = new GcmMessageResult(); msgResult.MessageId = r.Value<string>("message_id"); msgResult.CanonicalRegistrationId = r.Value<string>("registration_id"); if (!string.IsNullOrEmpty(msgResult.CanonicalRegistrationId)) { msgResult.ResponseStatus = GcmMessageTransportResponseStatus.CanonicalRegistrationId; } else if (r["error"] != null) { var err = r.Value<string>("error") ?? ""; switch (err.ToLower().Trim()) { case "missingregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MissingRegistrationId; break; case "unavailable": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Unavailable; break; case "notregistered": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.NotRegistered; break; case "invalidregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidRegistration; break; case "mismatchsenderid": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MismatchSenderId; break; case "messagetoobig": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MessageTooBig; break; default: msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Error; break; } } result.Results.Add(msgResult); } asyncParam.WebResponse.Close(); var evtmrr = MessageResponseReceived; if (evtmrr != null) evtmrr(result); }
void processResponseOk(GcmAsyncParameters asyncParam) { var result = new GcmMessageTransportResponse() { ResponseCode = GcmMessageTransportResponseCode.Ok, Message = asyncParam.Message }; var updateClientAuth = asyncParam.WebResponse.GetResponseHeader("Update-Client-Auth"); if (!string.IsNullOrEmpty(updateClientAuth) && UpdateGoogleClientAuthToken != null) { UpdateGoogleClientAuthToken(updateClientAuth); } //Get the response body var json = new JObject(); try { json = JObject.Parse((new StreamReader(asyncParam.WebResponse.GetResponseStream())).ReadToEnd()); } catch { } result.NumberOfCanonicalIds = json.Value <long>("canonical_ids"); result.NumberOfFailures = json.Value <long>("failure"); result.NumberOfSuccesses = json.Value <long>("success"); var jsonResults = json["results"] as JArray; if (jsonResults == null) { jsonResults = new JArray(); } foreach (var r in json["results"]) { var msgResult = new GcmMessageResult(); msgResult.MessageId = r.Value <string>("message_id"); msgResult.CanonicalRegistrationId = r.Value <string>("registration_id"); if (!string.IsNullOrEmpty(msgResult.CanonicalRegistrationId)) { msgResult.ResponseStatus = GcmMessageTransportResponseStatus.CanonicalRegistrationId; } else if (r["error"] != null) { var err = r.Value <string>("error") ?? ""; switch (err.ToLower().Trim()) { case "missingregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MissingRegistrationId; break; case "unavailable": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Unavailable; break; case "notregistered": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.NotRegistered; break; case "invalidregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidRegistration; break; case "mismatchsenderid": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MismatchSenderId; break; case "messagetoobig": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MessageTooBig; break; case "invaliddatakey": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidDataKey; break; case "invalidttl": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidTtl; break; case "internalservererror": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InternalServerError; break; default: msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Error; break; } } result.Results.Add(msgResult); } asyncParam.WebResponse.Close(); var evtmrr = MessageResponseReceived; if (evtmrr != null) { evtmrr(result); } }
void processResponseError(GcmAsyncParameters asyncParam) { try { var result = new GcmMessageTransportResponse(); result.ResponseCode = GcmMessageTransportResponseCode.Error; if (asyncParam == null || asyncParam.WebResponse == null) { throw new GcmMessageTransportException("Unknown Transport Error", result); } int statusCode = (int)asyncParam.WebResponse.StatusCode; if (asyncParam.WebResponse.StatusCode == HttpStatusCode.Unauthorized) { //401 bad auth token result.ResponseCode = GcmMessageTransportResponseCode.InvalidAuthToken; throw new GcmAuthenticationErrorTransportException(result); } else if (asyncParam.WebResponse.StatusCode == HttpStatusCode.BadRequest) { result.ResponseCode = GcmMessageTransportResponseCode.BadRequest; throw new GcmBadRequestTransportException(result); } else if (statusCode >= 500 && statusCode < 600) { //First try grabbing the retry-after header and parsing it. TimeSpan retryAfter = new TimeSpan(0, 0, 120); var wrRetryAfter = asyncParam.WebResponse.GetResponseHeader("Retry-After"); if (!string.IsNullOrEmpty(wrRetryAfter)) { DateTime wrRetryAfterDate = DateTime.UtcNow; if (DateTime.TryParse(wrRetryAfter, out wrRetryAfterDate)) { retryAfter = wrRetryAfterDate - DateTime.UtcNow; } else { int wrRetryAfterSeconds = 120; if (int.TryParse(wrRetryAfter, out wrRetryAfterSeconds)) { retryAfter = new TimeSpan(0, 0, wrRetryAfterSeconds); } } } //Compatability for apps written with previous versions of PushSharp. if (asyncParam.WebResponse.StatusCode == HttpStatusCode.InternalServerError) { result.ResponseCode = GcmMessageTransportResponseCode.InternalServiceError; } else { //503 exponential backoff, get retry-after header result.ResponseCode = GcmMessageTransportResponseCode.ServiceUnavailable; } throw new GcmServiceUnavailableTransportException(retryAfter, result); } throw new GcmMessageTransportException("Unknown Transport Error", result); } finally { if (asyncParam != null && asyncParam.WebResponse != null) { asyncParam.WebResponse.Close(); } } }
void processResponseOk(GcmAsyncParameters asyncParam) { var result = new GcmMessageTransportResponse() { ResponseCode = GcmMessageTransportResponseCode.Ok, Message = asyncParam.Message }; var updateClientAuth = asyncParam.WebResponse.GetResponseHeader("Update-Client-Auth"); if (!string.IsNullOrEmpty(updateClientAuth) && UpdateGoogleClientAuthToken != null) { UpdateGoogleClientAuthToken(updateClientAuth); } //Get the response body var json = new JObject(); try { json = Utils.FromJSonString((new StreamReader(asyncParam.WebResponse.GetResponseStream())).ReadToEnd()); } catch { } long jsonResultLong = 0; long.TryParse(json["canonical_ids"].ToString(), out jsonResultLong); result.NumberOfCanonicalIds = jsonResultLong; jsonResultLong = 0; long.TryParse(json["failure"].ToString(), out jsonResultLong); result.NumberOfFailures = jsonResultLong; jsonResultLong = 0; long.TryParse(json["success"].ToString(), out jsonResultLong); result.NumberOfSuccesses = jsonResultLong; var jsonResults = json["results"] as JArray; if (jsonResults == null) { jsonResults = new JArray(); } foreach (JObject r in (JArray)json["results"]) { var msgResult = new GcmMessageResult(); msgResult.MessageId = (string)r["message_id"]; msgResult.CanonicalRegistrationId = (string)r["registration_id"]; if (!string.IsNullOrEmpty(msgResult.CanonicalRegistrationId)) { msgResult.ResponseStatus = GcmMessageTransportResponseStatus.CanonicalRegistrationId; } else if (r["error"] != null) { var err = (string)r["error"] ?? ""; switch (err.ToLower().Trim()) { case "missingregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MissingRegistrationId; break; case "unavailable": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Unavailable; break; case "notregistered": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.NotRegistered; break; case "invalidregistration": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.InvalidRegistration; break; case "mismatchsenderid": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MismatchSenderId; break; case "messagetoobig": msgResult.ResponseStatus = GcmMessageTransportResponseStatus.MessageTooBig; break; default: msgResult.ResponseStatus = GcmMessageTransportResponseStatus.Error; break; } } result.Results.Add(msgResult); } asyncParam.WebResponse.Close(); var evtmrr = MessageResponseReceived; if (evtmrr != null) { evtmrr(result); } }