source: binary-improvements2/WebServer/src/WebAPI/APIs/Log.cs@ 434

Last change on this file since 434 was 434, checked in by alloc, 18 months ago

Added permission management APIs

File size: 2.8 KB
Line 
1using System.Collections.Generic;
2using JetBrains.Annotations;
3using Utf8Json;
4
5namespace Webserver.WebAPI.APIs {
6 [UsedImplicitly]
7 public class Log : AbsRestApi {
8 private const int maxCount = 1000;
9
10 private static readonly byte[] jsonKeyEntries = JsonWriter.GetEncodedPropertyNameWithBeginObject ("entries");
11 private static readonly byte[] jsonKeyFirstLine = JsonWriter.GetEncodedPropertyNameWithPrefixValueSeparator ("firstLine");
12 private static readonly byte[] jsonKeyLastLine = JsonWriter.GetEncodedPropertyNameWithPrefixValueSeparator ("lastLine");
13
14 private static readonly byte[] jsonMsgKey = JsonWriter.GetEncodedPropertyNameWithBeginObject ("msg");
15 private static readonly byte[] jsonTypeKey = JsonWriter.GetEncodedPropertyNameWithPrefixValueSeparator ("type");
16 private static readonly byte[] jsonTraceKey = JsonWriter.GetEncodedPropertyNameWithPrefixValueSeparator ("trace");
17 private static readonly byte[] jsonIsotimeKey = JsonWriter.GetEncodedPropertyNameWithPrefixValueSeparator ("isotime");
18 private static readonly byte[] jsonUptimeKey = JsonWriter.GetEncodedPropertyNameWithPrefixValueSeparator ("uptime");
19
20 protected override void HandleRestGet (RequestContext _context) {
21 if (_context.Request.QueryString ["count"] == null || !int.TryParse (_context.Request.QueryString ["count"], out int count)) {
22 count = 50;
23 }
24
25 if (count == 0) {
26 count = 1;
27 }
28
29 if (count > maxCount) {
30 count = maxCount;
31 }
32
33 if (count < -maxCount) {
34 count = -maxCount;
35 }
36
37 if (_context.Request.QueryString ["firstLine"] == null || !int.TryParse (_context.Request.QueryString ["firstLine"], out int firstLine)) {
38 firstLine = count > 0 ? LogBuffer.Instance.OldestLine : LogBuffer.Instance.LatestLine;
39 }
40
41 PrepareEnvelopedResult (out JsonWriter writer);
42
43 writer.WriteRaw (jsonKeyEntries);
44
45 List<LogBuffer.LogEntry> logEntries = LogBuffer.Instance.GetRange (ref firstLine, count, out int lastLine);
46
47 writer.WriteBeginArray ();
48
49 for (int i = 0; i < logEntries.Count; i++) {
50 LogBuffer.LogEntry logEntry = logEntries [i];
51
52 if (i > 0) {
53 writer.WriteValueSeparator ();
54 }
55
56 writer.WriteRaw (jsonMsgKey);
57 writer.WriteString (logEntry.Message);
58
59 writer.WriteRaw (jsonTypeKey);
60 writer.WriteString (logEntry.Type.ToStringCached ());
61
62 writer.WriteRaw (jsonTraceKey);
63 writer.WriteString (logEntry.Trace);
64
65 writer.WriteRaw (jsonIsotimeKey);
66 writer.WriteString (logEntry.IsoTime);
67
68 writer.WriteRaw (jsonUptimeKey);
69 writer.WriteString (logEntry.Uptime.ToString ());
70
71 writer.WriteEndObject ();
72 }
73
74 writer.WriteEndArray ();
75
76 writer.WriteRaw (jsonKeyFirstLine);
77 writer.WriteInt32 (firstLine);
78
79 writer.WriteRaw (jsonKeyLastLine);
80 writer.WriteInt32 (lastLine);
81
82 writer.WriteEndObject ();
83
84 SendEnvelopedResult (_context, ref writer);
85 }
86 }
87}
Note: See TracBrowser for help on using the repository browser.