Signed-off-by: Vasiliy Tolstov <v.tolstov@unistack.org>
This commit is contained in:
2021-05-26 01:20:27 +03:00
parent c4a74bc93b
commit 6eaf4973cf
3 changed files with 33 additions and 523 deletions

59
yaml.go
View File

@@ -3,37 +3,46 @@ package yaml
import (
"io"
"io/ioutil"
"github.com/ghodss/yaml"
"github.com/unistack-org/micro/v3/codec"
rutil "github.com/unistack-org/micro/v3/util/reflect"
)
type yamlCodec struct{}
func (c *yamlCodec) Marshal(b interface{}) ([]byte, error) {
switch m := b.(type) {
const (
flattenTag = "flatten"
)
func (c *yamlCodec) Marshal(v interface{}) ([]byte, error) {
switch m := v.(type) {
case nil:
return nil, nil
case *codec.Frame:
return m.Data, nil
}
return yaml.Marshal(b)
if nv, nerr := rutil.StructFieldByTag(v, codec.DefaultTagName, flattenTag); nerr == nil {
v = nv
}
return yaml.Marshal(v)
}
func (c *yamlCodec) Unmarshal(b []byte, v interface{}) error {
if len(b) == 0 {
if len(b) == 0 || v == nil {
return nil
}
switch m := v.(type) {
case nil:
return nil
case *codec.Frame:
if m, ok := v.(*codec.Frame); ok {
m.Data = b
return nil
}
if nv, nerr := rutil.StructFieldByTag(v, codec.DefaultTagName, flattenTag); nerr == nil {
v = nv
}
return yaml.Unmarshal(b, v)
}
@@ -41,48 +50,34 @@ func (c *yamlCodec) ReadHeader(conn io.Reader, m *codec.Message, t codec.Message
return nil
}
func (c *yamlCodec) ReadBody(conn io.Reader, b interface{}) error {
switch m := b.(type) {
case nil:
return nil
case *codec.Frame:
buf, err := ioutil.ReadAll(conn)
if err != nil {
return err
} else if len(buf) == 0 {
return nil
}
m.Data = buf
func (c *yamlCodec) ReadBody(conn io.Reader, v interface{}) error {
if v == nil {
return nil
}
buf, err := ioutil.ReadAll(conn)
buf, err := io.ReadAll(conn)
if err != nil {
return err
} else if len(buf) == 0 {
// not needed but similar changes in all codecs
return nil
}
return yaml.Unmarshal(buf, b)
return c.Unmarshal(buf, v)
}
func (c *yamlCodec) Write(conn io.Writer, m *codec.Message, b interface{}) error {
switch m := b.(type) {
case nil:
func (c *yamlCodec) Write(conn io.Writer, m *codec.Message, v interface{}) error {
if v == nil {
return nil
case *codec.Frame:
_, err := conn.Write(m.Data)
return err
}
buf, err := yaml.Marshal(b)
buf, err := c.Marshal(v)
if err != nil {
return err
} else if len(buf) == 0 {
return codec.ErrInvalidMessage
}
_, err = conn.Write(buf)
return err
}