Salesforce Knowledge Management · API Governance Rules

Salesforce Knowledge Management API Rules

Spectral linting rules defining API design standards and conventions for Salesforce Knowledge Management.

9 Rules error 5 warn 4
View Rules File View on GitHub

Rule Categories

salesforce

Rules

warn
salesforce-km-operation-summary-title-case
Operation summaries must use Title Case
$.paths[*][*].summary
warn
salesforce-km-operation-id-camel-case
OperationIds must use camelCase
$.paths[*][*].operationId
warn
salesforce-km-tags-title-case
All tags must use Title Case
$.paths[*][*].tags[*]
error
salesforce-km-response-200-description
All 200 responses must have a description
$.paths[*][*].responses['200']
error
salesforce-km-contact-required
API info must include contact details
$.info
error
salesforce-km-version-required
API info must include a version
$.info
error
salesforce-km-servers-required
API must define at least one server
$
error
salesforce-km-security-defined
API must define security requirements
$
warn
salesforce-km-article-status-enum
Knowledge article PublishStatus should use defined enum values
$.components.schemas.KnowledgeArticleSummary.properties.PublishStatus

Spectral Ruleset

Raw ↑
rules:
  salesforce-km-operation-summary-title-case:
    description: Operation summaries must use Title Case
    message: "Summary '{{value}}' must use Title Case"
    severity: warn
    given: "$.paths[*][*].summary"
    then:
      function: pattern
      functionOptions:
        match: "^[A-Z]"

  salesforce-km-operation-id-camel-case:
    description: OperationIds must use camelCase
    message: "OperationId '{{value}}' must use camelCase"
    severity: warn
    given: "$.paths[*][*].operationId"
    then:
      function: pattern
      functionOptions:
        match: "^[a-z][a-zA-Z0-9]*$"

  salesforce-km-tags-title-case:
    description: All tags must use Title Case
    message: "Tag '{{value}}' must use Title Case"
    severity: warn
    given: "$.paths[*][*].tags[*]"
    then:
      function: pattern
      functionOptions:
        match: "^[A-Z]"

  salesforce-km-response-200-description:
    description: All 200 responses must have a description
    severity: error
    given: "$.paths[*][*].responses['200']"
    then:
      field: description
      function: truthy

  salesforce-km-contact-required:
    description: API info must include contact details
    severity: error
    given: "$.info"
    then:
      field: contact
      function: truthy

  salesforce-km-version-required:
    description: API info must include a version
    severity: error
    given: "$.info"
    then:
      field: version
      function: truthy

  salesforce-km-servers-required:
    description: API must define at least one server
    severity: error
    given: "$"
    then:
      field: servers
      function: truthy

  salesforce-km-security-defined:
    description: API must define security requirements
    severity: error
    given: "$"
    then:
      field: security
      function: truthy

  salesforce-km-article-status-enum:
    description: Knowledge article PublishStatus should use defined enum values
    message: "Article PublishStatus should be one of: Online, Draft, Archived"
    severity: warn
    given: "$.components.schemas.KnowledgeArticleSummary.properties.PublishStatus"
    then:
      field: enum
      function: truthy