Mike Hearn [ARCHIVE] on Nostr: 📅 Original date posted:2012-12-03 📝 Original message:> It would also be really ...
📅 Original date posted:2012-12-03
📝 Original message:> It would also be really nice to migrate to textual representations of data
> structures as opposed to binary ones. The most successful internet
> standards are based on text.
There are lots of successful binary protocols: TCP, IP, PNG, JPEG,
MP3, DNS, SSH, SSL, the Bitcoin protocol itself. What's more some
other protocols that are text based have suffered serious problems due
to that choice. Witness the absurd design of SMTP that means you can't
start a paragraph with the word From because that's a new-message
marker! Or the fact that file attachments grow by 33% when you send
them. Or the various exploits that can exist in web servers thanks to
header splitting attacks.
Trying to represent something binary as text doesn't make any sense.
If you look at these data structures they consist of keys, signatures,
hashes, certificates and other fundamentally binary things. You'd just
end up base64 encoding everything anyway, at which point all you've
done is design an inefficient binary protocol that masquerades as
text. The disadvantages of both with the advantages of neither.
Protocol buffers have a text form that you can print to and parse
from, if you so wish, though I only normally see people use that
support for debug prints and sometimes because they want to load
hand-written config files directly into protobuf generated objects.
Published at
2023-06-07 10:42:47Event JSON
{
"id": "38aee6525dd28e9904d45bfcbcf1c37e1bfcd74378388048ef956101cf884917",
"pubkey": "f2c95df3766562e3b96b79a0254881c59e8639f23987846961cf55412a77f6f2",
"created_at": 1686134567,
"kind": 1,
"tags": [
[
"e",
"1bd78b419247dfb60fa2e8b1cf4983b406411160c7aa6e19780a4034c5da34de",
"",
"root"
],
[
"e",
"4b88209ee513eb02fbee32d79957f0383b2092d2c46fd836e9046a65bd7ffe7d",
"",
"reply"
],
[
"p",
"857f2f78dc1639e711f5ea703a9fc978e22ebd279abdea1861b7daa833512ee4"
]
],
"content": "📅 Original date posted:2012-12-03\n📝 Original message:\u003e It would also be really nice to migrate to textual representations of data\n\u003e structures as opposed to binary ones. The most successful internet\n\u003e standards are based on text.\n\nThere are lots of successful binary protocols: TCP, IP, PNG, JPEG,\nMP3, DNS, SSH, SSL, the Bitcoin protocol itself. What's more some\nother protocols that are text based have suffered serious problems due\nto that choice. Witness the absurd design of SMTP that means you can't\nstart a paragraph with the word From because that's a new-message\nmarker! Or the fact that file attachments grow by 33% when you send\nthem. Or the various exploits that can exist in web servers thanks to\nheader splitting attacks.\n\nTrying to represent something binary as text doesn't make any sense.\nIf you look at these data structures they consist of keys, signatures,\nhashes, certificates and other fundamentally binary things. You'd just\nend up base64 encoding everything anyway, at which point all you've\ndone is design an inefficient binary protocol that masquerades as\ntext. The disadvantages of both with the advantages of neither.\n\nProtocol buffers have a text form that you can print to and parse\nfrom, if you so wish, though I only normally see people use that\nsupport for debug prints and sometimes because they want to load\nhand-written config files directly into protobuf generated objects.",
"sig": "f6dcb5993f5e8471f5eb46fb3de61c5f041f417245d89cc6b6fddec6976af86c655f75a6d7a88c7bdce40dd3dc737f327b7bc3104bdf986f6ca905af3c708abb"
}