OpenAPI:定义具有一个必填字段和互斥可选字段的 JSON 模式

问题描述 投票:0回答:2

我正在为具有特定负载结构的端点创建 OpenAPI 描述:

  • 其中一个字段为必填项
  • 两个附加字段是可选的
  • 一次只能出现一个可选字段(互斥)

这是我尝试过的:

openapi: 3.0.4
info:
  title: My API
  version: 1.0.0
paths:
  /my-endpoint:
    post:
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              required: 
                - mandatoryField
              properties:
                mandatoryField:
                  type: string
                optionalFieldOne:
                  type: string
                optionalFieldTwo:
                  type: string


I am stuck here.
yaml openapi jsonschema
2个回答
0
投票

最简单的方法是使用

maxProperties: 2
并通过
additionalProperties: false
禁止额外的属性。这确保最多只能提供一个可选属性。

type: object
required: 
  - mandatoryField
properties:
  mandatoryField:
    type: string
  optionalFieldOne:
    type: string
  optionalFieldTwo:
    type: string
maxProperties: 2
additionalProperties: false

定义互斥属性的另一种方法是使用

not
+
required
禁止同时存在这些属性(但在我看来,具有
not
的模式可读性较差)。

type: object
required:
  - mandatoryField
properties:
  mandatoryField:
    type: string
  optionalFieldOne:
    type: string
  optionalFieldTwo:
    type: string

# This means: if both optionalFieldOne and optionalFieldTwo are present
# then the schema is not valid
not:
  required:
    - optionalFieldOne
    - optionalFieldTwo

0
投票

还有

required
oneOf

的第三种变体
type: object
required:
  - mandatoryField
properties:
  mandatoryField:
    type: string
  optionalFieldOne:
    type: string
  optionalFieldTwo:
    type: string
oneOf:
- required:
  - optionalFieldOne
- required:
  - optionalFieldTwo
© www.soinside.com 2019 - 2024. All rights reserved.