Skip to content

mattbaird/jsonpatch

Folders and files

NameName
Last commit message
Last commit date
May 17, 2019
Apr 17, 2015
Mar 19, 2019
Sep 3, 2023
May 17, 2019
Apr 23, 2021
Oct 12, 2015
Jun 27, 2017
Oct 12, 2015
Dec 2, 2016
Jul 27, 2017
Oct 12, 2015

Repository files navigation

jsonpatch

As per http://jsonpatch.com/ JSON Patch is specified in RFC 6902 from the IETF.

JSON Patch allows you to generate JSON that describes changes you want to make to a document, so you don't have to send the whole doc. JSON Patch format is supported by HTTP PATCH method, allowing for standards based partial updates via REST APIs.

go get github.com/mattbaird/jsonpatch

I tried some of the other "jsonpatch" go implementations, but none of them could diff two json documents and generate format like jsonpatch.com specifies. Here's an example of the patch format:

[
  { "op": "replace", "path": "/baz", "value": "boo" },
  { "op": "add", "path": "/hello", "value": ["world"] },
  { "op": "remove", "path": "/foo"}
]

The API is super simple #example

package main

import (
	"fmt"
	"github.com/mattbaird/jsonpatch"
)

var simpleA = `{"a":100, "b":200, "c":"hello"}`
var simpleB = `{"a":100, "b":200, "c":"goodbye"}`

func main() {
	patch, e := jsonpatch.CreatePatch([]byte(simpleA), []byte(simpleB))
	if e != nil {
		fmt.Printf("Error creating JSON patch:%v", e)
		return
	}
	for _, operation := range patch {
		fmt.Printf("%s\n", operation.Json())
	}
}

This code needs more tests, as it's a highly recursive, type-fiddly monster. It's not a lot of code, but it has to deal with a lot of complexity.

About

As per http://jsonpatch.com/ JSON Patch is specified in RFC 6902 from the IETF.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages