added jsonpb format support

This commit is contained in:
Shelikhoo 2021-06-19 15:00:22 +01:00
parent ba2dd5995d
commit 32374eb545
No known key found for this signature in database
GPG Key ID: C4D5E79D22B25316
2 changed files with 93 additions and 0 deletions

24
common/serial/resolver.go Normal file
View File

@ -0,0 +1,24 @@
package serial
import (
"github.com/golang/protobuf/proto"
)
type AnyResolver interface {
Resolve(typeURL string) (proto.Message, error)
}
type serialResolver struct {
}
func (s serialResolver) Resolve(typeURL string) (proto.Message, error) {
instance, err := GetInstance(typeURL)
if err != nil {
return nil, err
}
return instance.(proto.Message), nil
}
func GetResolver() AnyResolver {
return &serialResolver{}
}

View File

@ -0,0 +1,69 @@
package jsonpb
import (
"bytes"
"github.com/golang/protobuf/jsonpb"
"github.com/golang/protobuf/proto"
core "github.com/v2fly/v2ray-core/v4"
"github.com/v2fly/v2ray-core/v4/common"
"github.com/v2fly/v2ray-core/v4/common/buf"
"github.com/v2fly/v2ray-core/v4/common/cmdarg"
"github.com/v2fly/v2ray-core/v4/common/serial"
"io"
)
//go:generate go run github.com/v2fly/v2ray-core/v4/common/errors/errorgen
func loadJsonPb(data io.Reader) (*core.Config, error) {
coreconf := &core.Config{}
jsonpbloader := &jsonpb.Unmarshaler{AnyResolver: serial.GetResolver()}
err := jsonpbloader.Unmarshal(data, coreconf)
if err != nil {
return nil, err
}
return coreconf, nil
}
func dumpJsonPb(config proto.Message, w io.Writer) error {
jsonpbdumper := &jsonpb.Marshaler{AnyResolver: serial.GetResolver()}
err := jsonpbdumper.Marshal(w, config)
if err != nil {
return err
}
return nil
}
func DumpJsonPb(config proto.Message, w io.Writer) error {
return dumpJsonPb(config, w)
}
const FormatProtobufJSON = "jsonpb"
func init() {
common.Must(core.RegisterConfigLoader(&core.ConfigFormat{
Name: []string{FormatProtobufJSON},
Extension: []string{".pb.json", ".pbjson"},
Loader: func(input interface{}) (*core.Config, error) {
switch v := input.(type) {
case string:
r, err := cmdarg.LoadArg(v)
if err != nil {
return nil, err
}
data, err := buf.ReadAllToBytes(r)
if err != nil {
return nil, err
}
return loadJsonPb(bytes.NewReader(data))
case io.Reader:
data, err := buf.ReadAllToBytes(v)
if err != nil {
return nil, err
}
return loadJsonPb(bytes.NewReader(data))
default:
return nil, newError("unknow type")
}
},
}))
}