Skip to content

Go library for JSONAPI serialization and deserialization

License

Notifications You must be signed in to change notification settings

dcoxall/jsonapi

Repository files navigation

JSON:API

Build Status

A Go JSON:API serialization and deserialization library.

Overview

This JSON API library was built to support circular references when serializing and deserializing Go structures. Due to the dual phase approach to avoid stack overflow errors then it is unlikely to be the most performant.

Usage

import (
    "bytes"
    "fmt"
    "github.com/dcoxall/jsonapi"
)

type Author struct {
    ID        string `jsonapi:"primary,author"`
    FirstName string `jsonapi:"attr,first_name"`
    LastName  string `jsonapi:"attr,last_name"`
}

type Book struct {
    ID     string  `jsonapi:"primary,book"`
    Name   string  `jsonapi:"attr,name"`
    Author *Author `jsonapi:"relation,author"`
}

func ExampleEncode() {
    book := &Book{
        ID:     "book-123",
        Name:   "JSON Book",
        Author: &Author{
            ID:        "author-123",
            FirstName: "Jane",
            LastName:  "Doe",
        },
    }
    buffer := new(bytes.Buffer)
    encoder := jsonapi.NewEncoder(buffer)
    if err := encoder.Encode(book); err != nil {
        fmt.Println(err.Error())
        return
    }
    fmt.Println(buffer.String())
}

The above would produce...

{
  "data": {
    "id": "book-123",
    "type": "book",
    "attributes": {
      "name": "JSON Book"
    },
    "relationships": {
      "author": {
        "data": {
          "id": "author-123",
          "type": "author"
        }
      }
    }
  },
  "included": [
    {
      "id": "author-123",
      "type": "author",
      "attributes": {
        "first_name": "Jane",
        "last_name": "Doe"
      }
    }
  ]
}

About

Go library for JSONAPI serialization and deserialization

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published