Class: Google::Apis::ServiceconsumermanagementV1::Documentation

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
generated/google/apis/serviceconsumermanagement_v1/classes.rb,
generated/google/apis/serviceconsumermanagement_v1/representations.rb,
generated/google/apis/serviceconsumermanagement_v1/representations.rb

Overview

Documentation provides the information for describing a service. Example:

documentation:
summary: >
The Google Calendar API gives access
to most calendar features.
pages:
- name: Overview
content: (== include google/foo/overview.md ==)
- name: Tutorial
content: (== include google/foo/tutorial.md ==)
subpages;
- name: Java
content: (== include google/foo/tutorial_java.md ==)
rules:
- selector: google.calendar.Calendar.Get
description: >
...
- selector: google.calendar.Calendar.Put
description: >
...

Documentation is provided in markdown syntax. In addition to standard markdown features, definition lists, tables and fenced code blocks are supported. Section headers can be provided and are interpreted relative to the section nesting of the context where a documentation fragment is embedded. Documentation from the IDL is merged with documentation defined via the config at normalization time, where documentation provided by config rules overrides IDL provided. A number of constructs specific to the API platform are supported in documentation text. In order to reference a proto element, the following notation can be used:

[fully.qualified.proto.name][]

To override the display text used for the link, this can be used:

[display text][fully.qualified.proto.name]

Text can be excluded from doc using the following notation:

(-- internal comment --)

A few directives are available in documentation. Note that directives must appear on a single line to be properly identified. The include directive includes a markdown file from an external source:

(== include path/to/file ==)

The resource_for directive marks a message to be the resource of a collection in REST view. If it is not specified, tools attempt to infer the resource from the operations in a collection:

(== resource_for v1.shelves.books ==)

The directive suppress_warning does not directly affect documentation and is documented together with service config validation.

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Core::JsonObjectSupport

#to_json

Methods included from Core::Hashable

process_value, #to_h

Constructor Details

#initialize(**args) ⇒ Documentation

Returns a new instance of Documentation.



987
988
989
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 987

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#documentation_root_urlString

The URL to the root of documentation. Corresponds to the JSON property documentationRootUrl

Returns:

  • (String)


943
944
945
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 943

def documentation_root_url
  @documentation_root_url
end

#overviewString

Declares a single overview page. For example:

documentation:
summary: ...
overview: (== include overview.md ==)

This is a shortcut for the following declaration (using pages style):

documentation:
summary: ...
pages:
- name: Overview
content: (== include overview.md ==)

Note: you cannot specify both overview field and pages field. Corresponds to the JSON property overview

Returns:

  • (String)


960
961
962
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 960

def overview
  @overview
end

#pagesArray<Google::Apis::ServiceconsumermanagementV1::Page>

The top level pages for the documentation set. Corresponds to the JSON property pages



965
966
967
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 965

def pages
  @pages
end

#rulesArray<Google::Apis::ServiceconsumermanagementV1::DocumentationRule>

A list of documentation rules that apply to individual API elements. NOTE: All service configuration rules follow "last one wins" order. Corresponds to the JSON property rules



971
972
973
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 971

def rules
  @rules
end

#service_root_urlString

Specifies the service root url if the default one (the service name from the yaml file) is not suitable. This can be seen in any fully specified service urls as well as sections that show a base that other urls are relative to. Corresponds to the JSON property serviceRootUrl

Returns:

  • (String)


979
980
981
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 979

def service_root_url
  @service_root_url
end

#summaryString

A short summary of what the service does. Can only be provided by plain text. Corresponds to the JSON property summary

Returns:

  • (String)


985
986
987
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 985

def summary
  @summary
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



992
993
994
995
996
997
998
999
# File 'generated/google/apis/serviceconsumermanagement_v1/classes.rb', line 992

def update!(**args)
  @documentation_root_url = args[:documentation_root_url] if args.key?(:documentation_root_url)
  @overview = args[:overview] if args.key?(:overview)
  @pages = args[:pages] if args.key?(:pages)
  @rules = args[:rules] if args.key?(:rules)
  @service_root_url = args[:service_root_url] if args.key?(:service_root_url)
  @summary = args[:summary] if args.key?(:summary)
end