python-boto3/boto3/docs/service.py

135 lines
5.3 KiB
Python
Raw Normal View History

2015-11-27 23:25:33 +01:00
# Copyright 2015 Amazon.com, Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"). You
# may not use this file except in compliance with the License. A copy of
# the License is located at
#
2021-09-22 18:34:33 +02:00
# https://aws.amazon.com/apache2.0/
2015-11-27 23:25:33 +01:00
#
# or in the "license" file accompanying this file. This file is
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
# ANY KIND, either express or implied. See the License for the specific
# language governing permissions and limitations under the License.
2016-05-22 04:03:29 +02:00
import os
2015-11-27 23:25:33 +01:00
from botocore.docs.bcdoc.restdoc import DocumentStructure
2022-05-26 01:13:54 +02:00
from botocore.docs.service import ServiceDocumenter as BaseServiceDocumenter
from botocore.exceptions import DataNotFoundError
2015-11-27 23:25:33 +01:00
2022-05-26 01:13:54 +02:00
import boto3
2015-11-27 23:25:33 +01:00
from boto3.docs.client import Boto3ClientDocumenter
2022-05-26 01:13:54 +02:00
from boto3.docs.resource import ResourceDocumenter, ServiceResourceDocumenter
from boto3.utils import ServiceContext
2015-11-27 23:25:33 +01:00
2016-05-22 04:03:29 +02:00
class ServiceDocumenter(BaseServiceDocumenter):
# The path used to find examples
EXAMPLE_PATH = os.path.join(os.path.dirname(boto3.__file__), 'examples')
2015-11-27 23:25:33 +01:00
def __init__(self, service_name, session):
2022-05-26 01:13:54 +02:00
super().__init__(
2019-01-28 22:47:44 +01:00
service_name=service_name,
# I know that this is an internal attribute, but the botocore session
# is needed to load the paginator and waiter models.
session=session._session,
)
2016-05-22 04:03:29 +02:00
self._boto3_session = session
self._client = self._boto3_session.client(service_name)
2015-11-27 23:25:33 +01:00
self._service_resource = None
2016-05-22 04:03:29 +02:00
if self._service_name in self._boto3_session.get_available_resources():
self._service_resource = self._boto3_session.resource(service_name)
2015-11-27 23:25:33 +01:00
self.sections = [
'title',
'table-of-contents',
'client',
'paginators',
'waiters',
'service-resource',
2016-05-22 04:03:29 +02:00
'resources',
2022-05-26 01:13:54 +02:00
'examples',
2015-11-27 23:25:33 +01:00
]
def document_service(self):
"""Documents an entire service.
:returns: The reStructured text of the documented service.
"""
doc_structure = DocumentStructure(
2022-05-26 01:13:54 +02:00
self._service_name, section_names=self.sections, target='html'
)
2016-05-22 04:03:29 +02:00
self.title(doc_structure.get_section('title'))
self.table_of_contents(doc_structure.get_section('table-of-contents'))
self.client_api(doc_structure.get_section('client'))
self.paginator_api(doc_structure.get_section('paginators'))
self.waiter_api(doc_structure.get_section('waiters'))
2015-11-27 23:25:33 +01:00
if self._service_resource:
self._document_service_resource(
2022-05-26 01:13:54 +02:00
doc_structure.get_section('service-resource')
)
2015-11-27 23:25:33 +01:00
self._document_resources(doc_structure.get_section('resources'))
2016-05-22 04:03:29 +02:00
self._document_examples(doc_structure.get_section('examples'))
2015-11-27 23:25:33 +01:00
return doc_structure.flush_structure()
2016-05-22 04:03:29 +02:00
def client_api(self, section):
examples = None
2015-11-27 23:25:33 +01:00
try:
2016-05-22 04:03:29 +02:00
examples = self.get_examples(self._service_name)
2015-11-27 23:25:33 +01:00
except DataNotFoundError:
2016-05-22 04:03:29 +02:00
pass
2015-11-27 23:25:33 +01:00
2016-05-22 04:03:29 +02:00
Boto3ClientDocumenter(self._client, examples).document_client(section)
2015-11-27 23:25:33 +01:00
def _document_service_resource(self, section):
ServiceResourceDocumenter(
2022-05-26 01:13:54 +02:00
self._service_resource, self._session
).document_resource(section)
2015-11-27 23:25:33 +01:00
def _document_resources(self, section):
temp_identifier_value = 'foo'
2016-05-22 04:03:29 +02:00
loader = self._session.get_component('data_loader')
2015-11-27 23:25:33 +01:00
json_resource_model = loader.load_service_model(
2022-05-26 01:13:54 +02:00
self._service_name, 'resources-1'
)
2015-11-27 23:25:33 +01:00
service_model = self._service_resource.meta.client.meta.service_model
for resource_name in json_resource_model['resources']:
resource_model = json_resource_model['resources'][resource_name]
2022-05-26 01:13:54 +02:00
resource_cls = (
self._boto3_session.resource_factory.load_from_definition(
2016-05-22 04:03:29 +02:00
resource_name=resource_name,
single_resource_json_definition=resource_model,
service_context=ServiceContext(
service_name=self._service_name,
resource_json_definitions=json_resource_model[
2022-05-26 01:13:54 +02:00
'resources'
],
2016-05-22 04:03:29 +02:00
service_model=service_model,
2022-05-26 01:13:54 +02:00
service_waiter_model=None,
),
2015-11-27 23:25:33 +01:00
)
2022-05-26 01:13:54 +02:00
)
2015-11-27 23:25:33 +01:00
identifiers = resource_cls.meta.resource_model.identifiers
args = []
for _ in identifiers:
args.append(temp_identifier_value)
resource = resource_cls(*args, client=self._client)
2022-05-26 01:13:54 +02:00
ResourceDocumenter(resource, self._session).document_resource(
section.add_new_section(resource.meta.resource_model.name)
)
2016-05-22 04:03:29 +02:00
def _get_example_file(self):
return os.path.realpath(
2022-05-26 01:13:54 +02:00
os.path.join(self.EXAMPLE_PATH, self._service_name + '.rst')
)
2016-05-22 04:03:29 +02:00
def _document_examples(self, section):
examples_file = self._get_example_file()
if os.path.isfile(examples_file):
section.style.h2('Examples')
section.style.new_line()
section.write(".. contents::\n :local:\n :depth: 1")
section.style.new_line()
section.style.new_line()
2022-05-26 01:13:54 +02:00
with open(examples_file) as f:
2016-05-22 04:03:29 +02:00
section.write(f.read())