本文整理汇总了C#中IMessage.GetBody方法的典型用法代码示例。如果您正苦于以下问题:C# IMessage.GetBody方法的具体用法?C# IMessage.GetBody怎么用?C# IMessage.GetBody使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IMessage
的用法示例。
在下文中一共展示了IMessage.GetBody方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ProcessWebHookNotification
private object ProcessWebHookNotification(IMessage<WebHookNotification> message) {
WebHookNotification body = message.GetBody();
Log.Trace().Project(body.ProjectId).Message("Process web hook call: project={0} url={1}", body.ProjectId, body.Url).Write();
var client = new HttpClient();
client.PostAsJsonAsync(body.Url, body.Data).ContinueWith(res => {
if (res.Result.StatusCode == HttpStatusCode.Gone) {
_projectHookRepository.Delete(Query.EQ(ProjectHookRepository.FieldNames.Url, body.Url));
Log.Trace().Project(body.ProjectId).Message("Deleting web hook: project={0} url={1}", body.ProjectId, body.Url).Write();
}
Log.Trace().Project(body.ProjectId).Message("Web hook POST complete: status={0} project={1} url={2}", res.Result.StatusCode, body.ProjectId, body.Url).Write();
}).Wait();
return null;
}
示例2: CreateSerializationStrategy
private DefaultMessageSerializationStrategy CreateSerializationStrategy(IMessage<MyMessage> message, string messageType, byte[] messageBody, string correlationId)
{
var typeNameSerializer = MockRepository.GenerateStub<ITypeNameSerializer>();
typeNameSerializer.Stub(s => s.Serialize(message.MessageType)).Return(messageType);
var serializer = MockRepository.GenerateStub<ISerializer>();
serializer.Stub(s => s.MessageToBytes(message.GetBody())).Return(messageBody);
return new DefaultMessageSerializationStrategy(typeNameSerializer, serializer, new StaticCorrelationIdGenerationStrategy(correlationId));
}
示例3: ExecuteAsync
/// <summary>Executes the asynchronous operation.</summary>
///
/// <param name="request">The request.</param>
///
/// <returns>An object.</returns>
public object ExecuteAsync(IMessage<UnRetryableFail> request)
{
return Any(request.GetBody());
}
示例4: ProcessSummaryNotification
private object ProcessSummaryNotification(IMessage<SummaryNotification> message) {
var project = _projectRepository.GetByIdCached(message.GetBody().Id);
var organization = _organizationRepository.GetByIdCached(project.OrganizationId);
var userIds = project.NotificationSettings.Where(n => n.Value.SendDailySummary).Select(n => n.Key).ToList();
if (userIds.Count == 0)
return null;
var users = _userRepository.GetByIds(userIds).Where(u => u.IsEmailAddressVerified).ToList();
if (users.Count == 0)
return null;
long count;
List<ErrorStack> newest = _stackRepository.GetNew(project.Id, message.GetBody().UtcStartTime, message.GetBody().UtcEndTime, 0, 5, out count).ToList();
DateTime start = _projectRepository.UtcToDefaultProjectLocalTime(project.Id, message.GetBody().UtcStartTime);
DateTime end = _projectRepository.UtcToDefaultProjectLocalTime(project.Id, message.GetBody().UtcEndTime);
var result = _errorStatsHelper.GetProjectErrorStats(project.Id, _projectRepository.GetDefaultTimeOffset(project.Id), start, end);
var mostFrequent = result.MostFrequent.Results.Take(5).ToList();
var errorStacks = _stackRepository.GetByIds(mostFrequent.Select(s => s.Id));
foreach (var frequent in mostFrequent) {
var stack = errorStacks.SingleOrDefault(s => s.Id == frequent.Id);
if (stack == null) {
mostFrequent.RemoveAll(r => r.Id == frequent.Id);
continue;
}
// Stat's Id and Total properties are already calculated in the Results.
frequent.Type = stack.SignatureInfo.ContainsKey("ExceptionType") ? stack.SignatureInfo["ExceptionType"] : null;
frequent.Method = stack.SignatureInfo.ContainsKey("Method") ? stack.SignatureInfo["Method"] : null;
frequent.Path = stack.SignatureInfo.ContainsKey("Path") ? stack.SignatureInfo["Path"] : null;
frequent.Is404 = stack.SignatureInfo.ContainsKey("Path");
frequent.Title = stack.Title;
frequent.First = stack.FirstOccurrence;
frequent.Last = stack.LastOccurrence;
}
var notification = new SummaryNotificationModel {
ProjectId = project.Id,
ProjectName = project.Name,
StartDate = start,
EndDate = end,
Total = result.Total,
PerHourAverage = result.PerHourAverage,
NewTotal = result.NewTotal,
New = newest,
UniqueTotal = result.UniqueTotal,
MostFrequent = mostFrequent,
HasSubmittedErrors = project.TotalErrorCount > 0,
IsFreePlan = organization.PlanId == BillingManager.FreePlan.Id
};
foreach (var user in users.Where(u => u.EmailNotificationsEnabled))
_mailer.SendSummaryNotification(user.EmailAddress, notification);
return null;
}
示例5: ProcessSummaryNotificationException
private void ProcessSummaryNotificationException(IMessage<SummaryNotification> message, Exception exception) {
exception.ToExceptionless().AddDefaultInformation().MarkAsCritical().AddObject(message.GetBody()).AddTags("ErrorMQ").Submit();
Log.Error().Project(message.GetBody().Id).Exception(exception).Message("Error processing daily summary.").Write();
}
示例6: ProcessWebHookNotificationException
private void ProcessWebHookNotificationException(IMessage<WebHookNotification> message, Exception exception) {
Log.Error().Project(message.GetBody().ProjectId).Exception(exception).Message("Error calling web hook ({0}): {1}", message.GetBody().Url, exception.Message).Write();
}
示例7: ProcessNotificationException
private void ProcessNotificationException(IMessage<ErrorNotification> message, Exception exception) {
exception.ToExceptionless().AddDefaultInformation().MarkAsCritical().AddObject(message.GetBody()).AddTags("NotificationMQ").Submit();
Log.Error().Project(message.GetBody().ProjectId).Exception(exception).Message("Error sending notification.").Write();
}
示例8: ProcessNotification
private object ProcessNotification(IMessage<ErrorNotification> message) {
int emailsSent = 0;
ErrorNotification errorNotification = message.GetBody();
Log.Trace().Message("Process notification: project={0} error={1} stack={2}", errorNotification.ProjectId, errorNotification.ErrorId, errorNotification.ErrorStackId).Write();
var project = _projectRepository.GetByIdCached(errorNotification.ProjectId);
if (project == null) {
Log.Error().Message("Could not load project {0}.", errorNotification.ProjectId).Write();
return null;
}
Log.Trace().Message("Loaded project: name={0}", project.Name).Write();
var organization = _organizationRepository.GetByIdCached(project.OrganizationId);
if (organization == null) {
Log.Error().Message("Could not load organization {0}.", project.OrganizationId).Write();
return null;
}
Log.Trace().Message("Loaded organization: name={0}", organization.Name).Write();
var stack = _stackRepository.GetById(errorNotification.ErrorStackId);
if (stack == null) {
Log.Error().Message("Could not load stack {0}.", errorNotification.ErrorStackId).Write();
return null;
}
if (!organization.HasPremiumFeatures) {
Log.Trace().Message("Skipping because organization does not have premium features.").Write();
return null;
}
if (stack.DisableNotifications || stack.IsHidden) {
Log.Trace().Message("Skipping because stack notifications are disabled or it's hidden.").Write();
return null;
}
Log.Trace().Message("Loaded stack: title={0}", stack.Title).Write();
int totalOccurrences = stack.TotalOccurrences;
// after the first 5 occurrences, don't send a notification for the same stack more then once every 15 minutes
var lastTimeSent = _cacheClient.Get<DateTime>(String.Concat("NOTIFICATION_THROTTLE_", errorNotification.ErrorStackId));
if (totalOccurrences > 5 && !errorNotification.IsRegression && lastTimeSent != DateTime.MinValue &&
lastTimeSent > DateTime.Now.AddMinutes(-15)) {
Log.Info().Message("Skipping message because of throttling: last sent={0} occurrences={1}", lastTimeSent, totalOccurrences).Write();
return null;
}
foreach (var kv in project.NotificationSettings) {
var settings = kv.Value;
Log.Trace().Message("Processing notification: user={0}", kv.Key).Write();
var user = _userRepository.GetById(kv.Key);
if (user == null || String.IsNullOrEmpty(user.EmailAddress)) {
Log.Error().Message("Could not load user {0} or blank email address {1}.", kv.Key, user != null ? user.EmailAddress : "").Write();
continue;
}
if (!user.IsEmailAddressVerified) {
Log.Info().Message("User {0} with email address {1} has not been verified.", kv.Key, user != null ? user.EmailAddress : "").Write();
continue;
}
if (!user.EmailNotificationsEnabled) {
Log.Trace().Message("User {0} with email address {1} has email notifications disabled.", kv.Key, user != null ? user.EmailAddress : "").Write();
continue;
}
if (!user.OrganizationIds.Contains(project.OrganizationId)) {
// TODO: Should this notification setting be deleted?
Log.Error().Message("Unauthorized user: project={0} user={1} organization={2} error={3}", project.Id, kv.Key,
project.OrganizationId, errorNotification.ErrorId).Write();
continue;
}
Log.Trace().Message("Loaded user: email={0}", user.EmailAddress).Write();
bool shouldReportOccurrence = settings.Mode != NotificationMode.None;
bool shouldReportCriticalError = settings.ReportCriticalErrors && errorNotification.IsCritical;
bool shouldReportRegression = settings.ReportRegressions && errorNotification.IsRegression;
Log.Trace().Message("Settings: mode={0} critical={1} regression={2} 404={3} bots={4}",
settings.Mode, settings.ReportCriticalErrors,
settings.ReportRegressions, settings.Report404Errors,
settings.ReportKnownBotErrors).Write();
Log.Trace().Message("Should process: occurrence={0} critical={1} regression={2}",
shouldReportOccurrence, shouldReportCriticalError,
shouldReportRegression).Write();
if (settings.Mode == NotificationMode.New && !errorNotification.IsNew) {
shouldReportOccurrence = false;
Log.Trace().Message("Skipping because message is not new.").Write();
}
// check for 404s if the user has elected to not report them
if (shouldReportOccurrence && settings.Report404Errors == false && errorNotification.Code == "404") {
shouldReportOccurrence = false;
Log.Trace().Message("Skipping because message is 404.").Write();
}
// check for known bots if the user has elected to not report them
if (shouldReportOccurrence && settings.ReportKnownBotErrors == false &&
//.........这里部分代码省略.........
示例9: ProcessErrorException
private void ProcessErrorException(IMessage<Error> message, Exception exception) {
exception.ToExceptionless().AddDefaultInformation().MarkAsCritical().AddObject(message.GetBody()).AddTags("ErrorMQ").Submit();
Log.Error().Project(message.GetBody().ProjectId).Exception(exception).Message("Error processing error.").Write();
_stats.Counter(StatNames.ErrorsProcessingFailed);
}
示例10: ProcessError
private object ProcessError(IMessage<Error> message) {
Error value = message.GetBody();
if (value == null)
return null;
_stats.Counter(StatNames.ErrorsDequeued);
using (_stats.StartTimer(StatNames.ErrorsProcessingTime))
_errorPipeline.Run(value);
return null;
}
示例11: ProcessEventException
private void ProcessEventException(IMessage<PersistentEvent> message, Exception exception)
{
exception.ToExceptionless().AddDefaultInformation().MarkAsCritical().AddObject(message.GetBody()).AddTags("ErrorMQ").Submit();
Log.Error().Project(message.GetBody().ProjectId).Exception(exception).Message("Error processing error.").Write();
}
示例12: ProcessEvent
private object ProcessEvent(IMessage<PersistentEvent> message)
{
PersistentEvent value = message.GetBody();
if (value == null)
return null;
using (_stats.StartTimer(StatNames.EventsProcessingTime))
_eventPipeline.Run(value);
return null;
}
示例13: ExecuteAsync
/// <summary>Executes the asynchronous operation.</summary>
///
/// <param name="request">The request.</param>
///
/// <returns>An object.</returns>
public object ExecuteAsync(IMessage<Greet> request)
{
return Any(request.GetBody());
}
示例14: HandleSecureRequests
public SecureResponse HandleSecureRequests(IMessage<Secure> message, SecureLogic logic)
{
return logic.ProcessRequest(message.GetBody());
}
示例15: ExecuteAsync
/// <summary>Executes the asynchronous operation.</summary>
///
/// <param name="request">The request.</param>
///
/// <returns>An object.</returns>
public object ExecuteAsync(IMessage<AlwaysFail> request)
{
return Any(request.GetBody());
}