Documentation ¶
Overview ¶
Package schema provides definitions for the JSON schema of the different manifests in the App Container Specification. The manifests are canonically represented in their respective structs:
- `ImageManifest`
- `PodManifest`
Validation is performed through serialization: if a blob of JSON data will unmarshal to one of the *Manifests, it is considered a valid implementation of the standard. Similarly, if a constructed *Manifest struct marshals successfully to JSON, it must be valid.
Index ¶
Constants ¶
const ( ACIExtension = ".aci" ImageManifestKind = types.ACKind("ImageManifest") )
const PodManifestKind = types.ACKind("PodManifest")
Variables ¶
var ( // AppContainerVersion is the SemVer representation of version AppContainerVersion types.SemVer )
Functions ¶
This section is empty.
Types ¶
type AppList ¶
type AppList []RuntimeApp
func (AppList) Get ¶
func (al AppList) Get(name types.ACName) *RuntimeApp
Get retrieves an app by the specified name from the AppList; if there is no such app, nil is returned. The returned *RuntimeApp MUST be considered read-only.
func (AppList) MarshalJSON ¶
func (*AppList) UnmarshalJSON ¶
type ImageManifest ¶
type ImageManifest struct { ACKind types.ACKind `json:"acKind"` ACVersion types.SemVer `json:"acVersion"` Name types.ACName `json:"name"` Labels types.Labels `json:"labels,omitempty"` App *types.App `json:"app,omitempty"` Annotations types.Annotations `json:"annotations,omitempty"` Dependencies types.Dependencies `json:"dependencies,omitempty"` PathWhitelist []string `json:"pathWhitelist,omitempty"` }
func BlankImageManifest ¶
func BlankImageManifest() *ImageManifest
func (*ImageManifest) GetAnnotation ¶
func (im *ImageManifest) GetAnnotation(name string) (val string, ok bool)
func (*ImageManifest) GetLabel ¶
func (im *ImageManifest) GetLabel(name string) (val string, ok bool)
func (ImageManifest) MarshalJSON ¶
func (im ImageManifest) MarshalJSON() ([]byte, error)
func (*ImageManifest) UnmarshalJSON ¶
func (im *ImageManifest) UnmarshalJSON(data []byte) error
type Mount ¶
type Mount struct { Volume types.ACName `json:"volume"` MountPoint types.ACName `json:"mountPoint"` }
Mount describes the mapping between a volume and an apps MountPoint that will be fulfilled at runtime.
type PodManifest ¶
type PodManifest struct { ACVersion types.SemVer `json:"acVersion"` ACKind types.ACKind `json:"acKind"` Apps AppList `json:"apps"` Volumes []types.Volume `json:"volumes"` Isolators []types.Isolator `json:"isolators"` Annotations types.Annotations `json:"annotations"` Ports []types.ExposedPort `json:"ports"` }
func BlankPodManifest ¶
func BlankPodManifest() *PodManifest
func (PodManifest) MarshalJSON ¶
func (pm PodManifest) MarshalJSON() ([]byte, error)
func (*PodManifest) UnmarshalJSON ¶
func (pm *PodManifest) UnmarshalJSON(data []byte) error
type RuntimeApp ¶
type RuntimeApp struct { Name types.ACName `json:"name"` Image RuntimeImage `json:"image"` App *types.App `json:"app,omitempty"` Mounts []Mount `json:"mounts,omitempty"` Annotations types.Annotations `json:"annotations,omitempty"` }
RuntimeApp describes an application referenced in a PodManifest