Skip to content
Snippets Groups Projects
  1. Jun 18, 2015
  2. Jun 17, 2015
    • Daniel Stenberg's avatar
      openssl: fix build with BoringSSL · 46d0eba2
      Daniel Stenberg authored
      OPENSSL_load_builtin_modules does not exist in BoringSSL. Regression
      from cae43a10
      46d0eba2
    • Paul Howarth's avatar
      openssl: Fix build with openssl < ~ 0.9.8f · 4a239862
      Paul Howarth authored
      The symbol SSL3_MT_NEWSESSION_TICKET appears to have been introduced at
      around openssl 0.9.8f, and the use of it in lib/vtls/openssl.c breaks
      builds with older openssls (certainly with 0.9.8b, which is the latest
      older version I have to try with).
      4a239862
    • Jay Satiro's avatar
      schannel: schannel_recv overhaul · 3e7ec1e8
      Jay Satiro authored
      This commit is several drafts squashed together. The changes from each
      draft are noted below. If any changes are similar and possibly
      contradictory the change in the latest draft takes precedence.
      
      Bug: https://github.com/bagder/curl/issues/244
      Reported-by: Chris Araman
      
      %%
      %% Draft 1
      %%
      - return 0 if len == 0. that will have to be documented.
      - continue on and process the caches regardless of raw recv
      - if decrypted data will be returned then set the error code to CURLE_OK
      and return its count
      - if decrypted data will not be returned and the connection has closed
      (eg nread == 0) then return 0 and CURLE_OK
      - if decrypted data will not be returned and the connection *hasn't*
      closed then set the error code to CURLE_AGAIN --only if an error code
      isn't already set-- and return -1
      - narrow the Win2k workaround to only Win2k
      
      %%
      %% Draft 2
      %%
      - Trying out a change in flow to handle corner cases.
      
      %%
      %% Draft 3
      %%
      - Back out the lazier decryption change made in draft2.
      
      %%
      %% Draft 4
      %%
      - Some formatting and branching changes
      - Decrypt all encrypted cached data when len == 0
      - Save connection closed state
      - Change special Win2k check to use connection closed state
      
      %%
      %% Draft 5
      %%
      - Default to CURLE_AGAIN in cleanup if an error code wasn't set and the
      connection isn't closed.
      
      %%
      %% Draft 6
      %%
      - Save the last error only if it is an unrecoverable error.
      
      Prior to this I saved the last error state in all cases; unfortunately
      the logic to cover that in all cases would lead to some muddle and I'm
      concerned that could then lead to a bug in the future so I've replaced
      it by only recording an unrecoverable error and that state will persist.
      
      - Do not recurse on renegotiation.
      
      Instead we'll continue on to process any trailing encrypted data
      received during the renegotiation only.
      
      - Move the err checks in cleanup after the check for decrypted data.
      
      In either case decrypted data is always returned but I think it's easier
      to understand when those err checks come after the decrypted data check.
      
      %%
      %% Draft 7
      %%
      - Regardless of len value go directly to cleanup if there is an
      unrecoverable error or a close_notify was already received. Prior to
      this change we only acknowledged those two states if len != 0.
      
      - Fix a bug in connection closed behavior: Set the error state in the
      cleanup, because we don't know for sure it's an error until that time.
      
      - (Related to above) In the case the connection is closed go "greedy"
      with the decryption to make sure all remaining encrypted data has been
      decrypted even if it is not needed at that time by the caller. This is
      necessary because we can only tell if the connection closed gracefully
      (close_notify) once all encrypted data has been decrypted.
      
      - Do not renegotiate when an unrecoverable error is pending.
      
      %%
      %% Draft 8
      %%
      - Don't show 'server closed the connection' info message twice.
      
      - Show an info message if server closed abruptly (missing close_notify).
      3e7ec1e8
  3. Jun 11, 2015
    • Joel Depooter's avatar
      schannel: Add support for optional client certificates · a3e5a437
      Joel Depooter authored
      Some servers will request a client certificate, but not require one.
      This change allows libcurl to connect to such servers when using
      schannel as its ssl/tls backend. When a server requests a client
      certificate, libcurl will now continue the handshake without one,
      rather than terminating the handshake. The server can then decide
      if that is acceptable or not. Prior to this change, libcurl would
      terminate the handshake, reporting a SEC_I_INCOMPLETE_CREDENTIALS
      error.
      a3e5a437
  4. Jun 09, 2015
  5. Jun 08, 2015
  6. Jun 04, 2015
  7. Jun 01, 2015
    • Jay Satiro's avatar
      curl_setup: Add macros for FOPEN_READTEXT, FOPEN_WRITETEXT · e8423f9c
      Jay Satiro authored
      - Change fopen calls to use FOPEN_READTEXT instead of "r" or "rt"
      - Change fopen calls to use FOPEN_WRITETEXT instead of "w" or "wt"
      
      This change is to explicitly specify when we need to read/write text.
      Unfortunately 't' is not part of POSIX fopen so we can't specify it
      directly. Instead we now have FOPEN_READTEXT, FOPEN_WRITETEXT.
      
      Prior to this change we had an issue on Windows if an application that
      uses libcurl overrides the default file mode to binary. The default file
      mode in Windows is normally text mode (translation mode) and that's what
      libcurl expects.
      
      Bug: https://github.com/bagder/curl/pull/258#issuecomment-107093055
      Reported-by: Orgad Shaneh
      e8423f9c
  8. May 27, 2015
  9. May 20, 2015
  10. May 19, 2015
  11. May 04, 2015
  12. May 02, 2015
  13. May 01, 2015
  14. Apr 30, 2015
  15. Apr 27, 2015
  16. Apr 26, 2015
  17. Apr 22, 2015
  18. Apr 21, 2015
  19. Apr 19, 2015
  20. Apr 17, 2015
  21. Apr 14, 2015
  22. Apr 13, 2015
Loading