Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for BLAKE hashes in subresource integrity #104

Open
abitrolly opened this issue Aug 23, 2021 · 6 comments
Open

Add support for BLAKE hashes in subresource integrity #104

abitrolly opened this issue Aug 23, 2021 · 6 comments

Comments

@abitrolly
Copy link

BLAKE2 is a cryptographic hash function faster than MD5, SHA-1, SHA-2, and SHA-3, yet is at least as secure as the latest standard SHA-3. BLAKE2 has been adopted by many projects due to its high speed, security, and simplicity.

https://www.blake2.net/

@mozfreddyb
Copy link
Collaborator

Is this about why it wasn't included or is this about what it takes to include it?

Speaking to the former: What's specified as a web standard heavily depends on what browsers agree to implement. Specifically, for a W3C Recommendation, you would need more than two interoperable implementations. When we specified SRI, the blake hash functions were relatively new.

Regarding the latter:
It seems at least Gecko and Blink have an implementation of blake2b. If you want this to happen, you'd need to draft a Pull Request to this repository and write a "Explainer document" (a one-pager, you'll find examples on the web) to discuss the details, especially the merits, the risks and the reason why doing this now is necessary.

This is merely the first step. The implementation doesn't drive itself either, but that's on another page...

In the meantime: I suggest people find and document their non-conforming use of hash functions somewhere that makes it easy to find, so that other hash function names are interoperable and non-colliding.
The current specification text in SRI and the grammar defined in CSP require the hash-digest construct to be separated by just one dash, so an underscore (_) is advised

For the blake family of hash functions I would gently suggest the following prefixes, when used in an SRI-like setting:

  • blake2s._224-
  • blake2s_256-
  • blake2b_384-
  • blake2b_512-
  • blake3-

(Unless there is some other precedent for putting them into a string that shouldn't contain a dash. If so, please tell me and use that instead)

@abitrolly
Copy link
Author

Thanks for the explanation. That's pretty thorough.

Regarding PR for BLAKE inclusion and following the process, I am quite sidetracked already (yakshaveinc/tasks#76), and would rather read the research from someone on a payroll, rather than doing the research myself. It was interesting to discover that such spec exists while I am trying to fit content addressing into handling of Python packages metadata (pypi/warehouse#8254 (comment)). One of the reason for the content addressing to be effective, is to agree on the the hashing function, so that you can validate that your already have the needed file without doing additional lookup which hash function you need to use for the lookup and doing lookups in all hash functions supported.

By the way, the PyPI (Python package index) tends towards sha256=0d87f879a3df4ad9389ab6d63c69eea078517d41541ddd5744cfcff3396e8543 format for integrity info that is embedded in URLs.

Although some projects say that hashes are no content identifiers, I still think they are. Here I would rather see the adoption of https://multiformats.io/multihash/ for the format, because checking integrity and detecting weak checksum algorithms is a task for an automated tool. Maybe there is no need for me to see sha256 or whatever in the URL to compare the checksum manually.

@mozfreddyb
Copy link
Collaborator

Looks like I can close this issue. Any objections?

@abitrolly
Copy link
Author

@mozfreddyb I would rename this to "include BLAKE in the spec". It would be unfair to skip IETF RFC https://datatracker.ietf.org/doc/rfc7693/ just because nobody has time or paid contract to properly follow the process. Maybe I will get back to it in a few months.

@abitrolly
Copy link
Author

For the blake family of hash functions I would gently suggest the following prefixes, when used in an SRI-like setting:

blake2s._224-
blake2s_256-
blake2b_384-
blake2b_512-
blake3-

These are pretty readable on their own.

blake3-
blake2s128-
blake2b384-

@dveditz dveditz changed the title Why BLAKE is not included? Add support for BLAKE hashes in subresource integrity Aug 31, 2021
@abitrolly
Copy link
Author

abitrolly commented Sep 16, 2021

I've created the Gitcoin Grant while for this task BLAKE https://gitcoin.co/grants/3451/add-blake2-into-w3c-sri-spec but there seems to be little interest in anybody in sponsoring this activity. Maybe it is because Ethereum fees are high, maybe people are just don't see the reason when there is IPFS already.

See also #108 that proposes a better format for separating hash name, size and its value, which is relevant here.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants