summary refs log tree commit diff
path: root/MxApiExtensions/Controllers/Extensions/DebugController.cs
blob: 6f87e51b7649ca1e732d65363954ba01a995f4fa (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
using System.Collections.Concurrent;
using Microsoft.AspNetCore.Mvc;
using Microsoft.OpenApi.Extensions;
using MxApiExtensions.Classes.LibMatrix;
using MxApiExtensions.Services;

namespace MxApiExtensions.Controllers.Extensions;

[ApiController]
[Route("/")]
public class DebugController(ILogger<ProxyConfigurationController> logger, MxApiExtensionsConfiguration config, UserContextService userContextService)
    : ControllerBase {
    private readonly ILogger _logger = logger;

    private static ConcurrentDictionary<string, RoomInfoEntry> _roomInfoCache = new();

    [HttpGet("debug")]
    public async Task<object?> GetDebug() {
#if !DEBUG
        var user = await userContextService.GetCurrentUserContext();
        var mxid = user.Homeserver.UserId;
        if(!config.Admins.Contains(mxid)) {
            _logger.LogWarning("Got debug request for {user}, but they are not an admin", mxid);
            Response.StatusCode = StatusCodes.Status403Forbidden;
            Response.ContentType = "application/json";

            await Response.WriteAsJsonAsync(new {
                ErrorCode = "M_FORBIDDEN",
                Error = "You are not an admin"
            });
            await Response.CompleteAsync();
            return null;
        }
        _logger.LogInformation("Got debug request for {user}", mxid);
#endif

        return new {
            syncControllerTasks = SyncController.TrackedTasks.Select(t => new {
                t?.Id,
                t?.IsCompleted,
                t?.IsCompletedSuccessfully,
                t?.IsCanceled,
                t?.IsFaulted,
                Status = t?.Status.GetDisplayName()
            }),
            UserContextService.UserContextStore
        };
    }
}