1. 17 4月, 2018 1 次提交
  2. 29 3月, 2018 1 次提交
  3. 21 3月, 2018 1 次提交
    • M
      Don't wait for dry at the end of a handshake · 424afe93
      Matt Caswell 提交于
      For DTLS/SCTP we were waiting for a dry event during the call to
      tls_finish_handshake(). This function just tidies up various internal
      things, and after it completes the handshake is over. I can find no good
      reason for waiting for a dry event here, and nothing in RFC6083 suggests
      to me that we should need to. More importantly though it seems to be
      wrong. It is perfectly possible for a peer to send app data/alerts/new
      handshake while we are still cleaning up our handshake. If this happens
      then we will never get the dry event and so we cannot continue.
      Reviewed-by: NRich Salz <rsalz@openssl.org>
      (Merged from https://github.com/openssl/openssl/pull/5084)
      424afe93
  4. 15 3月, 2018 1 次提交
  5. 09 2月, 2018 1 次提交
    • M
      Don't calculate the Finished MAC twice · 5d671101
      Matt Caswell 提交于
      In <= TLSv1.2 a Finished message always comes immediately after a CCS
      except in the case of NPN where there is an additional message between
      the CCS and Finished. Historically we always calculated the Finished MAC
      when we processed the CCS. However to deal with NPN we also calculated it
      when we receive the Finished message. Really this should only have been
      done if we hand negotiated NPN.
      
      This simplifies the code to only calculate the MAC when we receive the
      Finished. In 1.1.1 we need to do it this way anyway because there is no
      CCS (except in middlebox compat mode) in TLSv1.3.
      
      Coincidentally, this commit also fixes the fact that no-nextprotoneg does
      not currently work in master.
      Reviewed-by: NAndy Polyakov <appro@openssl.org>
      (Merged from https://github.com/openssl/openssl/pull/5285)
      5d671101
  6. 02 2月, 2018 1 次提交
    • T
      Add TLSv1.3 post-handshake authentication (PHA) · 9d75dce3
      Todd Short 提交于
      Add SSL_verify_client_post_handshake() for servers to initiate PHA
      
      Add SSL_force_post_handshake_auth() for clients that don't have certificates
      initially configured, but use a certificate callback.
      
      Update SSL_CTX_set_verify()/SSL_set_verify() mode:
      
      * Add SSL_VERIFY_POST_HANDSHAKE to postpone client authentication until after
      the initial handshake.
      
      * Update SSL_VERIFY_CLIENT_ONCE now only sends out one CertRequest regardless
      of when the certificate authentication takes place; either initial handshake,
      re-negotiation, or post-handshake authentication.
      
      Add 'RequestPostHandshake' and 'RequirePostHandshake' SSL_CONF options that
      add the SSL_VERIFY_POST_HANDSHAKE to the 'Request' and 'Require' options
      
      Add support to s_client:
      * Enabled automatically when cert is configured
      * Can be forced enabled via -force_pha
      
      Add support to s_server:
      * Use 'c' to invoke PHA in s_server
      * Remove some dead code
      
      Update documentation
      
      Update unit tests:
      * Illegal use of PHA extension
      * TLSv1.3 certificate tests
      
      DTLS and TLS behave ever-so-slightly differently. So, when DTLS1.3 is
      implemented, it's PHA support state machine may need to be different.
      Add a TODO and a #error
      
      Update handshake context to deal with PHA.
      
      The handshake context for TLSv1.3 post-handshake auth is up through the
      ClientFinish message, plus the CertificateRequest message. Subsequent
      Certificate, CertificateVerify, and Finish messages are based on this
      handshake context (not the Certificate message per se, but it's included
      after the hash). KeyUpdate, NewSessionTicket, and prior Certificate
      Request messages are not included in post-handshake authentication.
      
      After the ClientFinished message is processed, save off the digest state
      for future post-handshake authentication. When post-handshake auth occurs,
      copy over the saved handshake context into the "main" handshake digest.
      This effectively discards the any KeyUpdate or NewSessionTicket messages
      and any prior post-handshake authentication.
      
      This, of course, assumes that the ID-22 did not mean to include any
      previous post-handshake authentication into the new handshake transcript.
      This is implied by section 4.4.1 that lists messages only up to the
      first ClientFinished.
      Reviewed-by: NBen Kaduk <kaduk@mit.edu>
      Reviewed-by: NMatt Caswell <matt@openssl.org>
      (Merged from https://github.com/openssl/openssl/pull/4964)
      9d75dce3
  7. 30 1月, 2018 1 次提交
    • M
      Move decisions about whether to accept reneg into the state machine · 3faa07b5
      Matt Caswell 提交于
      If a server receives an unexpected ClientHello then we may or may not
      accept it. Make sure all such decisions are made in the state machine
      and not in the record layer. This also removes a disparity between the
      TLS and the DTLS code. The TLS code was making this decision in the
      record layer, while the DTLS code was making it later.
      
      Finally it also solves a problem where a warning alert was being sent
      during tls_setup_handshake() and the function was returning a failure
      return code. This is problematic because it can be called from a
      transition function - which we only allow fatal errors to occur in.
      Reviewed-by: NRich Salz <rsalz@openssl.org>
      (Merged from https://github.com/openssl/openssl/pull/5190)
      3faa07b5
  8. 25 1月, 2018 2 次提交
  9. 29 12月, 2017 1 次提交
  10. 14 12月, 2017 4 次提交
  11. 04 12月, 2017 5 次提交
  12. 13 11月, 2017 1 次提交
  13. 30 10月, 2017 2 次提交
  14. 18 10月, 2017 1 次提交
  15. 09 10月, 2017 1 次提交
  16. 23 9月, 2017 1 次提交
  17. 01 9月, 2017 1 次提交
  18. 03 8月, 2017 1 次提交
  19. 01 8月, 2017 1 次提交
  20. 13 7月, 2017 2 次提交
  21. 03 7月, 2017 1 次提交
  22. 24 6月, 2017 1 次提交
  23. 21 6月, 2017 4 次提交
  24. 20 6月, 2017 1 次提交
  25. 10 6月, 2017 1 次提交
  26. 07 6月, 2017 1 次提交
  27. 23 5月, 2017 1 次提交