-
Notifications
You must be signed in to change notification settings - Fork 385
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Specify .well-known s2s discovery and X.509 validation
Original proposals: * #1708 (note: the JSON requirements were softened by #1824) * #1711 Implementation proofs: * matrix-org/synapse#4489 * No explicit PRs for MSC1711 could be found, however Synapse is known to implement it. There are no intentional changes which differ from the proposals in this commit, however the author has relied upon various historical conversations outside of the proposals to gain the required context. Inaccuracies introduced by the author are purely accidental.
- Loading branch information
Showing
4 changed files
with
155 additions
and
50 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,53 @@ | ||
# Copyright 2019 New Vector 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. | ||
swagger: '2.0' | ||
info: | ||
title: "Matrix Federation Server Discovery API" | ||
version: "1.0.0" | ||
host: localhost:443 | ||
schemes: | ||
- https | ||
basePath: /.well-known | ||
produces: | ||
- application/json | ||
paths: | ||
"/matrix/server": | ||
get: | ||
summary: Gets information about the delegated server for server-server communication. | ||
description: |- | ||
Gets information about the delegated server for server-server communication | ||
between Matrix homeservers. Servers should follow 30x redirects, carefully | ||
avoiding redirect loops, and use normal X.509 certificate validation. | ||
responses: | ||
200: | ||
description: | ||
The delegated server information. The ``Content-Type`` for this response SHOULD | ||
be ``application/json``, however servers parsing the response should assume that | ||
the body is JSON regardless of type. Failures parsing the JSON or invalid data | ||
provided in the resulting parsed JSON must result in server discovery failure (no | ||
attempts should be made to continue finding an IP address/port number to connect | ||
to). | ||
examples: | ||
application/json: { | ||
"m.server": "delegated.example.com:1234" | ||
} | ||
schema: | ||
type: object | ||
properties: | ||
"m.server": | ||
type: string | ||
description: |- | ||
The server name to delegate server-server communciations to, with optional | ||
port. The delegated server name uses the same grammar as | ||
`server names in the appendices <../appendices.html#server-name>`_. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters