rules: info-title-required: description: API title must be present. severity: error given: $.info then: field: title function: truthy info-title-format: description: Title should start with "LinkedIn". severity: warn given: $.info.title then: function: pattern functionOptions: match: "^LinkedIn " info-description-required: description: API description must be present. severity: error given: $.info then: field: description function: truthy info-version-required: description: API version must be specified. severity: error given: $.info then: field: version function: truthy openapi-version-3: description: OpenAPI version must be 3.0.x. severity: error given: $ then: field: openapi function: pattern functionOptions: match: "^3\\.0\\." servers-defined: description: At least one server must be defined. severity: error given: $ then: field: servers function: truthy servers-https-only: description: Server URLs must use HTTPS. severity: error given: $.servers[*].url then: function: pattern functionOptions: match: "^https://" paths-no-trailing-slash: description: Paths must not have trailing slashes. severity: error given: $.paths then: field: "@key" function: pattern functionOptions: notMatch: "\\/$" paths-camelcase: description: Path segments should use camelCase. severity: info given: $.paths then: field: "@key" function: pattern functionOptions: notMatch: "\\/[a-z]+_[a-z]" operation-description-required: description: Every operation must have a description. severity: error given: $.paths[*][get,post,put,patch,delete] then: field: description function: truthy operation-operationid-required: description: Every operation must have an operationId. severity: error given: $.paths[*][get,post,put,patch,delete] then: field: operationId function: truthy operation-operationid-unique: description: Operation IDs must be unique. severity: error given: $ then: function: oasOpId operation-tags-required: description: Every operation must have at least one tag. severity: warn given: $.paths[*][get,post,put,patch,delete] then: field: tags function: truthy tags-title-case: description: Tag names should use Title Case. severity: info given: $.tags[*].name then: function: pattern functionOptions: match: "^[A-Z][a-zA-Z0-9]*(\\s[A-Za-z0-9]+)*$" parameter-description-required: description: All parameters must have a description. severity: error given: $.paths[*][get,post,put,patch,delete].parameters[*] then: field: description function: truthy parameter-camelcase: description: Parameter names should use camelCase. severity: warn given: $.paths[*][get,post,put,patch,delete].parameters[*] then: field: name function: pattern functionOptions: match: "^[a-z][a-zA-Z0-9.]*$" request-body-json: description: Request bodies should use application/json. severity: warn given: $.paths[*][post,put,patch].requestBody.content then: field: application/json function: truthy response-success-required: description: Every operation must define a success response. severity: error given: $.paths[*][get,post,put,patch,delete].responses then: function: schema functionOptions: schema: anyOf: - required: ["200"] - required: ["201"] - required: ["204"] response-description-required: description: All responses must have a description. severity: error given: $.paths[*][get,post,put,patch,delete].responses[*] then: field: description function: truthy schema-names-pascalcase: description: Schema names should use PascalCase. severity: warn given: $.components.schemas then: field: "@key" function: pattern functionOptions: match: "^[A-Z][a-zA-Z0-9]*$" schema-properties-camelcase: description: Schema properties should use camelCase. severity: info given: $.components.schemas[*].properties then: field: "@key" function: pattern functionOptions: match: "^[a-z][a-zA-Z0-9]*$" security-schemes-defined: description: Security schemes should be defined. severity: warn given: $.components then: field: securitySchemes function: truthy get-no-request-body: description: GET operations must not have a request body. severity: error given: $.paths[*].get then: field: requestBody function: falsy no-empty-descriptions: description: Descriptions must not be empty. severity: error given: "$..description" then: function: truthy