airshipctl/manifests/function/airshipctl-schemas/airshipit.org_manifestmetadata.yaml
Matthew Fuller 52c5aedc63 Generate additional CRDs from API types
'make manifests' attempts to generate all airshipctl API types,
but several types throw errors and the resulting CRDs can't be
properly generated. This change:

- updates the controller-gen version to pull in a bug fix for the
  error 'map values must be a named type, not *ast.StarExpr'
- modifies the Templater type's Values member to be of type JSON
  since controller-gen does not support map[string]interface{},
  and unmarshals it separately in the templater itself
- adds 'image_repositories' to the VersionsCatalogueSpec struct
  to ensure it doesn't get deleted from the schema when manifests
  get regenerated
- checks in generated copies of all CRDs from airshipctl's API
  types, not just catalogues, to be used for validation

Closes: #574
Change-Id: I89a12cfd307a08da9aaec9773eac01169ea43ace
2021-06-25 19:10:25 +00:00

67 lines
2.2 KiB
YAML

---
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.6.1
creationTimestamp: null
name: manifestmetadata.airshipit.org
spec:
group: airshipit.org
names:
kind: ManifestMetadata
listKind: ManifestMetadataList
plural: manifestmetadata
singular: manifestmetadata
scope: Namespaced
versions:
- name: v1alpha1
schema:
openAPIV3Schema:
description: ManifestMetadata defines site specific metadata like inventory
and phase path
properties:
apiVersion:
description: 'APIVersion defines the versioned schema of this representation
of an object. Servers should convert recognized schemas to the latest
internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
type: string
inventory:
description: InventorySpec contains the path to the host inventory
properties:
path:
type: string
required:
- path
type: object
kind:
description: 'Kind is a string value representing the REST resource this
object represents. Servers may infer this from the endpoint the client
submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
type: string
metadata:
type: object
phase:
description: PhaseSpec represents configuration for a particular phase.
It contains a reference to the site specific manifest path and doument
entry prefix
properties:
documentEntryPointPrefix:
type: string
path:
type: string
required:
- documentEntryPointPrefix
- path
type: object
type: object
served: true
storage: true
status:
acceptedNames:
kind: ""
plural: ""
conditions: []
storedVersions: []