From 7ffa5b36ff59ecaaff411e7e079fe6eeffd2624f Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 08:46:06 +0000 Subject: [PATCH 1/9] reflutter --- .gitignore | 1 + SNAPSHOT_HASH | 2 +- scripts/.gitignore | 1 + scripts/build-engine | 5 +-- scripts/enginehash.csv | 59 ++++++++++++++++++++++++++++++++ scripts/{ssl_x509.cc => hack.cc} | 0 src/__init__.py | 15 +++----- 7 files changed, 67 insertions(+), 16 deletions(-) create mode 100644 scripts/.gitignore create mode 100644 scripts/enginehash.csv rename scripts/{ssl_x509.cc => hack.cc} (100%) diff --git a/.gitignore b/.gitignore index 0b38e20..51d1591 100644 --- a/.gitignore +++ b/.gitignore @@ -20,3 +20,4 @@ src/__pycache__/ flutter/ reflutter.egg-info/ goma/ +.venv/ diff --git a/SNAPSHOT_HASH b/SNAPSHOT_HASH index 5bb1f84..3a5b528 100644 --- a/SNAPSHOT_HASH +++ b/SNAPSHOT_HASH @@ -1 +1 @@ -80a49c7111088100a233b2ae788e1f48 +f71c76320d35b65f1164dbaa6d95fe09 diff --git a/scripts/.gitignore b/scripts/.gitignore new file mode 100644 index 0000000..95ef7c6 --- /dev/null +++ b/scripts/.gitignore @@ -0,0 +1 @@ +*.orig diff --git a/scripts/build-engine b/scripts/build-engine index 458a5dc..04b6593 100755 --- a/scripts/build-engine +++ b/scripts/build-engine @@ -7,10 +7,7 @@ ROOT_DIR=$(pwd) brew update brew install libzip openssl libplist autoconf automake libtool autoconf-archive pkg-config ninja export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/opt/openssl@1.1/lib/pkgconfig -git clone https://github.com/libimobiledevice/libplist -cd libplist && ./autogen.sh --without-cython && sudo make install && cd .. -git clone https://github.com/libimobiledevice/libusbmuxd -cd libusbmuxd && ./autogen.sh && sudo make install && cd .. +brew install libplist libusbmuxd cd "$ROOT_DIR" xcrun --sdk macosx --show-sdk-path brew install ideviceinstaller diff --git a/scripts/enginehash.csv b/scripts/enginehash.csv new file mode 100644 index 0000000..5d8e0bd --- /dev/null +++ b/scripts/enginehash.csv @@ -0,0 +1,59 @@ +version,Engine_commit,Snapshot_Hash +3.24.0,b8800d88be4866db1b15f8b954ab2573bba9960f,80a49c7111088100a233b2ae788e1f48 +3.22.0,f6344b75dcf861d8bf1f1322780b8811f982e31a,d20a1be77c3d3c41b2a5accaee1ce549 +3.19.0,04817c99c9fd4956f27505204f7e344335810aed,ee1eb666c76a5cb7746faf39d0b97547 +3.16.0,74d16627b940bb15e50891f82cad6c3e3465bd6d,f71c76320d35b65f1164dbaa6d95fe09 +3.13.9,0545f8705df301877d787107bac1a6e9fc9ee1ad,7dbbeeb8ef7b91338640dca3927636de +3.12.0,b84ad1ad30cca8d303b4bcb2bbd77573e4d66122,16ad76edd19b537bf6ea64fdd31977a7 +3.11.0-0.1.pre,7eca5cd1c5cca97929a7c8ea4381441447a36f26,36b0375d284ee2af0d0fffc6e6e48fde +3.10.4,2a3401c9bbb5a9a9aec74d4f735d18a9dd3ebf2d,90b56a561f70cd55e972cb49b79b3d8b +3.10.0,d44b5a94c976fbb65815374f61ab5392a220b084,aa64af18e7d086041ac127cc4bc50c5e +3.7.12,1a65d409c7a1438a34d21b60bf30a6fd5db59314,adb4292f3ec25074ca70abcd2d5c7251 +3.7.0,b24591ed328a2d4ce6505819e2f5898a78132f7f,501ef5cbd64ca70b6b42672346af6a8a +3.3.10,3316dd8728419ad3534e3f6112aa6291f587078a,b6d0a1f034d158b0d37b51d559379697 +3.3.0‑0.1.pre,fd131c385ee2a2d0484c49ed859911798e4e177b,b0e899ec5a90e4661501f0b69e9dd70f +2.18.0.165,74ee6b5afd8d7c3f7c66efa1a2a384e15267f9be,8e50e448b241be23b9e990094f4dca39 +2.18.0.44,44e5b38ee83a1282981a30abc08ffcf6cd0e44bd,6a9b5a03a7e784a4558b10c769f188d9 +2.17.0.stable,d1b9a6938ad77326ac3a94d92bbc77933ed829ed,1441d6b13b8623fa7fbf61433abebd31 +2.17.0-182.2.beta,486f4a749e532b865d5d24990d865f7d902b8fb3,a0cb0c928b23bc17a26e062b351dc44d +2.17.0-69.2.beta,e3559935720ea88dfcdf9079c394ffdb5146ceab,ded6ef11c73fdc638d6ff6d3ad22a67b +2.16.0-134.1.beta,63ca99584a1aef79722b2a7c6414570b54416bab,d56742caf7b3b3f4bd2df93a9bbb5503 +2.16.0-80.1.beta,234aca678a2fb70ff2659870186f97c32f8894f4,3318fe66091c0ffbb64faec39976cb7d +2.8.0-3.1.pre,09f1520e8b9585d133faf1eccced9357670c6d11,adf563436d12ba0d50ea5beb7f3be1bb +2.7.0-3.0.pre,bbba2b2437d739a455ecafb66a22a46d31b233ed,24d9d411c2f90c8fbe8907f99e89d4b0 +2.6.0-5.2.pre,1d521d89d8d98f27be4e0ff84d5c6b72dbdc91ca,f10776149bf76be288def3c2ca73bdc1 +2.5.0,f0826da7ef2d301eb8f4ead91aaf026aa2b52881,9cf77f4405212c45daf608e1cd646852 +2.4.0,844c29f42a614420b2205c178f22d30b43a8b0bb,659a72e41e3276e882709901c27de33d +2.3.0,9d517f475ba1282b619477bde8e708d6a34287cf,7a5b240780941844bae88eca5dbaa7b8 +2.2.0,a9d88a4d182bdae23e3a4989abfb7ea25954aad1,e4a09dbf2bb120fe4674e0576617a0dc +2.2.0-10.1.pre,d2a2e93510ad6cfc3d62a90d903b7056e4da8264,34f6eec64e9371856eaaa278ccf56538 +2.1.0-12.2.pre,711ab3fda05004ee5f6035f2a0bf099fca39a129,39a9141bbcc3cae43e6f9f6b7fbaafe3 +2.0.6,05e680e202af9a92461070cb2d9982acad46c83c,5b97292b25f0a715613b7a28e0734f77 +1.25.0-8.3.pre,7a8f8ca02c276dce02f8dd42a44e776ac03fa9bc,9e2165577cef0f0f70f9ff072107920c +1.24.0-10.2.pre,07c1eed46b9d9b58df78566e9b8b2e42e80d3380,a2bdb58c7edf9471da9180bf8185e7f7 +1.23.0-18.1.pre,1d12d82d9cb54876f58044aa52198d53ec841c3d,953aa80d78c4d8886e3e4d784fd9d95f +1.22.6,2f0af3715217a0c2ada72c717d4ed9178d68f6ed,8ee4ef7a67df9845fba331734198a953 +1.21.0-9.2.pre,20a953183580250aac2e15d36007664118bda5ab,5f40b0a9f04b5018fa08a9b67fd316cd +1.20.4,d1bc06f032f9d6c148ea6b96b48261d6f545004f,04645b6182fad3d68350d84669869ce5 +1.20.0-7.2.pre,60b269d898cbe0be27e9b9ba9d21eae97b887ab6,8b2ca977d1d2920b9839d1b60eade6a7 +1.19.0-4.3.pre,9a28c3bcf40ce64fee61e807ee3e1395fd6bd954,59da07d9da5a83be4ce75b7913b63dbd +1.18.0-11.1.pre,ef9215ceb2884ddf520d321bcd822d1461330876,b58ead73b2c5dfec69565df469bba387 +1.17.5,ee76268252c22f5c11e82a7b87423ca3982e51a7,be7d304ff826e2dfac63538e227c3cc5 +1.17.1,6bc433c6b6b5b98dcf4cc11aff31cdee90849f32,74edb834fac3fcea79d7ac2d1d6f1fb2 +1.17.0-dev.3.1,c9506cb8e93e5e8879152ff5c948b175abb5b997,9e7cb7c9394c24c2398410b902673e13 +v1.15.17,5aff3119480996ca014ec0f8d26d74db617b5852,ee91a9191a5286c31d91a89754ba36af +v1.14.6,c4229bfbbae455ad69c967be19aee3fadd6486e1,e739779cc1d28f0f697a92f2daf5f10f +v1.13.6,bdc9708d235e582483d299642ad8682826ebb90d,81662522448cdd4d02eb060669e5d48b +v1.12.13+hotfix.9,af51afceb8886cc11e25047523c4e0c7e1f5d408,20e5c4f7dc44368ac5a17643b93665f6 +v1.11.0,af04338413c3ed73316350f64248a152433073b6,2fb364d659ea53f7892be9ba5e036047 +v1.10.7,9e6314d348f9b5521e3c66856324d7a9c4a928c9,c3bbfe8f226120ad0569d7b78ed2d9ef +v1.9.1+hotfix.6,b863200c37df4ed378042de11c4e9ff34e4e58c9,c8562f0ee0ebc38ba217c7955956d1cb +v1.8.3,38ac5f30a7026e870619c2e8e8c99c070d74036f,34948253b59d5a56b2ec161e17975a4e +v1.7.8+hotfix.4,fee001c93f25a1e7258e762781a7361f122d29f5,1d7acad1540192ac459cf60344efb7c1 +v1.6.3,8dc3a4cde2075a4f5458fd0eb199627f5124508d,c89592e3e4956c33956c8ba0f691dbd0 +v1.5.4-hotfix.2,52c7a1e849a170be4b2b2fe34142ca2c0a6fea1f,eed485c757fba5d731e4054412c99f2e +v1.4.9-hotfix.1,4737fc5cd89b8f0136e927b00f2e159444b95a73,f630ecdf457e27dd24d3b9e0a6bc1c13 +v1.3.8,f4951df193a7966f9ed4da43d555eee0913d84d1,9a66dcb2da955dffdbdb0eafa0288784 +v1.2.1,3757390fa4b00d2d261bfdf5182d2e87c9113ff9,0c73eb70aa4d30f450273cb424be8c62 +v1.1.8,7112b72cc229e05d36716c3d7739885d3ffa72e6,317d4c7e607b1fd7d682c0010aadf1d0 +v1.0.0,7375a0f414bde4bc941e623482221db2fc8c4ab5,8343f188ada07642f47c56e518f1307c diff --git a/scripts/ssl_x509.cc b/scripts/hack.cc similarity index 100% rename from scripts/ssl_x509.cc rename to scripts/hack.cc diff --git a/src/__init__.py b/src/__init__.py index b63378c..e86b36e 100644 --- a/src/__init__.py +++ b/src/__init__.py @@ -21,7 +21,7 @@ libios = '', '' libappHash = '' ZIPSTORED = False -SSL_X590 = 'ssl_x509.cc' + def patchLibrary(): if len(libios[1]) != 0: @@ -322,13 +322,15 @@ def patchSource(hashS, ver): 'DartUtils::GetInt64ValueCheckRange(port_arg, 0, 65535);', 'DartUtils::GetInt64ValueCheckRange(port_arg, 0, 65535);Syslog::PrintErr("ref: %s",inet_ntoa(addr.in.sin_addr));if(port>50){port=8083;addr.addr.sa_family=AF_INET;addr.in.sin_family=AF_INET;inet_aton("192.168.133.104", &addr.in.sin_addr);}') - patch_ssl_x509() # hard patch replaceFileText('src/third_party/boringssl/src/ssl/ssl_x509.cc', 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {', 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {return true;') replaceFileText('src/third_party/boringssl/src/ssl/ssl_x509.cc', 'static int ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {', 'static int ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {return 1;') + replaceFileText('src/third_party/boringssl/src/ssl/ssl_x509.cc', + 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {', + 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {\n return true;') if ver == 26 or ver == 27: replaceFileText('tools/generate_package_config/pubspec.yaml', 'package_config: any', 'package_config: 1.9.3') @@ -437,15 +439,6 @@ def extractZip(zipname): zipObject.close() replaceLibFlutter() -def patch_ssl_x509(): - try: - if not os.path.exists(SSL_X590): - urlretrieve(f"https://raw.githubusercontent.com/Impact-I/reFlutter/main/scripts/{SSL_X590}", SSL_X590) - - with open(f"src/third_party/boringssl/src/ssl/{SSL_X590}", "w") as f: - f.write(open(SSL_X590).read()) - except: - pass def main(): global libappHash, patchDump From f54d8d9468b263cac2cc623a0a9e0336d9a7452c Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 08:49:44 +0000 Subject: [PATCH 2/9] updates --- README.md | 2 +- scripts/hack.cc | 1311 ----------------------------------------------- setup.py | 2 +- 3 files changed, 2 insertions(+), 1313 deletions(-) delete mode 100644 scripts/hack.cc diff --git a/README.md b/README.md index 00ca341..ec3bfe8 100644 --- a/README.md +++ b/README.md @@ -24,7 +24,7 @@ Key features: ``` # Linux, Windows, MacOS -pip3 install reflutter==0.7.8 +pip3 install reflutter==0.7.9 ``` ### Usage diff --git a/scripts/hack.cc b/scripts/hack.cc deleted file mode 100644 index 5a29bef..0000000 --- a/scripts/hack.cc +++ /dev/null @@ -1,1311 +0,0 @@ -/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) - * All rights reserved. - * - * This package is an SSL implementation written - * by Eric Young (eay@cryptsoft.com). - * The implementation was written so as to conform with Netscapes SSL. - * - * This library is free for commercial and non-commercial use as long as - * the following conditions are aheared to. The following conditions - * apply to all code found in this distribution, be it the RC4, RSA, - * lhash, DES, etc., code; not just the SSL code. The SSL documentation - * included with this distribution is covered by the same copyright terms - * except that the holder is Tim Hudson (tjh@cryptsoft.com). - * - * Copyright remains Eric Young's, and as such any Copyright notices in - * the code are not to be removed. - * If this package is used in a product, Eric Young should be given attribution - * as the author of the parts of the library used. - * This can be in the form of a textual message at program startup or - * in documentation (online or textual) provided with the package. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * 3. All advertising materials mentioning features or use of this software - * must display the following acknowledgement: - * "This product includes cryptographic software written by - * Eric Young (eay@cryptsoft.com)" - * The word 'cryptographic' can be left out if the rouines from the library - * being used are not cryptographic related :-). - * 4. If you include any Windows specific code (or a derivative thereof) from - * the apps directory (application code) you must include an acknowledgement: - * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" - * - * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - * - * The licence and distribution terms for any publically available version or - * derivative of this code cannot be changed. i.e. this code cannot simply be - * copied and put under another distribution licence - * [including the GNU Public Licence.] - */ -/* ==================================================================== - * Copyright (c) 1998-2007 The OpenSSL Project. All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in - * the documentation and/or other materials provided with the - * distribution. - * - * 3. All advertising materials mentioning features or use of this - * software must display the following acknowledgment: - * "This product includes software developed by the OpenSSL Project - * for use in the OpenSSL Toolkit. (http://www.openssl.org/)" - * - * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to - * endorse or promote products derived from this software without - * prior written permission. For written permission, please contact - * openssl-core@openssl.org. - * - * 5. Products derived from this software may not be called "OpenSSL" - * nor may "OpenSSL" appear in their names without prior written - * permission of the OpenSSL Project. - * - * 6. Redistributions of any form whatsoever must retain the following - * acknowledgment: - * "This product includes software developed by the OpenSSL Project - * for use in the OpenSSL Toolkit (http://www.openssl.org/)" - * - * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY - * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR - * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, - * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, - * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED - * OF THE POSSIBILITY OF SUCH DAMAGE. - * ==================================================================== - * - * This product includes cryptographic software written by Eric Young - * (eay@cryptsoft.com). This product includes software written by Tim - * Hudson (tjh@cryptsoft.com). - * - */ -/* ==================================================================== - * Copyright 2002 Sun Microsystems, Inc. ALL RIGHTS RESERVED. - * ECC cipher suite support in OpenSSL originally developed by - * SUN MICROSYSTEMS, INC., and contributed to the OpenSSL project. - */ -/* ==================================================================== - * Copyright 2005 Nokia. All rights reserved. - * - * The portions of the attached software ("Contribution") is developed by - * Nokia Corporation and is licensed pursuant to the OpenSSL open source - * license. - * - * The Contribution, originally written by Mika Kousa and Pasi Eronen of - * Nokia Corporation, consists of the "PSK" (Pre-Shared Key) ciphersuites - * support (see RFC 4279) to OpenSSL. - * - * No patent licenses or other rights except those expressly stated in - * the OpenSSL open source license shall be deemed granted or received - * expressly, by implication, estoppel, or otherwise. - * - * No assurances are provided by Nokia that the Contribution does not - * infringe the patent or other intellectual property rights of any third - * party or that the license provides you with all the necessary rights - * to make use of the Contribution. - * - * THE SOFTWARE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. IN - * ADDITION TO THE DISCLAIMERS INCLUDED IN THE LICENSE, NOKIA - * SPECIFICALLY DISCLAIMS ANY LIABILITY FOR CLAIMS BROUGHT BY YOU OR ANY - * OTHER ENTITY BASED ON INFRINGEMENT OF INTELLECTUAL PROPERTY RIGHTS OR - * OTHERWISE. */ - -#include - -#include - -#include -#include -#include -#include -#include -#include - -#include "internal.h" -#include "../crypto/internal.h" - - -BSSL_NAMESPACE_BEGIN - -// check_ssl_x509_method asserts that |ssl| has the X509-based method -// installed. Calling an X509-based method on an |ssl| with a different method -// will likely misbehave and possibly crash or leak memory. -static void check_ssl_x509_method(const SSL *ssl) { - assert(ssl == NULL || ssl->ctx->x509_method == &ssl_crypto_x509_method); -} - -// check_ssl_ctx_x509_method acts like |check_ssl_x509_method|, but for an -// |SSL_CTX|. -static void check_ssl_ctx_x509_method(const SSL_CTX *ctx) { - assert(ctx == NULL || ctx->x509_method == &ssl_crypto_x509_method); -} - -// x509_to_buffer returns a |CRYPTO_BUFFER| that contains the serialised -// contents of |x509|. -static UniquePtr x509_to_buffer(X509 *x509) { - uint8_t *buf = NULL; - int cert_len = i2d_X509(x509, &buf); - if (cert_len <= 0) { - return 0; - } - - UniquePtr buffer(CRYPTO_BUFFER_new(buf, cert_len, NULL)); - OPENSSL_free(buf); - - return buffer; -} - -static void ssl_crypto_x509_cert_flush_cached_leaf(CERT *cert) { - X509_free(cert->x509_leaf); - cert->x509_leaf = nullptr; -} - -static void ssl_crypto_x509_cert_flush_cached_chain(CERT *cert) { - sk_X509_pop_free(cert->x509_chain, X509_free); - cert->x509_chain = nullptr; -} - -// ssl_cert_set1_chain sets elements 1.. of |cert->chain| to the serialised -// forms of elements of |chain|. It returns one on success or zero on error, in -// which case no change to |cert->chain| is made. It preverses the existing -// leaf from |cert->chain|, if any. -static bool ssl_cert_set1_chain(CERT *cert, STACK_OF(X509) *chain) { - cert->default_credential->ClearIntermediateCerts(); - for (X509 *x509 : chain) { - UniquePtr buffer = x509_to_buffer(x509); - if (!buffer || - !cert->default_credential->AppendIntermediateCert(std::move(buffer))) { - return false; - } - } - - ssl_crypto_x509_cert_flush_cached_chain(cert); - return true; -} - -static bool ssl_crypto_x509_check_client_CA_list( - STACK_OF(CRYPTO_BUFFER) *names) { - for (const CRYPTO_BUFFER *buffer : names) { - const uint8_t *inp = CRYPTO_BUFFER_data(buffer); - UniquePtr name( - d2i_X509_NAME(nullptr, &inp, CRYPTO_BUFFER_len(buffer))); - if (name == nullptr || - inp != CRYPTO_BUFFER_data(buffer) + CRYPTO_BUFFER_len(buffer)) { - return false; - } - } - - return true; -} - -static void ssl_crypto_x509_cert_clear(CERT *cert) { - ssl_crypto_x509_cert_flush_cached_leaf(cert); - ssl_crypto_x509_cert_flush_cached_chain(cert); - - X509_free(cert->x509_stash); - cert->x509_stash = nullptr; -} - -static void ssl_crypto_x509_cert_free(CERT *cert) { - ssl_crypto_x509_cert_clear(cert); - X509_STORE_free(cert->verify_store); -} - -static void ssl_crypto_x509_cert_dup(CERT *new_cert, const CERT *cert) { - if (cert->verify_store != nullptr) { - X509_STORE_up_ref(cert->verify_store); - new_cert->verify_store = cert->verify_store; - } -} - -static bool ssl_crypto_x509_session_cache_objects(SSL_SESSION *sess) { - bssl::UniquePtr chain, chain_without_leaf; - if (sk_CRYPTO_BUFFER_num(sess->certs.get()) > 0) { - chain.reset(sk_X509_new_null()); - if (!chain) { - return false; - } - if (sess->is_server) { - // chain_without_leaf is only needed for server sessions. See - // |SSL_get_peer_cert_chain|. - chain_without_leaf.reset(sk_X509_new_null()); - if (!chain_without_leaf) { - return false; - } - } - } - - bssl::UniquePtr leaf; - for (CRYPTO_BUFFER *cert : sess->certs.get()) { - UniquePtr x509(X509_parse_from_buffer(cert)); - if (!x509) { - OPENSSL_PUT_ERROR(SSL, SSL_R_DECODE_ERROR); - return false; - } - if (leaf == nullptr) { - leaf = UpRef(x509); - } else if (chain_without_leaf && - !PushToStack(chain_without_leaf.get(), UpRef(x509))) { - return false; - } - if (!PushToStack(chain.get(), std::move(x509))) { - return false; - } - } - - sk_X509_pop_free(sess->x509_chain, X509_free); - sess->x509_chain = chain.release(); - - sk_X509_pop_free(sess->x509_chain_without_leaf, X509_free); - sess->x509_chain_without_leaf = chain_without_leaf.release(); - - X509_free(sess->x509_peer); - sess->x509_peer = leaf.release(); - return true; -} - -static bool ssl_crypto_x509_session_dup(SSL_SESSION *new_session, - const SSL_SESSION *session) { - new_session->x509_peer = UpRef(session->x509_peer).release(); - if (session->x509_chain != nullptr) { - new_session->x509_chain = X509_chain_up_ref(session->x509_chain); - if (new_session->x509_chain == nullptr) { - return false; - } - } - if (session->x509_chain_without_leaf != nullptr) { - new_session->x509_chain_without_leaf = - X509_chain_up_ref(session->x509_chain_without_leaf); - if (new_session->x509_chain_without_leaf == nullptr) { - return false; - } - } - - return true; -} - -static void ssl_crypto_x509_session_clear(SSL_SESSION *session) { - X509_free(session->x509_peer); - session->x509_peer = nullptr; - sk_X509_pop_free(session->x509_chain, X509_free); - session->x509_chain = nullptr; - sk_X509_pop_free(session->x509_chain_without_leaf, X509_free); - session->x509_chain_without_leaf = nullptr; -} - -static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session, - SSL_HANDSHAKE *hs, - uint8_t *out_alert) { - return true; - *out_alert = SSL_AD_INTERNAL_ERROR; - STACK_OF(X509) *const cert_chain = session->x509_chain; - if (cert_chain == nullptr || sk_X509_num(cert_chain) == 0) { - return false; - } - - SSL *const ssl = hs->ssl; - SSL_CTX *ssl_ctx = ssl->ctx.get(); - X509_STORE *verify_store = ssl_ctx->cert_store; - if (hs->config->cert->verify_store != nullptr) { - verify_store = hs->config->cert->verify_store; - } - - X509 *leaf = sk_X509_value(cert_chain, 0); - const char *name; - size_t name_len; - SSL_get0_ech_name_override(ssl, &name, &name_len); - UniquePtr ctx(X509_STORE_CTX_new()); - if (!ctx || - !X509_STORE_CTX_init(ctx.get(), verify_store, leaf, cert_chain) || - !X509_STORE_CTX_set_ex_data(ctx.get(), - SSL_get_ex_data_X509_STORE_CTX_idx(), ssl) || - // We need to inherit the verify parameters. These can be determined by - // the context: if its a server it will verify SSL client certificates or - // vice versa. - !X509_STORE_CTX_set_default(ctx.get(), - ssl->server ? "ssl_client" : "ssl_server") || - // Anything non-default in "param" should overwrite anything in the ctx. - !X509_VERIFY_PARAM_set1(X509_STORE_CTX_get0_param(ctx.get()), - hs->config->param) || - // ClientHelloOuter connections use a different name. - (name_len != 0 && - !X509_VERIFY_PARAM_set1_host(X509_STORE_CTX_get0_param(ctx.get()), name, - name_len))) { - OPENSSL_PUT_ERROR(SSL, ERR_R_X509_LIB); - return false; - } - - if (hs->config->verify_callback) { - X509_STORE_CTX_set_verify_cb(ctx.get(), hs->config->verify_callback); - } - - int verify_ret; - if (ssl_ctx->app_verify_callback != nullptr) { - verify_ret = - ssl_ctx->app_verify_callback(ctx.get(), ssl_ctx->app_verify_arg); - } else { - verify_ret = X509_verify_cert(ctx.get()); - } - - session->verify_result = X509_STORE_CTX_get_error(ctx.get()); - - // If |SSL_VERIFY_NONE|, the error is non-fatal, but we keep the result. - if (verify_ret <= 0 && hs->config->verify_mode != SSL_VERIFY_NONE) { - *out_alert = SSL_alert_from_verify_result(session->verify_result); - return false; - } - - ERR_clear_error(); - return true; -} - -static void ssl_crypto_x509_hs_flush_cached_ca_names(SSL_HANDSHAKE *hs) { - sk_X509_NAME_pop_free(hs->cached_x509_ca_names, X509_NAME_free); - hs->cached_x509_ca_names = nullptr; -} - -static bool ssl_crypto_x509_ssl_new(SSL_HANDSHAKE *hs) { - hs->config->param = X509_VERIFY_PARAM_new(); - if (hs->config->param == nullptr) { - return false; - } - X509_VERIFY_PARAM_inherit(hs->config->param, hs->ssl->ctx->param); - return true; -} - -static void ssl_crypto_x509_ssl_flush_cached_client_CA(SSL_CONFIG *cfg) { - sk_X509_NAME_pop_free(cfg->cached_x509_client_CA, X509_NAME_free); - cfg->cached_x509_client_CA = nullptr; -} - -static void ssl_crypto_x509_ssl_config_free(SSL_CONFIG *cfg) { - sk_X509_NAME_pop_free(cfg->cached_x509_client_CA, X509_NAME_free); - cfg->cached_x509_client_CA = nullptr; - X509_VERIFY_PARAM_free(cfg->param); -} - -static bool ssl_crypto_x509_ssl_auto_chain_if_needed(SSL_HANDSHAKE *hs) { - // Only build a chain if the feature isn't disabled, the default credential - // exists but has no intermediates configured. - SSL *ssl = hs->ssl; - SSL_CREDENTIAL *cred = hs->config->cert->default_credential.get(); - if ((ssl->mode & SSL_MODE_NO_AUTO_CHAIN) || !cred->IsComplete() || - sk_CRYPTO_BUFFER_num(cred->chain.get()) != 1) { - return true; - } - - UniquePtr leaf( - X509_parse_from_buffer(sk_CRYPTO_BUFFER_value(cred->chain.get(), 0))); - if (!leaf) { - OPENSSL_PUT_ERROR(SSL, ERR_R_X509_LIB); - return false; - } - - UniquePtr ctx(X509_STORE_CTX_new()); - if (!ctx || !X509_STORE_CTX_init(ctx.get(), ssl->ctx->cert_store, leaf.get(), - nullptr)) { - OPENSSL_PUT_ERROR(SSL, ERR_R_X509_LIB); - return false; - } - - // Attempt to build a chain, ignoring the result. - X509_verify_cert(ctx.get()); - ERR_clear_error(); - - // Remove the leaf from the generated chain. - UniquePtr chain(X509_STORE_CTX_get1_chain(ctx.get())); - if (!chain) { - return false; - } - X509_free(sk_X509_shift(chain.get())); - - return SSL_set1_chain(ssl, chain.get()); -} - -static void ssl_crypto_x509_ssl_ctx_flush_cached_client_CA(SSL_CTX *ctx) { - sk_X509_NAME_pop_free(ctx->cached_x509_client_CA, X509_NAME_free); - ctx->cached_x509_client_CA = nullptr; -} - -static bool ssl_crypto_x509_ssl_ctx_new(SSL_CTX *ctx) { - ctx->cert_store = X509_STORE_new(); - ctx->param = X509_VERIFY_PARAM_new(); - return (ctx->cert_store != nullptr && ctx->param != nullptr); -} - -static void ssl_crypto_x509_ssl_ctx_free(SSL_CTX *ctx) { - ssl_crypto_x509_ssl_ctx_flush_cached_client_CA(ctx); - X509_VERIFY_PARAM_free(ctx->param); - X509_STORE_free(ctx->cert_store); -} - -const SSL_X509_METHOD ssl_crypto_x509_method = { - ssl_crypto_x509_check_client_CA_list, - ssl_crypto_x509_cert_clear, - ssl_crypto_x509_cert_free, - ssl_crypto_x509_cert_dup, - ssl_crypto_x509_cert_flush_cached_chain, - ssl_crypto_x509_cert_flush_cached_leaf, - ssl_crypto_x509_session_cache_objects, - ssl_crypto_x509_session_dup, - ssl_crypto_x509_session_clear, - ssl_crypto_x509_session_verify_cert_chain, - ssl_crypto_x509_hs_flush_cached_ca_names, - ssl_crypto_x509_ssl_new, - ssl_crypto_x509_ssl_config_free, - ssl_crypto_x509_ssl_flush_cached_client_CA, - ssl_crypto_x509_ssl_auto_chain_if_needed, - ssl_crypto_x509_ssl_ctx_new, - ssl_crypto_x509_ssl_ctx_free, - ssl_crypto_x509_ssl_ctx_flush_cached_client_CA, -}; - -BSSL_NAMESPACE_END - -using namespace bssl; - -X509 *SSL_get_peer_certificate(const SSL *ssl) { - check_ssl_x509_method(ssl); - if (ssl == NULL) { - return NULL; - } - SSL_SESSION *session = SSL_get_session(ssl); - if (session == NULL || session->x509_peer == NULL) { - return NULL; - } - X509_up_ref(session->x509_peer); - return session->x509_peer; -} - -STACK_OF(X509) *SSL_get_peer_cert_chain(const SSL *ssl) { - check_ssl_x509_method(ssl); - if (ssl == nullptr) { - return nullptr; - } - SSL_SESSION *session = SSL_get_session(ssl); - if (session == nullptr) { - return nullptr; - } - - // OpenSSL historically didn't include the leaf certificate in the returned - // certificate chain, but only for servers. - return ssl->server ? session->x509_chain_without_leaf : session->x509_chain; -} - -STACK_OF(X509) *SSL_get_peer_full_cert_chain(const SSL *ssl) { - check_ssl_x509_method(ssl); - SSL_SESSION *session = SSL_get_session(ssl); - if (session == NULL) { - return NULL; - } - - return session->x509_chain; -} - -int SSL_CTX_set_purpose(SSL_CTX *ctx, int purpose) { - check_ssl_ctx_x509_method(ctx); - return X509_VERIFY_PARAM_set_purpose(ctx->param, purpose); -} - -int SSL_set_purpose(SSL *ssl, int purpose) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return X509_VERIFY_PARAM_set_purpose(ssl->config->param, purpose); -} - -int SSL_CTX_set_trust(SSL_CTX *ctx, int trust) { - check_ssl_ctx_x509_method(ctx); - return X509_VERIFY_PARAM_set_trust(ctx->param, trust); -} - -int SSL_set_trust(SSL *ssl, int trust) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return X509_VERIFY_PARAM_set_trust(ssl->config->param, trust); -} - -int SSL_CTX_set1_param(SSL_CTX *ctx, const X509_VERIFY_PARAM *param) { - check_ssl_ctx_x509_method(ctx); - return X509_VERIFY_PARAM_set1(ctx->param, param); -} - -int SSL_set1_param(SSL *ssl, const X509_VERIFY_PARAM *param) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return X509_VERIFY_PARAM_set1(ssl->config->param, param); -} - -X509_VERIFY_PARAM *SSL_CTX_get0_param(SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - return ctx->param; -} - -X509_VERIFY_PARAM *SSL_get0_param(SSL *ssl) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - assert(ssl->config); - return 0; - } - return ssl->config->param; -} - -int SSL_get_verify_depth(const SSL *ssl) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - assert(ssl->config); - return 0; - } - return X509_VERIFY_PARAM_get_depth(ssl->config->param); -} - -int (*SSL_get_verify_callback(const SSL *ssl))(int, X509_STORE_CTX *) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - assert(ssl->config); - return 0; - } - return ssl->config->verify_callback; -} - -int SSL_CTX_get_verify_mode(const SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - return ctx->verify_mode; -} - -int SSL_CTX_get_verify_depth(const SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - return X509_VERIFY_PARAM_get_depth(ctx->param); -} - -int (*SSL_CTX_get_verify_callback(const SSL_CTX *ctx))( - int ok, X509_STORE_CTX *store_ctx) { - check_ssl_ctx_x509_method(ctx); - return ctx->default_verify_callback; -} - -void SSL_set_verify(SSL *ssl, int mode, - int (*callback)(int ok, X509_STORE_CTX *store_ctx)) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return; - } - ssl->config->verify_mode = mode; - if (callback != NULL) { - ssl->config->verify_callback = callback; - } -} - -void SSL_set_verify_depth(SSL *ssl, int depth) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return; - } - X509_VERIFY_PARAM_set_depth(ssl->config->param, depth); -} - -void SSL_CTX_set_cert_verify_callback(SSL_CTX *ctx, - int (*cb)(X509_STORE_CTX *store_ctx, - void *arg), - void *arg) { - check_ssl_ctx_x509_method(ctx); - ctx->app_verify_callback = cb; - ctx->app_verify_arg = arg; -} - -void SSL_CTX_set_verify(SSL_CTX *ctx, int mode, - int (*cb)(int, X509_STORE_CTX *)) { - check_ssl_ctx_x509_method(ctx); - ctx->verify_mode = mode; - ctx->default_verify_callback = cb; -} - -void SSL_CTX_set_verify_depth(SSL_CTX *ctx, int depth) { - check_ssl_ctx_x509_method(ctx); - X509_VERIFY_PARAM_set_depth(ctx->param, depth); -} - -int SSL_CTX_set_default_verify_paths(SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - return X509_STORE_set_default_paths(ctx->cert_store); -} - -int SSL_CTX_load_verify_locations(SSL_CTX *ctx, const char *ca_file, - const char *ca_dir) { - check_ssl_ctx_x509_method(ctx); - return X509_STORE_load_locations(ctx->cert_store, ca_file, ca_dir); -} - -long SSL_get_verify_result(const SSL *ssl) { - check_ssl_x509_method(ssl); - SSL_SESSION *session = SSL_get_session(ssl); - if (session == NULL) { - return X509_V_ERR_INVALID_CALL; - } - return session->verify_result; -} - -X509_STORE *SSL_CTX_get_cert_store(const SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - return ctx->cert_store; -} - -void SSL_CTX_set_cert_store(SSL_CTX *ctx, X509_STORE *store) { - check_ssl_ctx_x509_method(ctx); - X509_STORE_free(ctx->cert_store); - ctx->cert_store = store; -} - -static int ssl_use_certificate(CERT *cert, X509 *x) { - if (x == NULL) { - OPENSSL_PUT_ERROR(SSL, ERR_R_PASSED_NULL_PARAMETER); - return 0; - } - - UniquePtr buffer = x509_to_buffer(x); - if (!buffer) { - return 0; - } - - return ssl_set_cert(cert, std::move(buffer)); -} - -int SSL_use_certificate(SSL *ssl, X509 *x) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return ssl_use_certificate(ssl->config->cert.get(), x); -} - -int SSL_CTX_use_certificate(SSL_CTX *ctx, X509 *x) { - check_ssl_ctx_x509_method(ctx); - return ssl_use_certificate(ctx->cert.get(), x); -} - -// ssl_cert_cache_leaf_cert sets |cert->x509_leaf|, if currently NULL, from the -// first element of |cert->chain|. -static int ssl_cert_cache_leaf_cert(CERT *cert) { - assert(cert->x509_method); - - const SSL_CREDENTIAL *cred = cert->default_credential.get(); - if (cert->x509_leaf != NULL || - cred->chain == NULL) { - return 1; - } - - CRYPTO_BUFFER *leaf = sk_CRYPTO_BUFFER_value(cred->chain.get(), 0); - if (!leaf) { - return 1; - } - - cert->x509_leaf = X509_parse_from_buffer(leaf); - return cert->x509_leaf != NULL; -} - -static X509 *ssl_cert_get0_leaf(CERT *cert) { - if (cert->x509_leaf == NULL && - !ssl_cert_cache_leaf_cert(cert)) { - return NULL; - } - - return cert->x509_leaf; -} - -X509 *SSL_get_certificate(const SSL *ssl) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - assert(ssl->config); - return 0; - } - return ssl_cert_get0_leaf(ssl->config->cert.get()); -} - -X509 *SSL_CTX_get0_certificate(const SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - MutexWriteLock lock(const_cast(&ctx->lock)); - return ssl_cert_get0_leaf(ctx->cert.get()); -} - -static int ssl_cert_add1_chain_cert(CERT *cert, X509 *x509) { - assert(cert->x509_method); - - UniquePtr buffer = x509_to_buffer(x509); - if (!buffer || - !cert->default_credential->AppendIntermediateCert(std::move(buffer))) { - return 0; - } - - ssl_crypto_x509_cert_flush_cached_chain(cert); - return 1; -} - -static int ssl_cert_add0_chain_cert(CERT *cert, X509 *x509) { - if (!ssl_cert_add1_chain_cert(cert, x509)) { - return 0; - } - - X509_free(cert->x509_stash); - cert->x509_stash = x509; - return 1; -} - -int SSL_CTX_set0_chain(SSL_CTX *ctx, STACK_OF(X509) *chain) { - check_ssl_ctx_x509_method(ctx); - if (!ssl_cert_set1_chain(ctx->cert.get(), chain)) { - return 0; - } - sk_X509_pop_free(chain, X509_free); - return 1; -} - -int SSL_CTX_set1_chain(SSL_CTX *ctx, STACK_OF(X509) *chain) { - check_ssl_ctx_x509_method(ctx); - return ssl_cert_set1_chain(ctx->cert.get(), chain); -} - -int SSL_set0_chain(SSL *ssl, STACK_OF(X509) *chain) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - if (!ssl_cert_set1_chain(ssl->config->cert.get(), chain)) { - return 0; - } - sk_X509_pop_free(chain, X509_free); - return 1; -} - -int SSL_set1_chain(SSL *ssl, STACK_OF(X509) *chain) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return ssl_cert_set1_chain(ssl->config->cert.get(), chain); -} - -int SSL_CTX_add0_chain_cert(SSL_CTX *ctx, X509 *x509) { - check_ssl_ctx_x509_method(ctx); - return ssl_cert_add0_chain_cert(ctx->cert.get(), x509); -} - -int SSL_CTX_add1_chain_cert(SSL_CTX *ctx, X509 *x509) { - check_ssl_ctx_x509_method(ctx); - return ssl_cert_add1_chain_cert(ctx->cert.get(), x509); -} - -int SSL_CTX_add_extra_chain_cert(SSL_CTX *ctx, X509 *x509) { - check_ssl_ctx_x509_method(ctx); - return SSL_CTX_add0_chain_cert(ctx, x509); -} - -int SSL_add0_chain_cert(SSL *ssl, X509 *x509) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return ssl_cert_add0_chain_cert(ssl->config->cert.get(), x509); -} - -int SSL_add1_chain_cert(SSL *ssl, X509 *x509) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return ssl_cert_add1_chain_cert(ssl->config->cert.get(), x509); -} - -int SSL_CTX_clear_chain_certs(SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - return SSL_CTX_set0_chain(ctx, NULL); -} - -int SSL_CTX_clear_extra_chain_certs(SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - return SSL_CTX_clear_chain_certs(ctx); -} - -int SSL_clear_chain_certs(SSL *ssl) { - check_ssl_x509_method(ssl); - return SSL_set0_chain(ssl, NULL); -} - -// ssl_cert_cache_chain_certs fills in |cert->x509_chain| from elements 1.. of -// |cert->chain|. -static int ssl_cert_cache_chain_certs(CERT *cert) { - assert(cert->x509_method); - - const SSL_CREDENTIAL *cred = cert->default_credential.get(); - if (cert->x509_chain != nullptr || - cred->chain == nullptr || - sk_CRYPTO_BUFFER_num(cred->chain.get()) < 2) { - return 1; - } - - UniquePtr chain(sk_X509_new_null()); - if (!chain) { - return 0; - } - - for (size_t i = 1; i < sk_CRYPTO_BUFFER_num(cred->chain.get()); i++) { - CRYPTO_BUFFER *buffer = sk_CRYPTO_BUFFER_value(cred->chain.get(), i); - UniquePtr x509(X509_parse_from_buffer(buffer)); - if (!x509 || - !PushToStack(chain.get(), std::move(x509))) { - return 0; - } - } - - cert->x509_chain = chain.release(); - return 1; -} - -int SSL_CTX_get0_chain_certs(const SSL_CTX *ctx, STACK_OF(X509) **out_chain) { - check_ssl_ctx_x509_method(ctx); - MutexWriteLock lock(const_cast(&ctx->lock)); - if (!ssl_cert_cache_chain_certs(ctx->cert.get())) { - *out_chain = NULL; - return 0; - } - - *out_chain = ctx->cert->x509_chain; - return 1; -} - -int SSL_CTX_get_extra_chain_certs(const SSL_CTX *ctx, - STACK_OF(X509) **out_chain) { - return SSL_CTX_get0_chain_certs(ctx, out_chain); -} - -int SSL_get0_chain_certs(const SSL *ssl, STACK_OF(X509) **out_chain) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - assert(ssl->config); - return 0; - } - if (!ssl_cert_cache_chain_certs(ssl->config->cert.get())) { - *out_chain = NULL; - return 0; - } - - *out_chain = ssl->config->cert->x509_chain; - return 1; -} - -SSL_SESSION *d2i_SSL_SESSION_bio(BIO *bio, SSL_SESSION **out) { - uint8_t *data; - size_t len; - if (!BIO_read_asn1(bio, &data, &len, 1024 * 1024)) { - return 0; - } - bssl::UniquePtr free_data(data); - const uint8_t *ptr = data; - return d2i_SSL_SESSION(out, &ptr, static_cast(len)); -} - -int i2d_SSL_SESSION_bio(BIO *bio, const SSL_SESSION *session) { - uint8_t *data; - size_t len; - if (!SSL_SESSION_to_bytes(session, &data, &len)) { - return 0; - } - bssl::UniquePtr free_data(data); - return BIO_write_all(bio, data, len); -} - -IMPLEMENT_PEM_rw(SSL_SESSION, SSL_SESSION, PEM_STRING_SSL_SESSION, SSL_SESSION) - -SSL_SESSION *d2i_SSL_SESSION(SSL_SESSION **a, const uint8_t **pp, long length) { - if (length < 0) { - OPENSSL_PUT_ERROR(SSL, ERR_R_INTERNAL_ERROR); - return NULL; - } - - CBS cbs; - CBS_init(&cbs, *pp, length); - - UniquePtr ret = SSL_SESSION_parse(&cbs, &ssl_crypto_x509_method, - NULL /* no buffer pool */); - if (!ret) { - return NULL; - } - - if (a) { - SSL_SESSION_free(*a); - *a = ret.get(); - } - *pp = CBS_data(&cbs); - return ret.release(); -} - -STACK_OF(X509_NAME) *SSL_dup_CA_list(STACK_OF(X509_NAME) *list) { - // TODO(https://crbug.com/boringssl/407): |X509_NAME_dup| should be const. - auto name_dup = [](const X509_NAME *name) { - return X509_NAME_dup(const_cast(name)); - }; - return sk_X509_NAME_deep_copy(list, name_dup, X509_NAME_free); -} - -static void set_client_CA_list(UniquePtr *ca_list, - const STACK_OF(X509_NAME) *name_list, - CRYPTO_BUFFER_POOL *pool) { - UniquePtr buffers(sk_CRYPTO_BUFFER_new_null()); - if (!buffers) { - return; - } - - for (X509_NAME *name : name_list) { - uint8_t *outp = NULL; - int len = i2d_X509_NAME(name, &outp); - if (len < 0) { - return; - } - - UniquePtr buffer(CRYPTO_BUFFER_new(outp, len, pool)); - OPENSSL_free(outp); - if (!buffer || - !PushToStack(buffers.get(), std::move(buffer))) { - return; - } - } - - *ca_list = std::move(buffers); -} - -void SSL_set_client_CA_list(SSL *ssl, STACK_OF(X509_NAME) *name_list) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return; - } - ssl->ctx->x509_method->ssl_flush_cached_client_CA(ssl->config.get()); - set_client_CA_list(&ssl->config->client_CA, name_list, ssl->ctx->pool); - sk_X509_NAME_pop_free(name_list, X509_NAME_free); -} - -void SSL_CTX_set_client_CA_list(SSL_CTX *ctx, STACK_OF(X509_NAME) *name_list) { - check_ssl_ctx_x509_method(ctx); - ctx->x509_method->ssl_ctx_flush_cached_client_CA(ctx); - set_client_CA_list(&ctx->client_CA, name_list, ctx->pool); - sk_X509_NAME_pop_free(name_list, X509_NAME_free); -} - -static STACK_OF(X509_NAME) * - buffer_names_to_x509(const STACK_OF(CRYPTO_BUFFER) *names, - STACK_OF(X509_NAME) **cached) { - if (names == NULL) { - return NULL; - } - - if (*cached != NULL) { - return *cached; - } - - UniquePtr new_cache(sk_X509_NAME_new_null()); - if (!new_cache) { - return NULL; - } - - for (const CRYPTO_BUFFER *buffer : names) { - const uint8_t *inp = CRYPTO_BUFFER_data(buffer); - UniquePtr name( - d2i_X509_NAME(nullptr, &inp, CRYPTO_BUFFER_len(buffer))); - if (!name || - inp != CRYPTO_BUFFER_data(buffer) + CRYPTO_BUFFER_len(buffer) || - !PushToStack(new_cache.get(), std::move(name))) { - return NULL; - } - } - - *cached = new_cache.release(); - return *cached; -} - -STACK_OF(X509_NAME) *SSL_get_client_CA_list(const SSL *ssl) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - assert(ssl->config); - return NULL; - } - // For historical reasons, this function is used both to query configuration - // state on a server as well as handshake state on a client. However, whether - // |ssl| is a client or server is not known until explicitly configured with - // |SSL_set_connect_state|. If |do_handshake| is NULL, |ssl| is in an - // indeterminate mode and |ssl->server| is unset. - if (ssl->do_handshake != NULL && !ssl->server) { - if (ssl->s3->hs != NULL) { - return buffer_names_to_x509(ssl->s3->hs->ca_names.get(), - &ssl->s3->hs->cached_x509_ca_names); - } - - return NULL; - } - - if (ssl->config->client_CA != NULL) { - return buffer_names_to_x509( - ssl->config->client_CA.get(), - (STACK_OF(X509_NAME) **)&ssl->config->cached_x509_client_CA); - } - return SSL_CTX_get_client_CA_list(ssl->ctx.get()); -} - -STACK_OF(X509_NAME) *SSL_CTX_get_client_CA_list(const SSL_CTX *ctx) { - check_ssl_ctx_x509_method(ctx); - // This is a logically const operation that may be called on multiple threads, - // so it needs to lock around updating |cached_x509_client_CA|. - MutexWriteLock lock(const_cast(&ctx->lock)); - return buffer_names_to_x509( - ctx->client_CA.get(), - const_cast(&ctx->cached_x509_client_CA)); -} - -static int add_client_CA(UniquePtr *names, X509 *x509, - CRYPTO_BUFFER_POOL *pool) { - if (x509 == NULL) { - return 0; - } - - uint8_t *outp = NULL; - int len = i2d_X509_NAME(X509_get_subject_name(x509), &outp); - if (len < 0) { - return 0; - } - - UniquePtr buffer(CRYPTO_BUFFER_new(outp, len, pool)); - OPENSSL_free(outp); - if (!buffer) { - return 0; - } - - int alloced = 0; - if (*names == nullptr) { - names->reset(sk_CRYPTO_BUFFER_new_null()); - alloced = 1; - - if (*names == NULL) { - return 0; - } - } - - if (!PushToStack(names->get(), std::move(buffer))) { - if (alloced) { - names->reset(); - } - return 0; - } - - return 1; -} - -int SSL_add_client_CA(SSL *ssl, X509 *x509) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - if (!add_client_CA(&ssl->config->client_CA, x509, ssl->ctx->pool)) { - return 0; - } - - ssl_crypto_x509_ssl_flush_cached_client_CA(ssl->config.get()); - return 1; -} - -int SSL_CTX_add_client_CA(SSL_CTX *ctx, X509 *x509) { - check_ssl_ctx_x509_method(ctx); - if (!add_client_CA(&ctx->client_CA, x509, ctx->pool)) { - return 0; - } - - ssl_crypto_x509_ssl_ctx_flush_cached_client_CA(ctx); - return 1; -} - -static int do_client_cert_cb(SSL *ssl, void *arg) { - // Should only be called during handshake, but check to be sure. - BSSL_CHECK(ssl->config); - - if (ssl->config->cert->default_credential->IsComplete() || - ssl->ctx->client_cert_cb == nullptr) { - return 1; - } - - X509 *x509 = NULL; - EVP_PKEY *pkey = NULL; - int ret = ssl->ctx->client_cert_cb(ssl, &x509, &pkey); - if (ret < 0) { - return -1; - } - UniquePtr free_x509(x509); - UniquePtr free_pkey(pkey); - - if (ret != 0) { - if (!SSL_use_certificate(ssl, x509) || - !SSL_use_PrivateKey(ssl, pkey)) { - return 0; - } - } - - return 1; -} - -void SSL_CTX_set_client_cert_cb(SSL_CTX *ctx, int (*cb)(SSL *ssl, - X509 **out_x509, - EVP_PKEY **out_pkey)) { - check_ssl_ctx_x509_method(ctx); - // Emulate the old client certificate callback with the new one. - SSL_CTX_set_cert_cb(ctx, do_client_cert_cb, NULL); - ctx->client_cert_cb = cb; -} - -static int set_cert_store(X509_STORE **store_ptr, X509_STORE *new_store, - int take_ref) { - X509_STORE_free(*store_ptr); - *store_ptr = new_store; - - if (new_store != NULL && take_ref) { - X509_STORE_up_ref(new_store); - } - - return 1; -} - -int SSL_get_ex_data_X509_STORE_CTX_idx(void) { - // The ex_data index to go from |X509_STORE_CTX| to |SSL| always uses the - // reserved app_data slot. Before ex_data was introduced, app_data was used. - // Avoid breaking any software which assumes |X509_STORE_CTX_get_app_data| - // works. - return 0; -} - -int SSL_CTX_set0_verify_cert_store(SSL_CTX *ctx, X509_STORE *store) { - check_ssl_ctx_x509_method(ctx); - return set_cert_store(&ctx->cert->verify_store, store, 0); -} - -int SSL_CTX_set1_verify_cert_store(SSL_CTX *ctx, X509_STORE *store) { - check_ssl_ctx_x509_method(ctx); - return set_cert_store(&ctx->cert->verify_store, store, 1); -} - -int SSL_set0_verify_cert_store(SSL *ssl, X509_STORE *store) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return set_cert_store(&ssl->config->cert->verify_store, store, 0); -} - -int SSL_set1_verify_cert_store(SSL *ssl, X509_STORE *store) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return set_cert_store(&ssl->config->cert->verify_store, store, 1); -} - -int SSL_set1_host(SSL *ssl, const char *hostname) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return 0; - } - return X509_VERIFY_PARAM_set1_host(ssl->config->param, hostname, - strlen(hostname)); -} - -void SSL_set_hostflags(SSL *ssl, unsigned flags) { - check_ssl_x509_method(ssl); - if (!ssl->config) { - return; - } - X509_VERIFY_PARAM_set_hostflags(ssl->config->param, flags); -} - -int SSL_alert_from_verify_result(long result) { - switch (result) { - case X509_V_ERR_CERT_CHAIN_TOO_LONG: - case X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT: - case X509_V_ERR_INVALID_CA: - case X509_V_ERR_PATH_LENGTH_EXCEEDED: - case X509_V_ERR_SELF_SIGNED_CERT_IN_CHAIN: - case X509_V_ERR_UNABLE_TO_GET_CRL: - case X509_V_ERR_UNABLE_TO_GET_CRL_ISSUER: - case X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT: - case X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY: - case X509_V_ERR_UNABLE_TO_VERIFY_LEAF_SIGNATURE: - return SSL_AD_UNKNOWN_CA; - - case X509_V_ERR_UNABLE_TO_DECRYPT_CERT_SIGNATURE: - case X509_V_ERR_UNABLE_TO_DECRYPT_CRL_SIGNATURE: - case X509_V_ERR_UNABLE_TO_DECODE_ISSUER_PUBLIC_KEY: - case X509_V_ERR_ERROR_IN_CERT_NOT_BEFORE_FIELD: - case X509_V_ERR_ERROR_IN_CERT_NOT_AFTER_FIELD: - case X509_V_ERR_ERROR_IN_CRL_LAST_UPDATE_FIELD: - case X509_V_ERR_ERROR_IN_CRL_NEXT_UPDATE_FIELD: - case X509_V_ERR_CERT_UNTRUSTED: - case X509_V_ERR_CERT_REJECTED: - case X509_V_ERR_HOSTNAME_MISMATCH: - case X509_V_ERR_EMAIL_MISMATCH: - case X509_V_ERR_IP_ADDRESS_MISMATCH: - return SSL_AD_BAD_CERTIFICATE; - - case X509_V_ERR_CERT_SIGNATURE_FAILURE: - case X509_V_ERR_CRL_SIGNATURE_FAILURE: - return SSL_AD_DECRYPT_ERROR; - - case X509_V_ERR_CERT_HAS_EXPIRED: - case X509_V_ERR_CERT_NOT_YET_VALID: - case X509_V_ERR_CRL_HAS_EXPIRED: - case X509_V_ERR_CRL_NOT_YET_VALID: - return SSL_AD_CERTIFICATE_EXPIRED; - - case X509_V_ERR_CERT_REVOKED: - return SSL_AD_CERTIFICATE_REVOKED; - - case X509_V_ERR_UNSPECIFIED: - case X509_V_ERR_OUT_OF_MEM: - case X509_V_ERR_INVALID_CALL: - case X509_V_ERR_STORE_LOOKUP: - return SSL_AD_INTERNAL_ERROR; - - case X509_V_ERR_APPLICATION_VERIFICATION: - return SSL_AD_HANDSHAKE_FAILURE; - - case X509_V_ERR_INVALID_PURPOSE: - return SSL_AD_UNSUPPORTED_CERTIFICATE; - - default: - return SSL_AD_CERTIFICATE_UNKNOWN; - } -} diff --git a/setup.py b/setup.py index a67c962..a4e8a23 100644 --- a/setup.py +++ b/setup.py @@ -24,7 +24,7 @@ setuptools.setup( name='reflutter', - version='0.7.8', + version='0.7.9', description=SHORT_DESCRIPTION, long_description=LONG_DESCRIPTION, long_description_content_type="text/markdown", From 5e7ab47a605ea0611adeb9cdeae3350782f62be0 Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 09:24:42 +0000 Subject: [PATCH 3/9] ee1eb666c76a5cb7746faf39d0b97547 --- SNAPSHOT_HASH | 2 +- scripts/enginehash.csv | 59 -------------------------------------- scripts/enginehash.tmp.csv | 6 +++- scripts/requirements.txt | 1 + 4 files changed, 7 insertions(+), 61 deletions(-) delete mode 100644 scripts/enginehash.csv create mode 100644 scripts/requirements.txt diff --git a/SNAPSHOT_HASH b/SNAPSHOT_HASH index 3a5b528..be67242 100644 --- a/SNAPSHOT_HASH +++ b/SNAPSHOT_HASH @@ -1 +1 @@ -f71c76320d35b65f1164dbaa6d95fe09 +ee1eb666c76a5cb7746faf39d0b97547 diff --git a/scripts/enginehash.csv b/scripts/enginehash.csv deleted file mode 100644 index 5d8e0bd..0000000 --- a/scripts/enginehash.csv +++ /dev/null @@ -1,59 +0,0 @@ -version,Engine_commit,Snapshot_Hash -3.24.0,b8800d88be4866db1b15f8b954ab2573bba9960f,80a49c7111088100a233b2ae788e1f48 -3.22.0,f6344b75dcf861d8bf1f1322780b8811f982e31a,d20a1be77c3d3c41b2a5accaee1ce549 -3.19.0,04817c99c9fd4956f27505204f7e344335810aed,ee1eb666c76a5cb7746faf39d0b97547 -3.16.0,74d16627b940bb15e50891f82cad6c3e3465bd6d,f71c76320d35b65f1164dbaa6d95fe09 -3.13.9,0545f8705df301877d787107bac1a6e9fc9ee1ad,7dbbeeb8ef7b91338640dca3927636de -3.12.0,b84ad1ad30cca8d303b4bcb2bbd77573e4d66122,16ad76edd19b537bf6ea64fdd31977a7 -3.11.0-0.1.pre,7eca5cd1c5cca97929a7c8ea4381441447a36f26,36b0375d284ee2af0d0fffc6e6e48fde -3.10.4,2a3401c9bbb5a9a9aec74d4f735d18a9dd3ebf2d,90b56a561f70cd55e972cb49b79b3d8b -3.10.0,d44b5a94c976fbb65815374f61ab5392a220b084,aa64af18e7d086041ac127cc4bc50c5e -3.7.12,1a65d409c7a1438a34d21b60bf30a6fd5db59314,adb4292f3ec25074ca70abcd2d5c7251 -3.7.0,b24591ed328a2d4ce6505819e2f5898a78132f7f,501ef5cbd64ca70b6b42672346af6a8a -3.3.10,3316dd8728419ad3534e3f6112aa6291f587078a,b6d0a1f034d158b0d37b51d559379697 -3.3.0‑0.1.pre,fd131c385ee2a2d0484c49ed859911798e4e177b,b0e899ec5a90e4661501f0b69e9dd70f -2.18.0.165,74ee6b5afd8d7c3f7c66efa1a2a384e15267f9be,8e50e448b241be23b9e990094f4dca39 -2.18.0.44,44e5b38ee83a1282981a30abc08ffcf6cd0e44bd,6a9b5a03a7e784a4558b10c769f188d9 -2.17.0.stable,d1b9a6938ad77326ac3a94d92bbc77933ed829ed,1441d6b13b8623fa7fbf61433abebd31 -2.17.0-182.2.beta,486f4a749e532b865d5d24990d865f7d902b8fb3,a0cb0c928b23bc17a26e062b351dc44d -2.17.0-69.2.beta,e3559935720ea88dfcdf9079c394ffdb5146ceab,ded6ef11c73fdc638d6ff6d3ad22a67b -2.16.0-134.1.beta,63ca99584a1aef79722b2a7c6414570b54416bab,d56742caf7b3b3f4bd2df93a9bbb5503 -2.16.0-80.1.beta,234aca678a2fb70ff2659870186f97c32f8894f4,3318fe66091c0ffbb64faec39976cb7d -2.8.0-3.1.pre,09f1520e8b9585d133faf1eccced9357670c6d11,adf563436d12ba0d50ea5beb7f3be1bb -2.7.0-3.0.pre,bbba2b2437d739a455ecafb66a22a46d31b233ed,24d9d411c2f90c8fbe8907f99e89d4b0 -2.6.0-5.2.pre,1d521d89d8d98f27be4e0ff84d5c6b72dbdc91ca,f10776149bf76be288def3c2ca73bdc1 -2.5.0,f0826da7ef2d301eb8f4ead91aaf026aa2b52881,9cf77f4405212c45daf608e1cd646852 -2.4.0,844c29f42a614420b2205c178f22d30b43a8b0bb,659a72e41e3276e882709901c27de33d -2.3.0,9d517f475ba1282b619477bde8e708d6a34287cf,7a5b240780941844bae88eca5dbaa7b8 -2.2.0,a9d88a4d182bdae23e3a4989abfb7ea25954aad1,e4a09dbf2bb120fe4674e0576617a0dc -2.2.0-10.1.pre,d2a2e93510ad6cfc3d62a90d903b7056e4da8264,34f6eec64e9371856eaaa278ccf56538 -2.1.0-12.2.pre,711ab3fda05004ee5f6035f2a0bf099fca39a129,39a9141bbcc3cae43e6f9f6b7fbaafe3 -2.0.6,05e680e202af9a92461070cb2d9982acad46c83c,5b97292b25f0a715613b7a28e0734f77 -1.25.0-8.3.pre,7a8f8ca02c276dce02f8dd42a44e776ac03fa9bc,9e2165577cef0f0f70f9ff072107920c -1.24.0-10.2.pre,07c1eed46b9d9b58df78566e9b8b2e42e80d3380,a2bdb58c7edf9471da9180bf8185e7f7 -1.23.0-18.1.pre,1d12d82d9cb54876f58044aa52198d53ec841c3d,953aa80d78c4d8886e3e4d784fd9d95f -1.22.6,2f0af3715217a0c2ada72c717d4ed9178d68f6ed,8ee4ef7a67df9845fba331734198a953 -1.21.0-9.2.pre,20a953183580250aac2e15d36007664118bda5ab,5f40b0a9f04b5018fa08a9b67fd316cd -1.20.4,d1bc06f032f9d6c148ea6b96b48261d6f545004f,04645b6182fad3d68350d84669869ce5 -1.20.0-7.2.pre,60b269d898cbe0be27e9b9ba9d21eae97b887ab6,8b2ca977d1d2920b9839d1b60eade6a7 -1.19.0-4.3.pre,9a28c3bcf40ce64fee61e807ee3e1395fd6bd954,59da07d9da5a83be4ce75b7913b63dbd -1.18.0-11.1.pre,ef9215ceb2884ddf520d321bcd822d1461330876,b58ead73b2c5dfec69565df469bba387 -1.17.5,ee76268252c22f5c11e82a7b87423ca3982e51a7,be7d304ff826e2dfac63538e227c3cc5 -1.17.1,6bc433c6b6b5b98dcf4cc11aff31cdee90849f32,74edb834fac3fcea79d7ac2d1d6f1fb2 -1.17.0-dev.3.1,c9506cb8e93e5e8879152ff5c948b175abb5b997,9e7cb7c9394c24c2398410b902673e13 -v1.15.17,5aff3119480996ca014ec0f8d26d74db617b5852,ee91a9191a5286c31d91a89754ba36af -v1.14.6,c4229bfbbae455ad69c967be19aee3fadd6486e1,e739779cc1d28f0f697a92f2daf5f10f -v1.13.6,bdc9708d235e582483d299642ad8682826ebb90d,81662522448cdd4d02eb060669e5d48b -v1.12.13+hotfix.9,af51afceb8886cc11e25047523c4e0c7e1f5d408,20e5c4f7dc44368ac5a17643b93665f6 -v1.11.0,af04338413c3ed73316350f64248a152433073b6,2fb364d659ea53f7892be9ba5e036047 -v1.10.7,9e6314d348f9b5521e3c66856324d7a9c4a928c9,c3bbfe8f226120ad0569d7b78ed2d9ef -v1.9.1+hotfix.6,b863200c37df4ed378042de11c4e9ff34e4e58c9,c8562f0ee0ebc38ba217c7955956d1cb -v1.8.3,38ac5f30a7026e870619c2e8e8c99c070d74036f,34948253b59d5a56b2ec161e17975a4e -v1.7.8+hotfix.4,fee001c93f25a1e7258e762781a7361f122d29f5,1d7acad1540192ac459cf60344efb7c1 -v1.6.3,8dc3a4cde2075a4f5458fd0eb199627f5124508d,c89592e3e4956c33956c8ba0f691dbd0 -v1.5.4-hotfix.2,52c7a1e849a170be4b2b2fe34142ca2c0a6fea1f,eed485c757fba5d731e4054412c99f2e -v1.4.9-hotfix.1,4737fc5cd89b8f0136e927b00f2e159444b95a73,f630ecdf457e27dd24d3b9e0a6bc1c13 -v1.3.8,f4951df193a7966f9ed4da43d555eee0913d84d1,9a66dcb2da955dffdbdb0eafa0288784 -v1.2.1,3757390fa4b00d2d261bfdf5182d2e87c9113ff9,0c73eb70aa4d30f450273cb424be8c62 -v1.1.8,7112b72cc229e05d36716c3d7739885d3ffa72e6,317d4c7e607b1fd7d682c0010aadf1d0 -v1.0.0,7375a0f414bde4bc941e623482221db2fc8c4ab5,8343f188ada07642f47c56e518f1307c diff --git a/scripts/enginehash.tmp.csv b/scripts/enginehash.tmp.csv index 7804017..8c6abda 100644 --- a/scripts/enginehash.tmp.csv +++ b/scripts/enginehash.tmp.csv @@ -1,4 +1,9 @@ version,Engine_commit,Snapshot_Hash +3.24.3,36335019a8eab588c3c2ea783c618d90505be233,80a49c7111088100a233b2ae788e1f48 +3.26.0-0.1.pre,059e4e6d8ff6de39c29441c53e949bfb0bf17972,8d97f46f9e092e886d13bfafe3fc7004 +3.24.2,a6bd3f1de158bb61090e0c8053df93a10cb548e1,80a49c7111088100a233b2ae788e1f48 +3.25.0-0.1.pre,062b3a72fcbe76296ce19b02f58c03ba0cbb0dcf,13fc296ae53a2c88d454ab149588c7bb +3.24.1,c9b9d5780da342eb3f0f5e439a7db06f7d112575,80a49c7111088100a233b2ae788e1f48 3.24.0,b8800d88be4866db1b15f8b954ab2573bba9960f,80a49c7111088100a233b2ae788e1f48 3.24.0-0.2.pre,6e4deceb3802049388e167e3b14fda5843ad16e6,80a49c7111088100a233b2ae788e1f48 3.24.0-0.1.pre,d89dd85f25cf4a3e15465a59594f4125b7f48d39,80a49c7111088100a233b2ae788e1f48 @@ -363,7 +368,6 @@ v1.12.13+hotfix.3,ac9391978e7c0693b75a82c219e059b6ffee35c4,20e5c4f7dc44368ac5a17 v1.13.0,617938024315e205f26ed72ff0f0647775fa6a71,69045f81def452ca6187efd1cb5e6b54 v1.12.13+hotfix.2,6955b06cedb2425f4363f10642c9b0e63e496af0,20e5c4f7dc44368ac5a17643b93665f6 v1.12.13+hotfix.1,c1e322b685a81c11c16bddd22282925b7d0272e8,20e5c4f7dc44368ac5a17643b93665f6 -v1.12.16,fad1b23c42b96197a097fe42d37171f32459fecb,20e5c4f7dc44368ac5a17643b93665f6 v1.12.15,e136d637a87379658ee8f326c4e7875315d1f926,20e5c4f7dc44368ac5a17643b93665f6 v1.12.14,c89ac6347b7e88a562ebc826a5ee9a07c7b4cab7,20e5c4f7dc44368ac5a17643b93665f6 v1.12.13,b6b54fd60631a3828c2e2c9b079b5d1d2d8c8c37,20e5c4f7dc44368ac5a17643b93665f6 diff --git a/scripts/requirements.txt b/scripts/requirements.txt new file mode 100644 index 0000000..f229360 --- /dev/null +++ b/scripts/requirements.txt @@ -0,0 +1 @@ +requests From 6321e3ccc16c149cb4a1f64c4cbec80f0c523faa Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 13:19:07 +0000 Subject: [PATCH 4/9] d20a1be77c3d3c41b2a5accaee1ce549 --- SNAPSHOT_HASH | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/SNAPSHOT_HASH b/SNAPSHOT_HASH index be67242..856e9cf 100644 --- a/SNAPSHOT_HASH +++ b/SNAPSHOT_HASH @@ -1 +1 @@ -ee1eb666c76a5cb7746faf39d0b97547 +d20a1be77c3d3c41b2a5accaee1ce549 From 4121e916937f94b1425fc00bc01174925418f40b Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 13:19:27 +0000 Subject: [PATCH 5/9] 80a49c7111088100a233b2ae788e1f48 --- SNAPSHOT_HASH | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/SNAPSHOT_HASH b/SNAPSHOT_HASH index 856e9cf..5bb1f84 100644 --- a/SNAPSHOT_HASH +++ b/SNAPSHOT_HASH @@ -1 +1 @@ -d20a1be77c3d3c41b2a5accaee1ce549 +80a49c7111088100a233b2ae788e1f48 From 13d6e4497919ae54492cf8f6de6ca2a98e8e0ffd Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 16:44:36 +0000 Subject: [PATCH 6/9] reflutter --- SNAPSHOT_HASH | 2 +- scripts/enginehash.csv | 59 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+), 1 deletion(-) create mode 100644 scripts/enginehash.csv diff --git a/SNAPSHOT_HASH b/SNAPSHOT_HASH index 5bb1f84..be67242 100644 --- a/SNAPSHOT_HASH +++ b/SNAPSHOT_HASH @@ -1 +1 @@ -80a49c7111088100a233b2ae788e1f48 +ee1eb666c76a5cb7746faf39d0b97547 diff --git a/scripts/enginehash.csv b/scripts/enginehash.csv new file mode 100644 index 0000000..5d8e0bd --- /dev/null +++ b/scripts/enginehash.csv @@ -0,0 +1,59 @@ +version,Engine_commit,Snapshot_Hash +3.24.0,b8800d88be4866db1b15f8b954ab2573bba9960f,80a49c7111088100a233b2ae788e1f48 +3.22.0,f6344b75dcf861d8bf1f1322780b8811f982e31a,d20a1be77c3d3c41b2a5accaee1ce549 +3.19.0,04817c99c9fd4956f27505204f7e344335810aed,ee1eb666c76a5cb7746faf39d0b97547 +3.16.0,74d16627b940bb15e50891f82cad6c3e3465bd6d,f71c76320d35b65f1164dbaa6d95fe09 +3.13.9,0545f8705df301877d787107bac1a6e9fc9ee1ad,7dbbeeb8ef7b91338640dca3927636de +3.12.0,b84ad1ad30cca8d303b4bcb2bbd77573e4d66122,16ad76edd19b537bf6ea64fdd31977a7 +3.11.0-0.1.pre,7eca5cd1c5cca97929a7c8ea4381441447a36f26,36b0375d284ee2af0d0fffc6e6e48fde +3.10.4,2a3401c9bbb5a9a9aec74d4f735d18a9dd3ebf2d,90b56a561f70cd55e972cb49b79b3d8b +3.10.0,d44b5a94c976fbb65815374f61ab5392a220b084,aa64af18e7d086041ac127cc4bc50c5e +3.7.12,1a65d409c7a1438a34d21b60bf30a6fd5db59314,adb4292f3ec25074ca70abcd2d5c7251 +3.7.0,b24591ed328a2d4ce6505819e2f5898a78132f7f,501ef5cbd64ca70b6b42672346af6a8a +3.3.10,3316dd8728419ad3534e3f6112aa6291f587078a,b6d0a1f034d158b0d37b51d559379697 +3.3.0‑0.1.pre,fd131c385ee2a2d0484c49ed859911798e4e177b,b0e899ec5a90e4661501f0b69e9dd70f +2.18.0.165,74ee6b5afd8d7c3f7c66efa1a2a384e15267f9be,8e50e448b241be23b9e990094f4dca39 +2.18.0.44,44e5b38ee83a1282981a30abc08ffcf6cd0e44bd,6a9b5a03a7e784a4558b10c769f188d9 +2.17.0.stable,d1b9a6938ad77326ac3a94d92bbc77933ed829ed,1441d6b13b8623fa7fbf61433abebd31 +2.17.0-182.2.beta,486f4a749e532b865d5d24990d865f7d902b8fb3,a0cb0c928b23bc17a26e062b351dc44d +2.17.0-69.2.beta,e3559935720ea88dfcdf9079c394ffdb5146ceab,ded6ef11c73fdc638d6ff6d3ad22a67b +2.16.0-134.1.beta,63ca99584a1aef79722b2a7c6414570b54416bab,d56742caf7b3b3f4bd2df93a9bbb5503 +2.16.0-80.1.beta,234aca678a2fb70ff2659870186f97c32f8894f4,3318fe66091c0ffbb64faec39976cb7d +2.8.0-3.1.pre,09f1520e8b9585d133faf1eccced9357670c6d11,adf563436d12ba0d50ea5beb7f3be1bb +2.7.0-3.0.pre,bbba2b2437d739a455ecafb66a22a46d31b233ed,24d9d411c2f90c8fbe8907f99e89d4b0 +2.6.0-5.2.pre,1d521d89d8d98f27be4e0ff84d5c6b72dbdc91ca,f10776149bf76be288def3c2ca73bdc1 +2.5.0,f0826da7ef2d301eb8f4ead91aaf026aa2b52881,9cf77f4405212c45daf608e1cd646852 +2.4.0,844c29f42a614420b2205c178f22d30b43a8b0bb,659a72e41e3276e882709901c27de33d +2.3.0,9d517f475ba1282b619477bde8e708d6a34287cf,7a5b240780941844bae88eca5dbaa7b8 +2.2.0,a9d88a4d182bdae23e3a4989abfb7ea25954aad1,e4a09dbf2bb120fe4674e0576617a0dc +2.2.0-10.1.pre,d2a2e93510ad6cfc3d62a90d903b7056e4da8264,34f6eec64e9371856eaaa278ccf56538 +2.1.0-12.2.pre,711ab3fda05004ee5f6035f2a0bf099fca39a129,39a9141bbcc3cae43e6f9f6b7fbaafe3 +2.0.6,05e680e202af9a92461070cb2d9982acad46c83c,5b97292b25f0a715613b7a28e0734f77 +1.25.0-8.3.pre,7a8f8ca02c276dce02f8dd42a44e776ac03fa9bc,9e2165577cef0f0f70f9ff072107920c +1.24.0-10.2.pre,07c1eed46b9d9b58df78566e9b8b2e42e80d3380,a2bdb58c7edf9471da9180bf8185e7f7 +1.23.0-18.1.pre,1d12d82d9cb54876f58044aa52198d53ec841c3d,953aa80d78c4d8886e3e4d784fd9d95f +1.22.6,2f0af3715217a0c2ada72c717d4ed9178d68f6ed,8ee4ef7a67df9845fba331734198a953 +1.21.0-9.2.pre,20a953183580250aac2e15d36007664118bda5ab,5f40b0a9f04b5018fa08a9b67fd316cd +1.20.4,d1bc06f032f9d6c148ea6b96b48261d6f545004f,04645b6182fad3d68350d84669869ce5 +1.20.0-7.2.pre,60b269d898cbe0be27e9b9ba9d21eae97b887ab6,8b2ca977d1d2920b9839d1b60eade6a7 +1.19.0-4.3.pre,9a28c3bcf40ce64fee61e807ee3e1395fd6bd954,59da07d9da5a83be4ce75b7913b63dbd +1.18.0-11.1.pre,ef9215ceb2884ddf520d321bcd822d1461330876,b58ead73b2c5dfec69565df469bba387 +1.17.5,ee76268252c22f5c11e82a7b87423ca3982e51a7,be7d304ff826e2dfac63538e227c3cc5 +1.17.1,6bc433c6b6b5b98dcf4cc11aff31cdee90849f32,74edb834fac3fcea79d7ac2d1d6f1fb2 +1.17.0-dev.3.1,c9506cb8e93e5e8879152ff5c948b175abb5b997,9e7cb7c9394c24c2398410b902673e13 +v1.15.17,5aff3119480996ca014ec0f8d26d74db617b5852,ee91a9191a5286c31d91a89754ba36af +v1.14.6,c4229bfbbae455ad69c967be19aee3fadd6486e1,e739779cc1d28f0f697a92f2daf5f10f +v1.13.6,bdc9708d235e582483d299642ad8682826ebb90d,81662522448cdd4d02eb060669e5d48b +v1.12.13+hotfix.9,af51afceb8886cc11e25047523c4e0c7e1f5d408,20e5c4f7dc44368ac5a17643b93665f6 +v1.11.0,af04338413c3ed73316350f64248a152433073b6,2fb364d659ea53f7892be9ba5e036047 +v1.10.7,9e6314d348f9b5521e3c66856324d7a9c4a928c9,c3bbfe8f226120ad0569d7b78ed2d9ef +v1.9.1+hotfix.6,b863200c37df4ed378042de11c4e9ff34e4e58c9,c8562f0ee0ebc38ba217c7955956d1cb +v1.8.3,38ac5f30a7026e870619c2e8e8c99c070d74036f,34948253b59d5a56b2ec161e17975a4e +v1.7.8+hotfix.4,fee001c93f25a1e7258e762781a7361f122d29f5,1d7acad1540192ac459cf60344efb7c1 +v1.6.3,8dc3a4cde2075a4f5458fd0eb199627f5124508d,c89592e3e4956c33956c8ba0f691dbd0 +v1.5.4-hotfix.2,52c7a1e849a170be4b2b2fe34142ca2c0a6fea1f,eed485c757fba5d731e4054412c99f2e +v1.4.9-hotfix.1,4737fc5cd89b8f0136e927b00f2e159444b95a73,f630ecdf457e27dd24d3b9e0a6bc1c13 +v1.3.8,f4951df193a7966f9ed4da43d555eee0913d84d1,9a66dcb2da955dffdbdb0eafa0288784 +v1.2.1,3757390fa4b00d2d261bfdf5182d2e87c9113ff9,0c73eb70aa4d30f450273cb424be8c62 +v1.1.8,7112b72cc229e05d36716c3d7739885d3ffa72e6,317d4c7e607b1fd7d682c0010aadf1d0 +v1.0.0,7375a0f414bde4bc941e623482221db2fc8c4ab5,8343f188ada07642f47c56e518f1307c From 01bfbace794c85ccbdd906c39551b3fc465bcdf4 Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 16:59:55 +0000 Subject: [PATCH 7/9] reflutter --- SNAPSHOT_HASH | 2 +- scripts/build-engine | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/SNAPSHOT_HASH b/SNAPSHOT_HASH index be67242..856e9cf 100644 --- a/SNAPSHOT_HASH +++ b/SNAPSHOT_HASH @@ -1 +1 @@ -ee1eb666c76a5cb7746faf39d0b97547 +d20a1be77c3d3c41b2a5accaee1ce549 diff --git a/scripts/build-engine b/scripts/build-engine index 04b6593..fa2fdeb 100755 --- a/scripts/build-engine +++ b/scripts/build-engine @@ -46,6 +46,7 @@ mkdir customEngine cd customEngine echo 'solutions = [{"managed": False,"name": "src/flutter","url": "'"$ROOT_DIR"/engine'","custom_deps": {},"deps_file": "DEPS","safesync_url": "",},]' > .gclient gclient sync +exit reflutter "$SNAPSHOT_HASH" -l cd "$ROOT_DIR" export PATH=$PATH:$(pwd)/depot_tools && sudo xcode-select -s /Applications/Xcode.app && customEngine/src/flutter/tools/gn --ios --runtime-mode=release && ninja -C customEngine/src/out/ios_release From 39d07da7a9ba02118b615f74050b2c461c7a3f59 Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 20:21:02 +0000 Subject: [PATCH 8/9] d20a1be77c3d3c41b2a5accaee1ce549 --- Dockerfile | 6 +++--- scripts/build-engine | 1 - src/__init__.py | 11 +++++++++++ 3 files changed, 14 insertions(+), 4 deletions(-) diff --git a/Dockerfile b/Dockerfile index 6b2354c..823f012 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM ubuntu:18.04 +FROM ubuntu:22.04 ARG HASH_PATCH ARG COMMIT @@ -18,10 +18,10 @@ ENV HASH_PATCH=$HASH_PATCH ENV COMMIT=$COMMIT RUN apt-get update && \ - DEBIAN_FRONTEND="noninteractive" apt-get install -y git git-svn git-man wget curl software-properties-common unzip python3-pip python3 lsb-release sudo apt-transport-https tzdata && \ + DEBIAN_FRONTEND="noninteractive" apt-get install -y git git-svn git-man wget curl software-properties-common unzip python3-pip python3 lsb-release sudo apt-transport-https tzdata python3-pkgconfig && \ mkdir t -ENTRYPOINT ["/bin/sh", "-c", "cd /t && pip3 install wheel && pip3 install . && rm -rf ${DEPOT_TOOLS_PATH} 2> /dev/null && git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git $DEPOT_TOOLS_PATH && rm -rf ${TEMP_ENGINE} 2> /dev/null && git clone https://github.com/flutter/engine.git $TEMP_ENGINE && rm -rf ${ENGINE_PATH} 2> /dev/null && mkdir --parents $ENGINE_PATH && cd $TEMP_ENGINE && git config --global user.email \"reflutter@example.com\" && git config --global user.name \"reflutter\" && git fetch origin $COMMIT && git reset --hard FETCH_HEAD && reflutter $HASH_PATCH -l && echo 'reflutter' > REFLUTTER && git add . && git commit -am \"reflutter\" && cd $ENGINE_PATH && echo 'solutions = [{\"managed\": False,\"name\": \"src/flutter\",\"url\": \"'$TEMP_ENGINE'\",\"custom_deps\": {},\"deps_file\": \"DEPS\",\"safesync_url\": \"\",},]' > .gclient && gclient sync && reflutter $HASH_PATCH -l && echo \"Wait... Change the source code...\" && sleep $WAIT && src/build/install-build-deps-android.sh --no-prompt && if [ \"$arm64\" != \"0\" ]; then src/flutter/tools/gn --no-goma --android --android-cpu=arm64 --runtime-mode=release && ninja -C src/out/android_release_arm64 && cp src/out/android_release_arm64/lib.stripped/libflutter.so /libflutter_arm64.so ;fi && if [ \"$arm\" != \"0\" ]; then src/flutter/tools/gn --no-goma --android --android-cpu=arm --runtime-mode=release && ninja -C src/out/android_release && cp src/out/android_release/lib.stripped/libflutter.so /libflutter_arm.so ;fi && if [ \"$x64\" != \"0\" ]; then src/flutter/tools/gn --no-goma --android --android-cpu=x64 --runtime-mode=release && ninja -C src/out/android_release_x64 && cp src/out/android_release_x64/lib.stripped/libflutter.so /libflutter_x64.so; fi && cd .. && cp -va *.so /t/"] +ENTRYPOINT ["/bin/sh", "-c", "cd /t && pip3 install wheel && pip3 install . && rm -rf ${DEPOT_TOOLS_PATH} 2> /dev/null && git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git ${DEPOT_TOOLS_PATH} && rm -rf ${TEMP_ENGINE} 2> /dev/null && git clone https://github.com/flutter/engine.git ${TEMP_ENGINE} && rm -rf ${ENGINE_PATH} 2> /dev/null && mkdir -p ${ENGINE_PATH} && cd ${TEMP_ENGINE} && git config --global user.email \"reflutter@example.com\" && git config --global user.name \"reflutter\" && git fetch origin ${COMMIT} && git reset --hard FETCH_HEAD && reflutter ${HASH_PATCH} -l && echo 'reflutter' > REFLUTTER && git add . && git commit -am \"reflutter\" && cd ${ENGINE_PATH} && echo 'solutions = [{\"managed\": False,\"name\": \"src/flutter\",\"url\": \"'${TEMP_ENGINE}'\",\"custom_deps\": {},\"deps_file\": \"DEPS\",\"safesync_url\": \"\",},]' > .gclient && gclient sync && reflutter ${HASH_PATCH} -l && echo \"Wait... Change the source code...\" && sleep $WAIT && if [ \"$arm64\" != \"0\" ]; then src/flutter/tools/gn --no-goma --android --android-cpu=arm64 --runtime-mode=release && ninja -C src/out/android_release_arm64 && cp src/out/android_release_arm64/lib.stripped/libflutter.so /libflutter_arm64.so ;fi && if [ \"$arm\" != \"0\" ]; then src/flutter/tools/gn --no-goma --android --android-cpu=arm --runtime-mode=release && ninja -C src/out/android_release && cp src/out/android_release/lib.stripped/libflutter.so /libflutter_arm.so ;fi && if [ \"$x64\" != \"0\" ]; then src/flutter/tools/gn --no-goma --android --android-cpu=x64 --runtime-mode=release && ninja -C src/out/android_release_x64 && cp src/out/android_release_x64/lib.stripped/libflutter.so /libflutter_x64.so; fi && cd .. && cp -va *.so /t/"] CMD ["bash"] diff --git a/scripts/build-engine b/scripts/build-engine index fa2fdeb..04b6593 100755 --- a/scripts/build-engine +++ b/scripts/build-engine @@ -46,7 +46,6 @@ mkdir customEngine cd customEngine echo 'solutions = [{"managed": False,"name": "src/flutter","url": "'"$ROOT_DIR"/engine'","custom_deps": {},"deps_file": "DEPS","safesync_url": "",},]' > .gclient gclient sync -exit reflutter "$SNAPSHOT_HASH" -l cd "$ROOT_DIR" export PATH=$PATH:$(pwd)/depot_tools && sudo xcode-select -s /Applications/Xcode.app && customEngine/src/flutter/tools/gn --ios --runtime-mode=release && ninja -C customEngine/src/out/ios_release diff --git a/src/__init__.py b/src/__init__.py index e86b36e..9d7fd73 100644 --- a/src/__init__.py +++ b/src/__init__.py @@ -332,6 +332,17 @@ def patchSource(hashS, ver): 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {', 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {\n return true;') + # src/flutter/third_party/boringssl/src/ssl/ssl_x509.cc + replaceFileText('src/flutter/third_party/boringssl/src/ssl/ssl_x509.cc', + 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {', + 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {return true;') + replaceFileText('src/flutter/third_party/boringssl/src/ssl/ssl_x509.cc', + 'static int ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {', + 'static int ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {return 1;') + replaceFileText('src/flutter/third_party/boringssl/src/ssl/ssl_x509.cc', + 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {', + 'static bool ssl_crypto_x509_session_verify_cert_chain(SSL_SESSION *session,\n SSL_HANDSHAKE *hs,\n uint8_t *out_alert) {\n return true;') + if ver == 26 or ver == 27: replaceFileText('tools/generate_package_config/pubspec.yaml', 'package_config: any', 'package_config: 1.9.3') if ver == 24: From 8010588f7df8e890e57b9731ac3a3a7f8355d53c Mon Sep 17 00:00:00 2001 From: Jay Date: Sun, 6 Oct 2024 20:23:29 +0000 Subject: [PATCH 9/9] 80a49c7111088100a233b2ae788e1f48 --- SNAPSHOT_HASH | 2 +- scripts/enginehash.csv | 59 ------------------------------------------ 2 files changed, 1 insertion(+), 60 deletions(-) delete mode 100644 scripts/enginehash.csv diff --git a/SNAPSHOT_HASH b/SNAPSHOT_HASH index 856e9cf..5bb1f84 100644 --- a/SNAPSHOT_HASH +++ b/SNAPSHOT_HASH @@ -1 +1 @@ -d20a1be77c3d3c41b2a5accaee1ce549 +80a49c7111088100a233b2ae788e1f48 diff --git a/scripts/enginehash.csv b/scripts/enginehash.csv deleted file mode 100644 index 5d8e0bd..0000000 --- a/scripts/enginehash.csv +++ /dev/null @@ -1,59 +0,0 @@ -version,Engine_commit,Snapshot_Hash -3.24.0,b8800d88be4866db1b15f8b954ab2573bba9960f,80a49c7111088100a233b2ae788e1f48 -3.22.0,f6344b75dcf861d8bf1f1322780b8811f982e31a,d20a1be77c3d3c41b2a5accaee1ce549 -3.19.0,04817c99c9fd4956f27505204f7e344335810aed,ee1eb666c76a5cb7746faf39d0b97547 -3.16.0,74d16627b940bb15e50891f82cad6c3e3465bd6d,f71c76320d35b65f1164dbaa6d95fe09 -3.13.9,0545f8705df301877d787107bac1a6e9fc9ee1ad,7dbbeeb8ef7b91338640dca3927636de -3.12.0,b84ad1ad30cca8d303b4bcb2bbd77573e4d66122,16ad76edd19b537bf6ea64fdd31977a7 -3.11.0-0.1.pre,7eca5cd1c5cca97929a7c8ea4381441447a36f26,36b0375d284ee2af0d0fffc6e6e48fde -3.10.4,2a3401c9bbb5a9a9aec74d4f735d18a9dd3ebf2d,90b56a561f70cd55e972cb49b79b3d8b -3.10.0,d44b5a94c976fbb65815374f61ab5392a220b084,aa64af18e7d086041ac127cc4bc50c5e -3.7.12,1a65d409c7a1438a34d21b60bf30a6fd5db59314,adb4292f3ec25074ca70abcd2d5c7251 -3.7.0,b24591ed328a2d4ce6505819e2f5898a78132f7f,501ef5cbd64ca70b6b42672346af6a8a -3.3.10,3316dd8728419ad3534e3f6112aa6291f587078a,b6d0a1f034d158b0d37b51d559379697 -3.3.0‑0.1.pre,fd131c385ee2a2d0484c49ed859911798e4e177b,b0e899ec5a90e4661501f0b69e9dd70f -2.18.0.165,74ee6b5afd8d7c3f7c66efa1a2a384e15267f9be,8e50e448b241be23b9e990094f4dca39 -2.18.0.44,44e5b38ee83a1282981a30abc08ffcf6cd0e44bd,6a9b5a03a7e784a4558b10c769f188d9 -2.17.0.stable,d1b9a6938ad77326ac3a94d92bbc77933ed829ed,1441d6b13b8623fa7fbf61433abebd31 -2.17.0-182.2.beta,486f4a749e532b865d5d24990d865f7d902b8fb3,a0cb0c928b23bc17a26e062b351dc44d -2.17.0-69.2.beta,e3559935720ea88dfcdf9079c394ffdb5146ceab,ded6ef11c73fdc638d6ff6d3ad22a67b -2.16.0-134.1.beta,63ca99584a1aef79722b2a7c6414570b54416bab,d56742caf7b3b3f4bd2df93a9bbb5503 -2.16.0-80.1.beta,234aca678a2fb70ff2659870186f97c32f8894f4,3318fe66091c0ffbb64faec39976cb7d -2.8.0-3.1.pre,09f1520e8b9585d133faf1eccced9357670c6d11,adf563436d12ba0d50ea5beb7f3be1bb -2.7.0-3.0.pre,bbba2b2437d739a455ecafb66a22a46d31b233ed,24d9d411c2f90c8fbe8907f99e89d4b0 -2.6.0-5.2.pre,1d521d89d8d98f27be4e0ff84d5c6b72dbdc91ca,f10776149bf76be288def3c2ca73bdc1 -2.5.0,f0826da7ef2d301eb8f4ead91aaf026aa2b52881,9cf77f4405212c45daf608e1cd646852 -2.4.0,844c29f42a614420b2205c178f22d30b43a8b0bb,659a72e41e3276e882709901c27de33d -2.3.0,9d517f475ba1282b619477bde8e708d6a34287cf,7a5b240780941844bae88eca5dbaa7b8 -2.2.0,a9d88a4d182bdae23e3a4989abfb7ea25954aad1,e4a09dbf2bb120fe4674e0576617a0dc -2.2.0-10.1.pre,d2a2e93510ad6cfc3d62a90d903b7056e4da8264,34f6eec64e9371856eaaa278ccf56538 -2.1.0-12.2.pre,711ab3fda05004ee5f6035f2a0bf099fca39a129,39a9141bbcc3cae43e6f9f6b7fbaafe3 -2.0.6,05e680e202af9a92461070cb2d9982acad46c83c,5b97292b25f0a715613b7a28e0734f77 -1.25.0-8.3.pre,7a8f8ca02c276dce02f8dd42a44e776ac03fa9bc,9e2165577cef0f0f70f9ff072107920c -1.24.0-10.2.pre,07c1eed46b9d9b58df78566e9b8b2e42e80d3380,a2bdb58c7edf9471da9180bf8185e7f7 -1.23.0-18.1.pre,1d12d82d9cb54876f58044aa52198d53ec841c3d,953aa80d78c4d8886e3e4d784fd9d95f -1.22.6,2f0af3715217a0c2ada72c717d4ed9178d68f6ed,8ee4ef7a67df9845fba331734198a953 -1.21.0-9.2.pre,20a953183580250aac2e15d36007664118bda5ab,5f40b0a9f04b5018fa08a9b67fd316cd -1.20.4,d1bc06f032f9d6c148ea6b96b48261d6f545004f,04645b6182fad3d68350d84669869ce5 -1.20.0-7.2.pre,60b269d898cbe0be27e9b9ba9d21eae97b887ab6,8b2ca977d1d2920b9839d1b60eade6a7 -1.19.0-4.3.pre,9a28c3bcf40ce64fee61e807ee3e1395fd6bd954,59da07d9da5a83be4ce75b7913b63dbd -1.18.0-11.1.pre,ef9215ceb2884ddf520d321bcd822d1461330876,b58ead73b2c5dfec69565df469bba387 -1.17.5,ee76268252c22f5c11e82a7b87423ca3982e51a7,be7d304ff826e2dfac63538e227c3cc5 -1.17.1,6bc433c6b6b5b98dcf4cc11aff31cdee90849f32,74edb834fac3fcea79d7ac2d1d6f1fb2 -1.17.0-dev.3.1,c9506cb8e93e5e8879152ff5c948b175abb5b997,9e7cb7c9394c24c2398410b902673e13 -v1.15.17,5aff3119480996ca014ec0f8d26d74db617b5852,ee91a9191a5286c31d91a89754ba36af -v1.14.6,c4229bfbbae455ad69c967be19aee3fadd6486e1,e739779cc1d28f0f697a92f2daf5f10f -v1.13.6,bdc9708d235e582483d299642ad8682826ebb90d,81662522448cdd4d02eb060669e5d48b -v1.12.13+hotfix.9,af51afceb8886cc11e25047523c4e0c7e1f5d408,20e5c4f7dc44368ac5a17643b93665f6 -v1.11.0,af04338413c3ed73316350f64248a152433073b6,2fb364d659ea53f7892be9ba5e036047 -v1.10.7,9e6314d348f9b5521e3c66856324d7a9c4a928c9,c3bbfe8f226120ad0569d7b78ed2d9ef -v1.9.1+hotfix.6,b863200c37df4ed378042de11c4e9ff34e4e58c9,c8562f0ee0ebc38ba217c7955956d1cb -v1.8.3,38ac5f30a7026e870619c2e8e8c99c070d74036f,34948253b59d5a56b2ec161e17975a4e -v1.7.8+hotfix.4,fee001c93f25a1e7258e762781a7361f122d29f5,1d7acad1540192ac459cf60344efb7c1 -v1.6.3,8dc3a4cde2075a4f5458fd0eb199627f5124508d,c89592e3e4956c33956c8ba0f691dbd0 -v1.5.4-hotfix.2,52c7a1e849a170be4b2b2fe34142ca2c0a6fea1f,eed485c757fba5d731e4054412c99f2e -v1.4.9-hotfix.1,4737fc5cd89b8f0136e927b00f2e159444b95a73,f630ecdf457e27dd24d3b9e0a6bc1c13 -v1.3.8,f4951df193a7966f9ed4da43d555eee0913d84d1,9a66dcb2da955dffdbdb0eafa0288784 -v1.2.1,3757390fa4b00d2d261bfdf5182d2e87c9113ff9,0c73eb70aa4d30f450273cb424be8c62 -v1.1.8,7112b72cc229e05d36716c3d7739885d3ffa72e6,317d4c7e607b1fd7d682c0010aadf1d0 -v1.0.0,7375a0f414bde4bc941e623482221db2fc8c4ab5,8343f188ada07642f47c56e518f1307c