2018-12-05 16:38:58 +03:00
|
|
|
#
|
2023-11-21 23:29:58 +03:00
|
|
|
# This file is licensed under the Affero General Public License (AGPL) version 3.
|
|
|
|
#
|
|
|
|
# Copyright (C) 2023 New Vector, Ltd
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Affero General Public License as
|
|
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
|
|
# License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# See the GNU Affero General Public License for more details:
|
|
|
|
# <https://www.gnu.org/licenses/agpl-3.0.html>.
|
|
|
|
#
|
|
|
|
# Originally licensed under the Apache License, Version 2.0:
|
|
|
|
# <http://www.apache.org/licenses/LICENSE-2.0>.
|
|
|
|
#
|
|
|
|
# [This file includes modifications made by New Vector Limited]
|
2018-12-05 16:38:58 +03:00
|
|
|
#
|
|
|
|
#
|
2024-08-30 17:04:08 +03:00
|
|
|
from unittest.mock import AsyncMock
|
|
|
|
|
2021-11-01 18:10:16 +03:00
|
|
|
from twisted.web.resource import Resource
|
2018-12-05 16:38:58 +03:00
|
|
|
|
2021-11-01 18:10:16 +03:00
|
|
|
from synapse.rest.well_known import well_known_resource
|
2018-12-05 16:38:58 +03:00
|
|
|
|
|
|
|
from tests import unittest
|
2023-11-23 15:35:37 +03:00
|
|
|
from tests.utils import HAS_AUTHLIB
|
2023-02-06 20:12:42 +03:00
|
|
|
|
2018-12-05 16:38:58 +03:00
|
|
|
|
|
|
|
class WellKnownTests(unittest.HomeserverTestCase):
|
2022-03-03 19:05:44 +03:00
|
|
|
def create_test_resource(self) -> Resource:
|
2021-11-01 18:10:16 +03:00
|
|
|
# replace the JsonResource with a Resource wrapping the WellKnownResource
|
|
|
|
res = Resource()
|
|
|
|
res.putChild(b".well-known", well_known_resource(self.hs))
|
|
|
|
return res
|
2018-12-05 16:38:58 +03:00
|
|
|
|
2021-09-13 20:07:12 +03:00
|
|
|
@unittest.override_config(
|
|
|
|
{
|
|
|
|
"public_baseurl": "https://tesths",
|
|
|
|
"default_identity_server": "https://testis",
|
|
|
|
}
|
|
|
|
)
|
2022-03-03 19:05:44 +03:00
|
|
|
def test_client_well_known(self) -> None:
|
2020-12-15 17:44:04 +03:00
|
|
|
channel = self.make_request(
|
2019-05-10 08:12:11 +03:00
|
|
|
"GET", "/.well-known/matrix/client", shorthand=False
|
2018-12-05 16:38:58 +03:00
|
|
|
)
|
|
|
|
|
2022-08-05 17:59:09 +03:00
|
|
|
self.assertEqual(channel.code, 200)
|
2018-12-05 16:38:58 +03:00
|
|
|
self.assertEqual(
|
2019-05-10 08:12:11 +03:00
|
|
|
channel.json_body,
|
|
|
|
{
|
2021-09-13 20:07:12 +03:00
|
|
|
"m.homeserver": {"base_url": "https://tesths/"},
|
2018-12-05 16:38:58 +03:00
|
|
|
"m.identity_server": {"base_url": "https://testis"},
|
2019-05-10 08:12:11 +03:00
|
|
|
},
|
2018-12-05 16:38:58 +03:00
|
|
|
)
|
2021-02-11 19:16:54 +03:00
|
|
|
|
2021-09-13 20:07:12 +03:00
|
|
|
@unittest.override_config(
|
|
|
|
{
|
|
|
|
"public_baseurl": None,
|
|
|
|
}
|
|
|
|
)
|
2022-03-03 19:05:44 +03:00
|
|
|
def test_client_well_known_no_public_baseurl(self) -> None:
|
2021-02-11 19:16:54 +03:00
|
|
|
channel = self.make_request(
|
|
|
|
"GET", "/.well-known/matrix/client", shorthand=False
|
|
|
|
)
|
|
|
|
|
2022-08-05 17:59:09 +03:00
|
|
|
self.assertEqual(channel.code, 404)
|
2021-11-01 18:10:16 +03:00
|
|
|
|
2022-06-16 13:48:18 +03:00
|
|
|
@unittest.override_config(
|
|
|
|
{
|
|
|
|
"public_baseurl": "https://tesths",
|
|
|
|
"default_identity_server": "https://testis",
|
|
|
|
"extra_well_known_client_content": {"custom": False},
|
|
|
|
}
|
|
|
|
)
|
|
|
|
def test_client_well_known_custom(self) -> None:
|
|
|
|
channel = self.make_request(
|
|
|
|
"GET", "/.well-known/matrix/client", shorthand=False
|
|
|
|
)
|
|
|
|
|
2022-08-05 17:59:09 +03:00
|
|
|
self.assertEqual(channel.code, 200)
|
2022-06-16 13:48:18 +03:00
|
|
|
self.assertEqual(
|
|
|
|
channel.json_body,
|
|
|
|
{
|
|
|
|
"m.homeserver": {"base_url": "https://tesths/"},
|
|
|
|
"m.identity_server": {"base_url": "https://testis"},
|
|
|
|
"custom": False,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
2021-11-01 18:10:16 +03:00
|
|
|
@unittest.override_config({"serve_server_wellknown": True})
|
2022-03-03 19:05:44 +03:00
|
|
|
def test_server_well_known(self) -> None:
|
2021-11-01 18:10:16 +03:00
|
|
|
channel = self.make_request(
|
|
|
|
"GET", "/.well-known/matrix/server", shorthand=False
|
|
|
|
)
|
|
|
|
|
2022-08-05 17:59:09 +03:00
|
|
|
self.assertEqual(channel.code, 200)
|
2021-11-01 18:10:16 +03:00
|
|
|
self.assertEqual(
|
|
|
|
channel.json_body,
|
|
|
|
{"m.server": "test:443"},
|
|
|
|
)
|
|
|
|
|
2022-03-03 19:05:44 +03:00
|
|
|
def test_server_well_known_disabled(self) -> None:
|
2021-11-01 18:10:16 +03:00
|
|
|
channel = self.make_request(
|
|
|
|
"GET", "/.well-known/matrix/server", shorthand=False
|
|
|
|
)
|
2022-08-05 17:59:09 +03:00
|
|
|
self.assertEqual(channel.code, 404)
|
2023-02-06 20:12:42 +03:00
|
|
|
|
|
|
|
@unittest.skip_unless(HAS_AUTHLIB, "requires authlib")
|
|
|
|
@unittest.override_config(
|
|
|
|
{
|
|
|
|
"public_baseurl": "https://homeserver", # this is only required so that client well known is served
|
2023-05-09 17:20:04 +03:00
|
|
|
"experimental_features": {
|
|
|
|
"msc3861": {
|
|
|
|
"enabled": True,
|
|
|
|
"issuer": "https://issuer",
|
|
|
|
"client_id": "id",
|
|
|
|
"client_auth_method": "client_secret_post",
|
|
|
|
"client_secret": "secret",
|
|
|
|
},
|
2023-02-06 20:12:42 +03:00
|
|
|
},
|
2023-05-09 17:20:04 +03:00
|
|
|
"disable_registration": True,
|
2023-02-06 20:12:42 +03:00
|
|
|
}
|
|
|
|
)
|
|
|
|
def test_client_well_known_msc3861_oauth_delegation(self) -> None:
|
2024-08-30 17:04:08 +03:00
|
|
|
# Patch the HTTP client to return the issuer metadata
|
2024-09-02 14:39:04 +03:00
|
|
|
req_mock = AsyncMock(
|
|
|
|
return_value={
|
|
|
|
"issuer": "https://issuer",
|
|
|
|
"account_management_uri": "https://my-account.issuer",
|
|
|
|
}
|
|
|
|
)
|
2024-08-30 17:04:08 +03:00
|
|
|
self.hs.get_proxied_http_client().get_json = req_mock # type: ignore[method-assign]
|
2023-02-06 20:12:42 +03:00
|
|
|
|
2024-08-30 17:04:08 +03:00
|
|
|
for _ in range(2):
|
|
|
|
channel = self.make_request(
|
|
|
|
"GET", "/.well-known/matrix/client", shorthand=False
|
|
|
|
)
|
|
|
|
|
|
|
|
self.assertEqual(channel.code, 200)
|
|
|
|
self.assertEqual(
|
|
|
|
channel.json_body,
|
|
|
|
{
|
|
|
|
"m.homeserver": {"base_url": "https://homeserver/"},
|
|
|
|
"org.matrix.msc2965.authentication": {
|
|
|
|
"issuer": "https://issuer",
|
|
|
|
"account": "https://my-account.issuer",
|
|
|
|
},
|
2023-02-06 20:12:42 +03:00
|
|
|
},
|
2024-08-30 17:04:08 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
# It should have been called exactly once, because it gets cached
|
2024-09-02 14:39:04 +03:00
|
|
|
req_mock.assert_called_once_with(
|
|
|
|
"https://issuer/.well-known/openid-configuration"
|
|
|
|
)
|