aboutsummaryrefslogtreecommitdiff
path: root/web/pw-server/src/lib/log_parser.ts
blob: 77c459fe8000e50c0b37c861ca145932fc996154 (plain)
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
50
51
52
53
54
55
export type PlayerLog = PlayerLogTurn[];

export type PlayerLogTurn = {
  action?: PlayerAction;
  stderr: string[];
};

type PlayerAction = BadCommand;

type BadCommand = {
  type: "bad_command";
  command: string;
  error: string;
};

function createEmptyLogTurn(): PlayerLogTurn {
  return {
    stderr: [],
  };
}

export function parsePlayerLog(playerId: number, logText: string): PlayerLog {
  const logLines = logText.split("\n").slice(0, -1);

  const playerLog: PlayerLog = [];

  let turn = null;

  logLines.forEach((logLine) => {
    const logMessage = JSON.parse(logLine);

    if (logMessage["type"] === "gamestate") {
      if (turn) {
        playerLog.push(turn);
        turn = createEmptyLogTurn();
      }
    } else if (logMessage["player_id"] === playerId) {
      if (!turn) {
        // older match logs don't have an initial game state due to a bug.
        turn = createEmptyLogTurn();
      }
      switch (logMessage["type"]) {
        case "stderr": {
          let msg = logMessage["message"];
          turn.stderr.push(msg);
        }
        case "bad_command": {
          turn.action = logMessage;
        }
      }
    }
  });

  return playerLog;
}