mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-07-28 21:08:33 -04:00
Be more lenient when parsing the version for oEmbed responses. (#11065)
This commit is contained in:
parent
2a2b189130
commit
732bbf6737
5 changed files with 60 additions and 8 deletions
|
@ -17,7 +17,6 @@ from typing import TYPE_CHECKING, List, Optional
|
|||
|
||||
import attr
|
||||
|
||||
from synapse.http.client import SimpleHttpClient
|
||||
from synapse.types import JsonDict
|
||||
from synapse.util import json_decoder
|
||||
|
||||
|
@ -48,7 +47,7 @@ class OEmbedProvider:
|
|||
requesting/parsing oEmbed content.
|
||||
"""
|
||||
|
||||
def __init__(self, hs: "HomeServer", client: SimpleHttpClient):
|
||||
def __init__(self, hs: "HomeServer"):
|
||||
self._oembed_patterns = {}
|
||||
for oembed_endpoint in hs.config.oembed.oembed_patterns:
|
||||
api_endpoint = oembed_endpoint.api_endpoint
|
||||
|
@ -69,7 +68,6 @@ class OEmbedProvider:
|
|||
# Iterate through each URL pattern and point it to the endpoint.
|
||||
for pattern in oembed_endpoint.url_patterns:
|
||||
self._oembed_patterns[pattern] = api_endpoint
|
||||
self._client = client
|
||||
|
||||
def get_oembed_url(self, url: str) -> Optional[str]:
|
||||
"""
|
||||
|
@ -139,10 +137,11 @@ class OEmbedProvider:
|
|||
# oEmbed responses *must* be UTF-8 according to the spec.
|
||||
oembed = json_decoder.decode(raw_body.decode("utf-8"))
|
||||
|
||||
# Ensure there's a version of 1.0.
|
||||
oembed_version = oembed["version"]
|
||||
if oembed_version != "1.0":
|
||||
raise RuntimeError(f"Invalid version: {oembed_version}")
|
||||
# The version is a required string field, but not always provided,
|
||||
# or sometimes provided as a float. Be lenient.
|
||||
oembed_version = oembed.get("version", "1.0")
|
||||
if oembed_version != "1.0" and oembed_version != 1:
|
||||
raise RuntimeError(f"Invalid oEmbed version: {oembed_version}")
|
||||
|
||||
# Ensure the cache age is None or an int.
|
||||
cache_age = oembed.get("cache_age")
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue