Skip to content

Commit

Permalink
feature: add explicit +required
Browse files Browse the repository at this point in the history
  • Loading branch information
alexzielenski committed Feb 13, 2024
1 parent 7a0d5b4 commit 24efcdb
Showing 1 changed file with 13 additions and 1 deletion.
14 changes: 13 additions & 1 deletion pkg/generators/openapi.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ import (
const tagName = "k8s:openapi-gen"
const markerPrefix = "+k8s:validation:"
const tagOptional = "optional"
const tagRequired = "required"
const tagDefault = "default"

// Known values for the tag.
Expand Down Expand Up @@ -80,6 +81,11 @@ func hasOpenAPITagValue(comments []string, value string) bool {
return false
}

func hasRequiredTag(m *types.Member) bool {
return types.ExtractCommentTags(
"+", m.CommentLines)[tagRequired] != nil
}

// hasOptionalTag returns true if the member has +optional in its comments or
// omitempty in its json tags.
func hasOptionalTag(m *types.Member) bool {
Expand Down Expand Up @@ -317,7 +323,13 @@ func (g openAPITypeWriter) generateMembers(t *types.Type, required []string) ([]
if name == "" {
continue
}
if !hasOptionalTag(&m) {
if isOptional, isRequired := hasOptionalTag(&m), hasRequiredTag(&m); isOptional && isRequired {
klog.Errorf("Error when generating: %v, %v\n", name, m)

//TODO: Thought of using +optional=false as alternative syntax for
// this instead but thats kinda weird, no?
return required, fmt.Errorf("member %s of type %s cannot be both optional and required", m.Name, t.Name)
} else if !isOptional || isRequired {
required = append(required, name)
}
if err = g.generateProperty(&m, t); err != nil {
Expand Down

0 comments on commit 24efcdb

Please sign in to comment.