commit | 5298ef99bf2b2d77600b3bb74dd572027bf495be | [log] [tgz] |
---|---|---|
author | David Benjamin <davidben@google.com> | Fri Mar 13 12:17:30 2020 -0400 |
committer | CQ bot account: commit-bot@chromium.org <commit-bot@chromium.org> | Mon Mar 16 16:45:10 2020 +0000 |
tree | e4bb0202d08499df2e33f9f5987600b0d44baa32 | |
parent | 80ddfc7d1b067da99e8f0e9090c280d7e62ab60c [diff] |
Configure QUIC secrets inside set_{read,write}_state. set_write_state flushes buffered handshake data, and we should finish writing to a level before moving on to the next one. I've moved the callback into set_{read,write}_state to ensure we still update read_level and write_level after installing secrets, since that's how we decide what level to write things and we should never write alerts with keys we don't have. (I believe the only way this can come up is if the QUIC callback itself fails, but it still seems prudent to defer updating the levels.) This does unfortunately mean a goofy secret_for_quic parameter, though it is arguably more "correct" in that QUIC would ideally be a third SSL_PROTOCOL_METHOD, rather than escape hatches over TLS. Probably a cleaner abstraction would be for set_read_state and set_write_state to take the secret and derive an SSLAEADContext internally. Update-Note: See b/151142920#comment9 Change-Id: I4bbb76e15b5d95615ea643bccf796db87fae4989 Reviewed-on: https://boringssl-review.googlesource.com/c/boringssl/+/40244 Commit-Queue: David Benjamin <davidben@google.com> Reviewed-by: Steven Valdez <svaldez@google.com>
BoringSSL is a fork of OpenSSL that is designed to meet Google's needs.
Although BoringSSL is an open source project, it is not intended for general use, as OpenSSL is. We don't recommend that third parties depend upon it. Doing so is likely to be frustrating because there are no guarantees of API or ABI stability.
Programs ship their own copies of BoringSSL when they use it and we update everything as needed when deciding to make API changes. This allows us to mostly avoid compromises in the name of compatibility. It works for us, but it may not work for you.
BoringSSL arose because Google used OpenSSL for many years in various ways and, over time, built up a large number of patches that were maintained while tracking upstream OpenSSL. As Google's product portfolio became more complex, more copies of OpenSSL sprung up and the effort involved in maintaining all these patches in multiple places was growing steadily.
Currently BoringSSL is the SSL library in Chrome/Chromium, Android (but it's not part of the NDK) and a number of other apps/programs.
Project links:
There are other files in this directory which might be helpful: