apply all the patches
This commit is contained in:
parent
7347357aab
commit
0f32f74431
44
main.go
44
main.go
|
@ -2,7 +2,6 @@ package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
|
@ -50,26 +49,29 @@ func getGamePk() string {
|
||||||
return gamePk
|
return gamePk
|
||||||
}
|
}
|
||||||
|
|
||||||
func extractPatch(diffPatch []byte) (jsonpatch.Patch, error) {
|
func extractPatches(diffPatch []byte) ([]jsonpatch.Patch, error) {
|
||||||
var p jsonpatch.Patch
|
var patches []jsonpatch.Patch
|
||||||
var d []any
|
var objs []any
|
||||||
err := json.Unmarshal(diffPatch, &d)
|
err := json.Unmarshal(diffPatch, &objs)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return p, err
|
return patches, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(d) == 0 {
|
for _, obj := range objs {
|
||||||
return p, errors.New("empty diffPatch")
|
diff := obj.(map[string]any)["Diff"]
|
||||||
|
patch, err := json.Marshal(diff)
|
||||||
|
if err != nil {
|
||||||
|
return patches, err
|
||||||
|
}
|
||||||
|
|
||||||
|
p, err := jsonpatch.DecodePatch(patch)
|
||||||
|
if err != nil {
|
||||||
|
return patches, err
|
||||||
|
}
|
||||||
|
patches = append(patches, p)
|
||||||
}
|
}
|
||||||
|
|
||||||
diff := d[0].(map[string]any)["Diff"]
|
return patches, nil
|
||||||
patch, err := json.Marshal(diff)
|
|
||||||
if err != nil {
|
|
||||||
return p, err
|
|
||||||
}
|
|
||||||
|
|
||||||
p, err = jsonpatch.DecodePatch(patch)
|
|
||||||
return p, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
@ -108,16 +110,18 @@ func main() {
|
||||||
}
|
}
|
||||||
|
|
||||||
diffPatchResp, err := statsapi.RequestDiffPatch(gamePk, ts, p.UpdateId)
|
diffPatchResp, err := statsapi.RequestDiffPatch(gamePk, ts, p.UpdateId)
|
||||||
patch, err := extractPatch(diffPatchResp)
|
patches, err := extractPatches(diffPatchResp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
feedResp, err = statsapi.RequestFeed(gamePk)
|
feedResp, err = statsapi.RequestFeed(gamePk)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
feedResp, err = patch.Apply(feedResp)
|
for _, patch := range patches {
|
||||||
if err != nil {
|
feedResp, err = patch.Apply(feedResp)
|
||||||
log.Fatal(err)
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue