Skip to content

Latest commit

 

History

History
75 lines (57 loc) · 3.77 KB

sdk-code-annotations.md

File metadata and controls

75 lines (57 loc) · 3.77 KB

Code Annotations Proposal for Operator SDK

Implementation Owner: @estroz

Status: implemented

This proposal has been implemented. See the PR #1162.

Background

Code can be annotated with special comment lines that tell a code parser information about document code. Two prominent examples are go build tags and Kubernetes code generators. The Operator SDK generates code that, after modification by users, is parsed, transformed, and then represented in an alternate form; SDK-specific code annotations can be used to inform SDK-specific tasks, like generating Cluster Service Versions from API's.

Goals

  • Define an annotation system that encapsulates current parsing needs and is extensible for future needs.

Design Overview

Annotations should follow this EBNF:

comment token = ? the character(s) that define a line comment in some language, ex. // in go ? ;
global prefix token = "+operator-sdk" ;
global prefix = comment token , global prefix token ;
use case token = ":use-case" ;
use case prefix = global prefix , use case token , { use case token } ; (* a set of annotations for some use case *)
parent path token = "parent" ;
child path token = ".child" ;
full path = parent path token , { child path token } ;
prefixed path = use case prefix , ":" , full path ;
value = ['"'] , "text" , ['"'] ;
annotation = prefixed path , "=" , value ;

The "use case" token is meant to encapsulate the usage for an annotation, ex. :gen-csv is used for generating CSV's.

A path token should have use-case-specific structure. The following etcd-operator API code would be successfully parsed by operator-sdk olm-catalog gen-csv in the manner described below:

type EtcdCluster struct {
	metav1.TypeMeta   `json:",inline"`
	metav1.ObjectMeta `json:"metadata,omitempty"`
	Spec              ClusterSpec   `json:"spec"`
	Status            ClusterStatus `json:"status"`
}

type ClusterSpec struct {
	// Pod defines the policy to create pod for the etcd pod.
	//
	// Updating Pod does not take effect on any existing etcd pods.
	Pod *PodPolicy `json:"pod,omitempty"`
}

// PodPolicy defines the policy to create pod for the etcd container.
type PodPolicy struct {
	...
	// +operator-sdk:gen-csv:customresourcedefinitions.specDescriptors.displayName="Resource Requirements"
	Resources v1.ResourceRequirements `json:"resources,omitempty"`
	...
}

By defining a set of paths with a :gen-csv use case token, an annotation parser "knows" that the EtcdCluster spec ClusterSpec has a struct field of type PodPolicy that should be included in the CSV manifest spec.customresourcedefinitions field as a specDescriptor entry with a displayName value of Resource Requirements.

For an annotation set to be user-friendly, these elements must be kept as simple as possible for the given task. Their parser implementation must be accompanied by documentation that explains how to create annotations for all supported fields, how the parser will interpret those annotations, and any constraints or requirements on paths or values.