Throw if the appservice config list is the wrong type (#15425)
* raise a ConfigError on an invalid app_service_config_files * changelog * Move config check to read_config * Add test * Ensure list also contains stringspull/15428/head
parent
66ad1b8984
commit
253e86a72e
|
@ -0,0 +1 @@
|
||||||
|
Synapse now correctly fails to start if the config option `app_service_config_files` is not a list.
|
|
@ -33,6 +33,16 @@ class AppServiceConfig(Config):
|
||||||
|
|
||||||
def read_config(self, config: JsonDict, **kwargs: Any) -> None:
|
def read_config(self, config: JsonDict, **kwargs: Any) -> None:
|
||||||
self.app_service_config_files = config.get("app_service_config_files", [])
|
self.app_service_config_files = config.get("app_service_config_files", [])
|
||||||
|
if not isinstance(self.app_service_config_files, list) or not all(
|
||||||
|
type(x) is str for x in self.app_service_config_files
|
||||||
|
):
|
||||||
|
# type-ignore: this function gets arbitrary json value; we do use this path.
|
||||||
|
raise ConfigError(
|
||||||
|
"Expected '%s' to be a list of AS config files:"
|
||||||
|
% (self.app_service_config_files),
|
||||||
|
"app_service_config_files",
|
||||||
|
)
|
||||||
|
|
||||||
self.track_appservice_user_ips = config.get("track_appservice_user_ips", False)
|
self.track_appservice_user_ips = config.get("track_appservice_user_ips", False)
|
||||||
|
|
||||||
|
|
||||||
|
@ -40,10 +50,6 @@ def load_appservices(
|
||||||
hostname: str, config_files: List[str]
|
hostname: str, config_files: List[str]
|
||||||
) -> List[ApplicationService]:
|
) -> List[ApplicationService]:
|
||||||
"""Returns a list of Application Services from the config files."""
|
"""Returns a list of Application Services from the config files."""
|
||||||
if not isinstance(config_files, list):
|
|
||||||
# type-ignore: this function gets arbitrary json value; we do use this path.
|
|
||||||
logger.warning("Expected %s to be a list of AS config files.", config_files) # type: ignore[unreachable]
|
|
||||||
return []
|
|
||||||
|
|
||||||
# Dicts of value -> filename
|
# Dicts of value -> filename
|
||||||
seen_as_tokens: Dict[str, str] = {}
|
seen_as_tokens: Dict[str, str] = {}
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
# Copyright 2023 Matrix.org Foundation C.I.C.
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
from synapse.config.appservice import AppServiceConfig, ConfigError
|
||||||
|
|
||||||
|
from tests.unittest import TestCase
|
||||||
|
|
||||||
|
|
||||||
|
class AppServiceConfigTest(TestCase):
|
||||||
|
def test_invalid_app_service_config_files(self) -> None:
|
||||||
|
for invalid_value in [
|
||||||
|
"foobar",
|
||||||
|
1,
|
||||||
|
None,
|
||||||
|
True,
|
||||||
|
False,
|
||||||
|
{},
|
||||||
|
["foo", "bar", False],
|
||||||
|
]:
|
||||||
|
with self.assertRaises(ConfigError):
|
||||||
|
AppServiceConfig().read_config(
|
||||||
|
{"app_service_config_files": invalid_value}
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_valid_app_service_config_files(self) -> None:
|
||||||
|
AppServiceConfig().read_config({"app_service_config_files": []})
|
||||||
|
AppServiceConfig().read_config(
|
||||||
|
{"app_service_config_files": ["/not/a/real/path", "/not/a/real/path/2"]}
|
||||||
|
)
|
Loading…
Reference in New Issue