2016-07-12 16:22:33 +00:00
|
|
|
# Copyright 2016 OpenMarket Ltd
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License 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.
|
2015-05-19 12:16:16 +00:00
|
|
|
"""Contains all the sections for the spec."""
|
2015-05-26 15:20:15 +00:00
|
|
|
from batesian import AccessKeyStore
|
|
|
|
from batesian.sections import Sections
|
2015-05-26 13:33:32 +00:00
|
|
|
import inspect
|
2015-05-29 14:58:33 +00:00
|
|
|
import json
|
2015-05-19 12:16:16 +00:00
|
|
|
import os
|
2018-09-10 22:29:30 +00:00
|
|
|
import logging
|
2015-05-19 12:16:16 +00:00
|
|
|
|
|
|
|
|
2018-09-10 22:29:30 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2015-05-26 15:20:15 +00:00
|
|
|
class MatrixSections(Sections):
|
2015-05-26 13:33:32 +00:00
|
|
|
|
2015-05-26 16:32:51 +00:00
|
|
|
# pass through git ver so it'll be dropped in the input file
|
|
|
|
def render_git_version(self):
|
2015-06-02 12:48:52 +00:00
|
|
|
return self.units.get("git_version")["string"]
|
|
|
|
|
|
|
|
def render_git_rev(self):
|
|
|
|
return self.units.get("git_version")["revision"]
|
2015-05-26 16:32:51 +00:00
|
|
|
|
2018-09-10 22:29:30 +00:00
|
|
|
def render_changelogs(self):
|
|
|
|
rendered = {}
|
2018-08-24 17:36:04 +00:00
|
|
|
changelogs = self.units.get("changelogs")
|
2019-02-07 05:02:21 +00:00
|
|
|
for spec, changelog_text in changelogs.items():
|
2018-09-10 22:29:30 +00:00
|
|
|
spec_var = "%s_changelog" % spec
|
|
|
|
logger.info("Rendering changelog for spec: %s" % spec)
|
2019-02-07 05:02:21 +00:00
|
|
|
rendered[spec_var] = changelog_text
|
2018-09-10 22:29:30 +00:00
|
|
|
return rendered
|
2018-08-24 17:36:04 +00:00
|
|
|
|
2015-09-22 12:08:15 +00:00
|
|
|
def _render_events(self, filterFn, sortFn):
|
2015-05-28 09:36:02 +00:00
|
|
|
template = self.env.get_template("events.tmpl")
|
|
|
|
examples = self.units.get("event_examples")
|
|
|
|
schemas = self.units.get("event_schemas")
|
2015-09-22 12:08:15 +00:00
|
|
|
subtitle_title_char = self.units.get("spec_targets")[
|
|
|
|
"relative_title_styles"
|
|
|
|
]["subtitle"]
|
2015-05-28 09:36:02 +00:00
|
|
|
sections = []
|
|
|
|
for event_name in sortFn(schemas):
|
|
|
|
if not filterFn(event_name):
|
|
|
|
continue
|
|
|
|
sections.append(template.render(
|
2015-10-28 15:00:53 +00:00
|
|
|
examples=examples[event_name],
|
2015-05-28 09:45:00 +00:00
|
|
|
event=schemas[event_name],
|
2015-09-22 12:08:15 +00:00
|
|
|
title_kind=subtitle_title_char
|
2015-05-28 09:36:02 +00:00
|
|
|
))
|
|
|
|
return "\n\n".join(sections)
|
|
|
|
|
2016-05-06 10:01:03 +00:00
|
|
|
def _render_http_api_group(self, group, sortPathList=None):
|
2015-06-01 11:03:42 +00:00
|
|
|
template = self.env.get_template("http-api.tmpl")
|
2015-06-01 15:29:19 +00:00
|
|
|
http_api = self.units.get("swagger_apis")[group]["__meta"]
|
2015-09-22 12:08:15 +00:00
|
|
|
subtitle_title_char = self.units.get("spec_targets")[
|
|
|
|
"relative_title_styles"
|
|
|
|
]["subtitle"]
|
2015-06-01 11:03:42 +00:00
|
|
|
sections = []
|
2015-06-02 15:01:26 +00:00
|
|
|
endpoints = []
|
2016-05-06 10:01:03 +00:00
|
|
|
if sortPathList:
|
2015-06-02 15:01:26 +00:00
|
|
|
# list of substrings to sort by
|
|
|
|
sorted_endpoints = []
|
2016-05-06 10:01:03 +00:00
|
|
|
for path_substr in sortPathList:
|
2015-06-02 15:01:26 +00:00
|
|
|
for e in http_api["endpoints"]:
|
|
|
|
if path_substr in e["path"]:
|
|
|
|
sorted_endpoints.append(e) # could have multiple
|
|
|
|
# dump rest
|
|
|
|
rest = [
|
|
|
|
e for e in http_api["endpoints"] if e not in sorted_endpoints
|
|
|
|
]
|
2016-05-06 10:01:03 +00:00
|
|
|
endpoints = sorted_endpoints + rest
|
2015-06-02 15:01:26 +00:00
|
|
|
else:
|
|
|
|
# sort alphabetically based on path
|
2016-05-06 10:01:03 +00:00
|
|
|
endpoints = http_api["endpoints"]
|
2015-06-02 15:01:26 +00:00
|
|
|
|
|
|
|
for endpoint in endpoints:
|
2015-06-01 11:03:42 +00:00
|
|
|
sections.append(template.render(
|
|
|
|
endpoint=endpoint,
|
2015-09-22 12:08:15 +00:00
|
|
|
title_kind=subtitle_title_char
|
2015-06-01 11:03:42 +00:00
|
|
|
))
|
|
|
|
return "\n\n".join(sections)
|
2015-05-29 15:50:22 +00:00
|
|
|
|
2015-09-08 15:35:08 +00:00
|
|
|
|
2015-09-23 09:48:49 +00:00
|
|
|
# Special function: Returning a dict will specify multiple sections where
|
|
|
|
# the key is the section name and the value is the value of the section
|
|
|
|
def render_group_http_apis(self):
|
|
|
|
# map all swagger_apis to the form $GROUP_http_api
|
|
|
|
swagger_groups = self.units.get("swagger_apis").keys()
|
|
|
|
renders = {}
|
|
|
|
for group in swagger_groups:
|
|
|
|
sortFnOrPathList = None
|
2016-03-08 17:42:41 +00:00
|
|
|
if group == "presence_cs":
|
2015-09-23 09:48:49 +00:00
|
|
|
sortFnOrPathList = ["status"]
|
2016-03-08 17:42:41 +00:00
|
|
|
elif group == "profile_cs":
|
2015-09-23 09:48:49 +00:00
|
|
|
sortFnOrPathList=["displayname", "avatar_url"]
|
|
|
|
renders[group + "_http_api"] = self._render_http_api_group(
|
|
|
|
group, sortFnOrPathList
|
|
|
|
)
|
|
|
|
return renders
|
2015-09-14 12:49:27 +00:00
|
|
|
|
2015-09-23 09:48:49 +00:00
|
|
|
# Special function: Returning a dict will specify multiple sections where
|
|
|
|
# the key is the section name and the value is the value of the section
|
|
|
|
def render_group_events(self):
|
|
|
|
# map all event schemata to the form $EVENTTYPE_event with s/./_/g
|
|
|
|
# e.g. m_room_topic_event
|
|
|
|
schemas = self.units.get("event_schemas")
|
|
|
|
renders = {}
|
|
|
|
for event_type in schemas:
|
|
|
|
renders[event_type.replace(".", "_") + "_event"] = self._render_events(
|
|
|
|
lambda x: x == event_type, sorted
|
|
|
|
)
|
|
|
|
return renders
|
2015-09-15 14:52:36 +00:00
|
|
|
|
2015-05-26 13:33:32 +00:00
|
|
|
def render_room_events(self):
|
2015-05-28 09:45:00 +00:00
|
|
|
def filterFn(eventType):
|
|
|
|
return (
|
2016-05-06 10:01:03 +00:00
|
|
|
eventType.startswith("m.room") and
|
2015-05-28 09:45:00 +00:00
|
|
|
not eventType.startswith("m.room.message#m.")
|
|
|
|
)
|
|
|
|
return self._render_events(filterFn, sorted)
|
2015-05-27 15:30:11 +00:00
|
|
|
|
|
|
|
def render_msgtype_events(self):
|
|
|
|
template = self.env.get_template("msgtypes.tmpl")
|
|
|
|
examples = self.units.get("event_examples")
|
|
|
|
schemas = self.units.get("event_schemas")
|
2015-09-22 12:08:15 +00:00
|
|
|
subtitle_title_char = self.units.get("spec_targets")[
|
|
|
|
"relative_title_styles"
|
|
|
|
]["subtitle"]
|
2015-05-27 15:30:11 +00:00
|
|
|
sections = []
|
2015-05-27 15:51:07 +00:00
|
|
|
msgtype_order = [
|
|
|
|
"m.room.message#m.text", "m.room.message#m.emote",
|
|
|
|
"m.room.message#m.notice", "m.room.message#m.image",
|
|
|
|
"m.room.message#m.file"
|
|
|
|
]
|
|
|
|
other_msgtypes = [
|
|
|
|
k for k in schemas.keys() if k.startswith("m.room.message#") and
|
|
|
|
k not in msgtype_order
|
|
|
|
]
|
|
|
|
for event_name in (msgtype_order + other_msgtypes):
|
2015-05-27 15:30:11 +00:00
|
|
|
if not event_name.startswith("m.room.message#m."):
|
2015-05-26 13:33:32 +00:00
|
|
|
continue
|
|
|
|
sections.append(template.render(
|
2015-11-10 15:26:51 +00:00
|
|
|
example=examples[event_name][0],
|
2015-09-22 12:08:15 +00:00
|
|
|
event=schemas[event_name],
|
|
|
|
title_kind=subtitle_title_char
|
2015-05-26 13:33:32 +00:00
|
|
|
))
|
|
|
|
return "\n\n".join(sections)
|
2015-05-21 14:41:34 +00:00
|
|
|
|
2015-05-26 16:32:51 +00:00
|
|
|
def render_voip_events(self):
|
2015-05-28 09:45:00 +00:00
|
|
|
def filterFn(eventType):
|
|
|
|
return eventType.startswith("m.call")
|
2015-05-28 10:35:18 +00:00
|
|
|
def sortFn(eventTypes):
|
|
|
|
ordering = [
|
|
|
|
"m.call.invite", "m.call.candidates", "m.call.answer",
|
|
|
|
"m.call.hangup"
|
|
|
|
]
|
|
|
|
rest = [
|
|
|
|
k for k in eventTypes if k not in ordering
|
|
|
|
]
|
|
|
|
return ordering + rest
|
|
|
|
return self._render_events(filterFn, sortFn)
|
2015-05-26 16:09:30 +00:00
|
|
|
|
2015-05-28 09:36:02 +00:00
|
|
|
def render_presence_events(self):
|
|
|
|
def filterFn(eventType):
|
|
|
|
return eventType.startswith("m.presence")
|
2015-09-22 12:08:15 +00:00
|
|
|
return self._render_events(filterFn, sorted)
|
2015-05-28 09:36:02 +00:00
|
|
|
|
2015-05-26 13:33:32 +00:00
|
|
|
def _render_ce_type(self, type):
|
|
|
|
template = self.env.get_template("common-event-fields.tmpl")
|
2015-05-26 13:50:45 +00:00
|
|
|
ce_types = self.units.get("common_event_fields")
|
2015-09-22 13:07:23 +00:00
|
|
|
subtitle_title_char = self.units.get("spec_targets")[
|
|
|
|
"relative_title_styles"
|
|
|
|
]["subtitle"]
|
|
|
|
return template.render(
|
|
|
|
common_event=ce_types[type], title_kind=subtitle_title_char
|
|
|
|
)
|
2015-05-21 14:41:34 +00:00
|
|
|
|
2015-05-26 13:33:32 +00:00
|
|
|
def render_common_event_fields(self):
|
|
|
|
return self._render_ce_type("event")
|
|
|
|
|
|
|
|
def render_common_room_event_fields(self):
|
|
|
|
return self._render_ce_type("room_event")
|
|
|
|
|
|
|
|
def render_common_state_event_fields(self):
|
|
|
|
return self._render_ce_type("state_event")
|
2015-09-23 09:48:49 +00:00
|
|
|
|
2016-04-26 14:23:36 +00:00
|
|
|
def render_apis(self):
|
|
|
|
template = self.env.get_template("apis.tmpl")
|
|
|
|
apis = self.units.get("apis")
|
|
|
|
return template.render(apis=apis)
|
2018-07-31 19:55:53 +00:00
|
|
|
|
2018-08-30 19:25:01 +00:00
|
|
|
def render_unstable_warnings(self):
|
|
|
|
rendered = {}
|
|
|
|
blocks = self.units.get("unstable_warnings")
|
|
|
|
for var, text in blocks.items():
|
|
|
|
rendered["unstable_warning_block_" + var] = text
|
|
|
|
return rendered
|
|
|
|
|
2018-07-31 19:55:53 +00:00
|
|
|
def render_swagger_definition(self):
|
|
|
|
rendered = {}
|
|
|
|
template = self.env.get_template("schema-definition.tmpl")
|
|
|
|
subtitle_title_char = self.units.get("spec_targets")[
|
|
|
|
"relative_title_styles"
|
|
|
|
]["subtitle"]
|
|
|
|
definitions = self.units.get("swagger_definitions")
|
|
|
|
for group, swagger_def in definitions.items():
|
|
|
|
rendered["definition_" + group] = template.render(
|
|
|
|
definition=swagger_def['definition'],
|
|
|
|
examples=swagger_def['examples'],
|
|
|
|
title_kind=subtitle_title_char)
|
2018-08-31 21:03:48 +00:00
|
|
|
return rendered
|