|
@@ -1,7 +1,6 @@
|
|
|
package conf
|
|
package conf
|
|
|
|
|
|
|
|
import (
|
|
import (
|
|
|
- "bytes"
|
|
|
|
|
"encoding/json"
|
|
"encoding/json"
|
|
|
"github.com/golang/protobuf/jsonpb"
|
|
"github.com/golang/protobuf/jsonpb"
|
|
|
"github.com/jhump/protoreflect/desc"
|
|
"github.com/jhump/protoreflect/desc"
|
|
@@ -13,13 +12,13 @@ func (c *Config) BuildServices(service map[string]*json.RawMessage) ([]*serial.T
|
|
|
var ret []*serial.TypedMessage
|
|
var ret []*serial.TypedMessage
|
|
|
for k, v := range service {
|
|
for k, v := range service {
|
|
|
message, err := desc.LoadMessageDescriptor(k)
|
|
message, err := desc.LoadMessageDescriptor(k)
|
|
|
- if err != nil {
|
|
|
|
|
|
|
+ if err != nil || message == nil {
|
|
|
return nil, newError("Cannot find service", k, "").Base(err)
|
|
return nil, newError("Cannot find service", k, "").Base(err)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
serviceConfig := dynamic.NewMessage(message)
|
|
serviceConfig := dynamic.NewMessage(message)
|
|
|
|
|
|
|
|
- if err := jsonpb.Unmarshal(bytes.NewReader(*v), serviceConfig); err != nil {
|
|
|
|
|
|
|
+ if err := serviceConfig.UnmarshalJSONPB(&jsonpb.Unmarshaler{AllowUnknownFields: false}, *v); err != nil {
|
|
|
return nil, newError("Cannot interpret service configure file", k, "").Base(err)
|
|
return nil, newError("Cannot interpret service configure file", k, "").Base(err)
|
|
|
}
|
|
}
|
|
|
|
|
|