mirror of
https://github.com/protocolbuffers/protobuf-go.git
synced 2025-01-01 11:58:21 +00:00
c51e2e0293
In 2014, when proto3 was being developed, there were a number of early adopters of the new syntax. Before the finalization of proto3 when it was released in open-source in July 2016, a decision was made to strictly validate strings in proto3. However, some of the early adopters were already using invalid UTF-8 with string fields. The google.protobuf.FieldOptions.enforce_utf8 option only exists to support those grandfathered users where they can opt-out of the validation logic. Practical use of that option in open source is impossible even if a user specifies the proto1_legacy build tag since it requires a hacked variant of descriptor.proto that is not externally available. This CL supports enforce_utf8 by modifiyng internal/filedesc to expose the flag if it detects it in the raw descriptor. We add an strs.EnforceUTF8 function as a centralized place to determine whether to perform validation. Validation opt-out is supported only in builds with legacy support. We implement support for validating UTF-8 in all proto3 string fields, even if they are backed by a Go []byte. Change-Id: I9c0628b84909bc7181125f09db730c80d490e485 Reviewed-on: https://go-review.googlesource.com/c/protobuf/+/186002 Reviewed-by: Damien Neil <dneil@google.com>
98 lines
3.3 KiB
Go
98 lines
3.3 KiB
Go
// Copyright 2018 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style.
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// Code generated by generate-types. DO NOT EDIT.
|
|
|
|
package proto
|
|
|
|
import (
|
|
"math"
|
|
"unicode/utf8"
|
|
|
|
"google.golang.org/protobuf/internal/encoding/wire"
|
|
"google.golang.org/protobuf/internal/errors"
|
|
"google.golang.org/protobuf/internal/strs"
|
|
"google.golang.org/protobuf/reflect/protoreflect"
|
|
)
|
|
|
|
var wireTypes = map[protoreflect.Kind]wire.Type{
|
|
protoreflect.BoolKind: wire.VarintType,
|
|
protoreflect.EnumKind: wire.VarintType,
|
|
protoreflect.Int32Kind: wire.VarintType,
|
|
protoreflect.Sint32Kind: wire.VarintType,
|
|
protoreflect.Uint32Kind: wire.VarintType,
|
|
protoreflect.Int64Kind: wire.VarintType,
|
|
protoreflect.Sint64Kind: wire.VarintType,
|
|
protoreflect.Uint64Kind: wire.VarintType,
|
|
protoreflect.Sfixed32Kind: wire.Fixed32Type,
|
|
protoreflect.Fixed32Kind: wire.Fixed32Type,
|
|
protoreflect.FloatKind: wire.Fixed32Type,
|
|
protoreflect.Sfixed64Kind: wire.Fixed64Type,
|
|
protoreflect.Fixed64Kind: wire.Fixed64Type,
|
|
protoreflect.DoubleKind: wire.Fixed64Type,
|
|
protoreflect.StringKind: wire.BytesType,
|
|
protoreflect.BytesKind: wire.BytesType,
|
|
protoreflect.MessageKind: wire.BytesType,
|
|
protoreflect.GroupKind: wire.StartGroupType,
|
|
}
|
|
|
|
func (o MarshalOptions) marshalSingular(b []byte, fd protoreflect.FieldDescriptor, v protoreflect.Value) ([]byte, error) {
|
|
switch fd.Kind() {
|
|
case protoreflect.BoolKind:
|
|
b = wire.AppendVarint(b, wire.EncodeBool(v.Bool()))
|
|
case protoreflect.EnumKind:
|
|
b = wire.AppendVarint(b, uint64(v.Enum()))
|
|
case protoreflect.Int32Kind:
|
|
b = wire.AppendVarint(b, uint64(int32(v.Int())))
|
|
case protoreflect.Sint32Kind:
|
|
b = wire.AppendVarint(b, wire.EncodeZigZag(int64(int32(v.Int()))))
|
|
case protoreflect.Uint32Kind:
|
|
b = wire.AppendVarint(b, uint64(uint32(v.Uint())))
|
|
case protoreflect.Int64Kind:
|
|
b = wire.AppendVarint(b, uint64(v.Int()))
|
|
case protoreflect.Sint64Kind:
|
|
b = wire.AppendVarint(b, wire.EncodeZigZag(v.Int()))
|
|
case protoreflect.Uint64Kind:
|
|
b = wire.AppendVarint(b, v.Uint())
|
|
case protoreflect.Sfixed32Kind:
|
|
b = wire.AppendFixed32(b, uint32(v.Int()))
|
|
case protoreflect.Fixed32Kind:
|
|
b = wire.AppendFixed32(b, uint32(v.Uint()))
|
|
case protoreflect.FloatKind:
|
|
b = wire.AppendFixed32(b, math.Float32bits(float32(v.Float())))
|
|
case protoreflect.Sfixed64Kind:
|
|
b = wire.AppendFixed64(b, uint64(v.Int()))
|
|
case protoreflect.Fixed64Kind:
|
|
b = wire.AppendFixed64(b, v.Uint())
|
|
case protoreflect.DoubleKind:
|
|
b = wire.AppendFixed64(b, math.Float64bits(v.Float()))
|
|
case protoreflect.StringKind:
|
|
if strs.EnforceUTF8(fd) && !utf8.ValidString(v.String()) {
|
|
return b, errors.InvalidUTF8(string(fd.FullName()))
|
|
}
|
|
b = wire.AppendString(b, v.String())
|
|
case protoreflect.BytesKind:
|
|
b = wire.AppendBytes(b, v.Bytes())
|
|
case protoreflect.MessageKind:
|
|
var pos int
|
|
var err error
|
|
b, pos = appendSpeculativeLength(b)
|
|
b, err = o.marshalMessage(b, v.Message())
|
|
if err != nil {
|
|
return b, err
|
|
}
|
|
b = finishSpeculativeLength(b, pos)
|
|
case protoreflect.GroupKind:
|
|
var err error
|
|
b, err = o.marshalMessage(b, v.Message())
|
|
if err != nil {
|
|
return b, err
|
|
}
|
|
b = wire.AppendVarint(b, wire.EncodeTag(fd.Number(), wire.EndGroupType))
|
|
default:
|
|
return b, errors.New("invalid kind %v", fd.Kind())
|
|
}
|
|
return b, nil
|
|
}
|