json

package
v0.16.3-0...-7d6e63f Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 3, 2016 License: Apache-2.0 Imports: 9 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var DefaultMetaFactory = SimpleMetaFactory{}

DefaultMetaFactory is a default factory for versioning objects in JSON. The object in memory and in the default JSON serialization will use the "kind" and "apiVersion" fields.

View Source
var Framer = jsonFramer{}

Framer is the default JSON framing behavior, with newlines delimiting individual objects.

View Source
var YAMLFramer = yamlFramer{}

Framer is the default JSON framing behavior, with newlines delimiting individual objects.

Functions

This section is empty.

Types

type MetaFactory

type MetaFactory interface {
	// Interpret should return the version and kind of the wire-format of
	// the object.
	Interpret(data []byte) (*unversioned.GroupVersionKind, error)
}

MetaFactory is used to store and retrieve the version and kind information for JSON objects in a serializer.

type Serializer

type Serializer struct {
	// contains filtered or unexported fields
}

func NewSerializer

func NewSerializer(meta MetaFactory, creater runtime.ObjectCreater, typer runtime.Typer, pretty bool) *Serializer

NewSerializer creates a JSON serializer that handles encoding versioned objects into the proper JSON form. If typer is not nil, the object has the group, version, and kind fields set.

func NewYAMLSerializer

func NewYAMLSerializer(meta MetaFactory, creater runtime.ObjectCreater, typer runtime.Typer) *Serializer

NewYAMLSerializer creates a YAML serializer that handles encoding versioned objects into the proper YAML form. If typer is not nil, the object has the group, version, and kind fields set. This serializer supports only the subset of YAML that matches JSON, and will error if constructs are used that do not serialize to JSON.

func (*Serializer) Decode

Decode attempts to convert the provided data into YAML or JSON, extract the stored schema kind, apply the provided default gvk, and then load that data into an object matching the desired schema kind or the provided into. If into is *runtime.Unknown, the raw data will be extracted and no decoding will be performed. If into is not registered with the typer, then the object will be straight decoded using normal JSON/YAML unmarshalling. If into is provided and the original data is not fully qualified with kind/version/group, the type of the into will be used to alter the returned gvk. On success or most errors, the method will return the calculated schema kind.

func (*Serializer) EncodeToStream

func (s *Serializer) EncodeToStream(obj runtime.Object, w io.Writer, overrides ...unversioned.GroupVersion) error

EncodeToStream serializes the provided object to the given writer. Overrides is ignored.

func (*Serializer) EncodesAsText

func (s *Serializer) EncodesAsText() bool

EncodesAsText returns true because both JSON and YAML are considered textual representations of data. This is used to determine whether the serialized object should be transmitted over a WebSocket Text or Binary frame. This must remain true for legacy compatibility with v1.1 watch over websocket implementations.

func (*Serializer) RecognizesData

func (s *Serializer) RecognizesData(peek io.Reader) (bool, error)

RecognizesData implements the RecognizingDecoder interface.

type SimpleMetaFactory

type SimpleMetaFactory struct {
}

SimpleMetaFactory provides default methods for retrieving the type and version of objects that are identified with an "apiVersion" and "kind" fields in their JSON serialization. It may be parameterized with the names of the fields in memory, or an optional list of base structs to search for those fields in memory.

func (SimpleMetaFactory) Interpret

Interpret will return the APIVersion and Kind of the JSON wire-format encoding of an object, or an error.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL