https://github.com/janstuemmel/cs2-log
Go package for parsing cs2 server logfiles
https://github.com/janstuemmel/cs2-log
counter-strike cs2 go golang
Last synced: 6 months ago
JSON representation
Go package for parsing cs2 server logfiles
- Host: GitHub
- URL: https://github.com/janstuemmel/cs2-log
- Owner: janstuemmel
- License: mit
- Created: 2023-06-12T17:08:01.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-11-24T18:33:31.000Z (about 2 years ago)
- Last Synced: 2025-04-11T02:59:57.595Z (9 months ago)
- Topics: counter-strike, cs2, go, golang
- Language: Go
- Homepage:
- Size: 67.4 KB
- Stars: 6
- Watchers: 2
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# cs2-log
Go package for parsing cs2 server logfiles. It exports types for cs2 logfiles, their regular expressions, a function for
parsing and a function for converting to non-html-escaped JSON.
## Usage
For more examples look at the [tests](./cs2log_test.go) and the command-line utility in [examples folder](./example).
Have also a look at [godoc](http://godoc.org/github.com/janstuemmel/cs2-log).
```go
package main
import (
"fmt"
"github.com/janstuemmel/cs2-log"
)
func main() {
var msg cs2log.Message
// a line from a server logfile
line := `L 11/05/2018 - 15:44:36: "Player<12><[U:1:29384012]>" purchased "m4a1"`
// parse into Message
msg, err := cs2log.Parse(line)
if err != nil {
panic(err)
}
fmt.Println(msg.GetType(), msg.GetTime().String())
// cast Message interface to PlayerPurchase type
playerPurchase, ok := msg.(cs2log.PlayerPurchase)
if ok != true {
panic("casting failed")
}
fmt.Println(playerPurchase.Player.SteamID, playerPurchase.Item)
// get json non-htmlescaped
jsn := cs2log.ToJSON(msg)
fmt.Println(jsn)
}
```
Example JSON output:
```json
{
"time": "2018-11-05T15:44:36Z",
"type": "PlayerPurchase",
"player": {
"name": "Player",
"id": 12,
"steam_id": "[U:1:29384012]",
"side": "CT"
},
"item": "m4a1"
}
```