Skip to content

Commit 6d966a3

Browse files
authored
Merge pull request #110 from ourzora/BACK-3396
BACK-3396: allow data uri containing a json to omit utf-8
2 parents 85aa49f + 45b23b8 commit 6d966a3

File tree

6 files changed

+55
-6
lines changed

6 files changed

+55
-6
lines changed

docs/changelog.md

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,9 @@
11
# Changelog
22

3+
## v0.3.5
4+
5+
- Allow data uri containing a json to omit "utf-8" encoding
6+
37
## v0.3.4
48

59
- Fix Nouns parser to make sure image uri is properly base64-encoded svg

docs/index.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
# Getting Started
22

3-
Documentation for version: **v0.3.4**
3+
Documentation for version: **v0.3.5**
44

55
## Overview
66

offchain/metadata/adapters/data_uri.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@ def decode_data_url(data_url): # type: ignore[no-untyped-def]
1818
decoded_data = base64.b64decode(data)
1919
decoded_text = decoded_data.decode("utf-8")
2020
return decoded_text
21-
elif "json;utf8" in data_parts[0]:
21+
elif "json" in data_parts[0]:
2222
decoded_data = urlopen(data_url).read()
2323
decoded_text = json.dumps(json.loads(decoded_data))
2424
return decoded_text

pyproject.toml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
[tool.poetry]
22
name = "offchain"
3-
version = "0.3.4"
3+
version = "0.3.5"
44
description = "Open source metadata processing framework"
55
authors = ["Zora eng <[email protected]>"]
66
readme = "README.md"

tests/metadata/adapters/test_data_adapter.py

Lines changed: 37 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,7 @@ async def test_gen_head(self, httpx_mock: HTTPXMock):
2929
@pytest.mark.asyncio
3030
async def test_gen_head_not_base64(self, httpx_mock: HTTPXMock):
3131
adapter = DataURIAdapter()
32-
data_url = "data:application/json;utf8,{\"name\":\"here for now\",\"description\":\"sometimes i don't know how to feel when i'm away.\", \"image\": \"\"}" # noqa
32+
data_url = 'data:application/json;utf8,{"name":"here for now","description":"sometimes i don\'t know how to feel when i\'m away.", "image": ""}' # noqa
3333
async with httpx.AsyncClient() as client:
3434
result = await adapter.gen_head(url=data_url, sess=client)
3535

@@ -45,6 +45,26 @@ async def test_gen_head_not_base64(self, httpx_mock: HTTPXMock):
4545
outgoing_request = httpx_mock.get_requests()
4646
assert not outgoing_request
4747

48+
@pytest.mark.asyncio
49+
async def test_gen_head_json_unspecified_encoding(self, httpx_mock: HTTPXMock):
50+
adapter = DataURIAdapter()
51+
json_str = '{"name":"here for now","description":"sometimes i don\'t know how to feel when i\'m away.", "image": ""}' # noqa
52+
data_url = f"data:application/json,{json_str}"
53+
async with httpx.AsyncClient() as client:
54+
result = await adapter.gen_head(url=data_url, sess=client)
55+
56+
expected = httpx.Response(
57+
status_code=200,
58+
headers={"content-type": "application/json", "content-length": "2600"},
59+
request=httpx.Request(method="HEAD", url=data_url),
60+
)
61+
assert result.status_code == 200
62+
assert result.request.method == "HEAD"
63+
assert result.headers == expected.headers
64+
# no real request was made
65+
outgoing_request = httpx_mock.get_requests()
66+
assert not outgoing_request
67+
4868
@pytest.mark.asyncio
4969
async def test_gen_send(self, httpx_mock: HTTPXMock):
5070
adapter = DataURIAdapter()
@@ -61,7 +81,7 @@ async def test_gen_send(self, httpx_mock: HTTPXMock):
6181
@pytest.mark.asyncio
6282
async def test_gen_send_not_base64(self, httpx_mock: HTTPXMock):
6383
adapter = DataURIAdapter()
64-
json_str = "{\"name\":\"here for now\",\"description\":\"sometimes i don't know how to feel when i'm away.\", \"image\": \"\"}" # noqa
84+
json_str = '{"name":"here for now","description":"sometimes i don\'t know how to feel when i\'m away.", "image": ""}' # noqa
6585
data_url = f"data:application/json;utf8,{json_str}"
6686
async with httpx.AsyncClient() as client:
6787
result = await adapter.gen_send(url=data_url, sess=client)
@@ -72,3 +92,18 @@ async def test_gen_send_not_base64(self, httpx_mock: HTTPXMock):
7292
# no real request was made
7393
outgoing_request = httpx_mock.get_requests()
7494
assert not outgoing_request
95+
96+
@pytest.mark.asyncio
97+
async def test_gen_send_json_unspecified_encoding(self, httpx_mock: HTTPXMock):
98+
adapter = DataURIAdapter()
99+
json_str = '{"name":"here for now","description":"sometimes i don\'t know how to feel when i\'m away.", "image": ""}' # noqa
100+
data_url = f"data:application/json,{json_str}"
101+
async with httpx.AsyncClient() as client:
102+
result = await adapter.gen_send(url=data_url, sess=client)
103+
104+
assert result.status_code == 200
105+
assert result.request.method == "GET"
106+
assert json.loads(result.text) == json.loads(json_str)
107+
# no real request was made
108+
outgoing_request = httpx_mock.get_requests()
109+
assert not outgoing_request

tests/metadata/fetchers/test_metadata_fetcher.py

Lines changed: 11 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,17 @@ async def test_gen_fetch_data_adapter(self): # type: ignore[no-untyped-def]
2828

2929
@pytest.mark.asyncio
3030
async def test_gen_fetch_ipfs_adapter(self): # type: ignore[no-untyped-def]
31-
fetcher = MetadataFetcher()
31+
fetcher = MetadataFetcher(
32+
async_adapter_configs=[
33+
AdapterConfig(
34+
adapter_cls=IPFSAdapter,
35+
mount_prefixes=[
36+
"ipfs://",
37+
],
38+
host_prefixes=["https://ipfs.decentralized-content.com/ipfs/"],
39+
),
40+
]
41+
)
3242
content = await fetcher.gen_fetch_content(
3343
"ipfs://bafkreiboyxwytfyufln3uzyzaixslzvmrqs5ezjo2cio2fymfqf6u57u6u" # noqa
3444
)

0 commit comments

Comments
 (0)