1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 01:02:56 +08:00

Add realm context to sentry

This commit is contained in:
Dean Herbert 2022-05-11 14:51:56 +09:00
parent 977a0453cc
commit f53d42d31f

View File

@ -6,14 +6,18 @@
using System; using System;
using System.Diagnostics; using System.Diagnostics;
using System.IO; using System.IO;
using System.Linq;
using System.Net; using System.Net;
using osu.Framework.Allocation; using osu.Framework.Allocation;
using osu.Framework.Bindables; using osu.Framework.Bindables;
using osu.Framework.Logging; using osu.Framework.Logging;
using osu.Game.Beatmaps; using osu.Game.Beatmaps;
using osu.Game.Configuration; using osu.Game.Configuration;
using osu.Game.Database;
using osu.Game.Models;
using osu.Game.Online.API.Requests.Responses; using osu.Game.Online.API.Requests.Responses;
using osu.Game.Overlays; using osu.Game.Overlays;
using osu.Game.Skinning;
using Sentry; using Sentry;
using Sentry.Protocol; using Sentry.Protocol;
@ -101,13 +105,27 @@ namespace osu.Game.Utils
Level = getSentryLevel(entry.Level), Level = getSentryLevel(entry.Level),
}, scope => }, scope =>
{ {
var beatmap = game.Dependencies.Get<IBindable<WorkingBeatmap>>().Value.BeatmapInfo;
scope.Contexts[@"config"] = new scope.Contexts[@"config"] = new
{ {
Game = game.Dependencies.Get<OsuConfigManager>().GetLoggableState() Game = game.Dependencies.Get<OsuConfigManager>().GetLoggableState()
// TODO: add framework config here. needs some consideration on how to expose. // TODO: add framework config here. needs some consideration on how to expose.
}; };
var beatmap = game.Dependencies.Get<IBindable<WorkingBeatmap>>().Value.BeatmapInfo; game.Dependencies.Get<RealmAccess>().Run(realm =>
{
scope.Contexts[@"realm"] = new
{
Counts = new
{
BeatmapSets = realm.All<BeatmapSetInfo>().Count(),
Beatmaps = realm.All<BeatmapInfo>().Count(),
Files = realm.All<RealmFile>().Count(),
Skins = realm.All<SkinInfo>().Count(),
}
};
});
scope.Contexts[@"beatmap"] = new scope.Contexts[@"beatmap"] = new
{ {