Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[PROPOSAL] Refactor query parameter definitions for maintainability #783

Open
kolchfa-aws opened this issue Jan 10, 2025 · 0 comments
Open

Comments

@kolchfa-aws
Copy link
Contributor

What/Why

  1. There are many query parameters that are shared by several APIs. For these parameters, I think it's best to keep the description of the parameter in the common shared schema. For example, expand_wildcards is shared by several APIs, including several CAT APIs. Some of the CAT APIs define their own descriptions for this parameter, while the description should be part of the common schema.
  2. For parameters that take enums (for example, the same expand_wildcards), the description should not contain the valid parameter values. Rather, these can be generated from the schema.

For reference, here's the common schema for expand_wildcards:

ExpandWildcards:
      oneOf: 
        - $ref: '#/components/schemas/ExpandWildcard'
        - type: array
          items:
            $ref: '#/components/schemas/ExpandWildcard'
    ExpandWildcard:
      oneOf:
        - type: string
          const: all
          description: Match any index, including hidden ones.
        - type: string
          const: closed
          ...

This proposal is to make it as follows:

ExpandWildcards:
      description: Specifies the type of index that wildcard expressions can match. Supports comma-separated values. 
      oneOf: 
        - $ref: '#/components/schemas/ExpandWildcard'
        - type: array
          items:
            $ref: '#/components/schemas/ExpandWildcard'
    ExpandWildcard:
      oneOf:
        - type: string
          const: all
          description: Match any index, including hidden ones.
        - type: string
          const: closed
          ...

And remove descriptions from individual APIs like CAT indices:

cat.indices::query.expand_wildcards:
      in: query
      name: expand_wildcards
      description: The type of index that wildcard patterns can match.  Supported values are `all`, `open`, `closed`, `hidden`, and `none`.
      schema:
        $ref: '../schemas/_common.yaml#/components/schemas/ExpandWildcards'
      style: form

What problems are you trying to solve?

Improve maintainability of the spec

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant