Skip to content
  1. Dec 04, 2014
    • Peter Wu's avatar
      libcurl: add UNIX domain sockets support · 970c22f9
      Peter Wu authored
      The ability to do HTTP requests over a UNIX domain socket has been
      requested before, in Apr 2008 [0][1] and Sep 2010 [2]. While a
      discussion happened, no patch seems to get through. I decided to give it
      a go since I need to test a nginx HTTP server which listens on a UNIX
      domain socket.
      
      One patch [3] seems to make it possible to use the
      CURLOPT_OPENSOCKETFUNCTION function to gain a UNIX domain socket.
      Another person wrote a Go program which can do HTTP over a UNIX socket
      for Docker[4] which uses a special URL scheme (though the name contains
      cURL, it has no relation to the cURL library).
      
      This patch considers support for UNIX domain sockets at the same level
      as HTTP proxies / IPv6, it acts as an intermediate socket provider and
      not as a separate protocol. Since this feature affects network
      operations, a new feature flag was added ("unix-sockets") with a
      corresponding CURL_VERSION_UNIX_SOCKETS macro.
      
      A new CURLOPT_UNIX_SOCKET_PATH option is added and documented. This
      option enables UNIX domain sockets support for all requests on the
      handle (replacing IP sockets and skipping proxies).
      
      A new configure option (--enable-unix-sockets) and CMake option
      (ENABLE_UNIX_SOCKETS) can disable this optional feature. Note that I
      deliberately did not mark this feature as advanced, this is a
      feature/component that should easily be available.
      
       [0]: http://curl.haxx.se/mail/lib-2008-04/0279.html
       [1]: http://daniel.haxx.se/blog/2008/04/14/http-over-unix-domain-sockets/
       [2]: http://sourceforge.net/p/curl/feature-requests/53/
       [3]: http://curl.haxx.se/mail/lib-2008-04/0361.html
       [4]: https://github.com/Soulou/curl-unix-socket
      
      
      
      Signed-off-by: default avatarPeter Wu <peter@lekensteyn.nl>
      970c22f9
  2. Dec 03, 2014
  3. Dec 02, 2014
  4. Dec 01, 2014
  5. Nov 30, 2014
    • Peter Wu's avatar
      lib/connect: restrict IP/TCP options to said sockets · aba5888f
      Peter Wu authored
      
      
      This patch prepares for adding UNIX domain sockets support.
      
      TCP_NODELAY and TCP_KEEPALIVE are specific to TCP/IP sockets, so do not
      apply these to other socket types. bindlocal only works for IP sockets
      (independent of TCP/UDP), so filter that out too for other types.
      
      Signed-off-by: default avatarPeter Wu <peter@lekensteyn.nl>
      aba5888f
    • Daniel Stenberg's avatar
      smb.c: use size_t as input argument types for msg sizes · 397a634e
      Daniel Stenberg authored
      This fixes warnings about conversions to int
      397a634e
    • Steve Holme's avatar
      smb.c: Fixed compilation warnings · 6b8e5c0e
      Steve Holme authored
      smb.c:398: warning: comparison of integers of different signs:
                 'ssize_t' (aka 'long') and 'unsigned long'
      smb.c:443: warning: comparison of integers of different signs:
                 'ssize_t' (aka 'long') and 'unsigned long'
      6b8e5c0e
    • Steve Holme's avatar
      libcurl: Exclude SMB from the protocol redirect · ce2d84b3
      Steve Holme authored
      As local files could be accessed through \\localhost\c$.
      ce2d84b3
    • Bill Nagel's avatar
      libcurl: Enable support for the SMB protocol · 6f241934
      Bill Nagel authored
      This patch enables SMB/CIFS support in libcurl.
      6f241934
    • Steve Holme's avatar
      smb.c: Fixed compilation warnings · d95cb3ed
      Steve Holme authored
      smb.c:322: warning: conversion to 'short unsigned int' from 'unsigned
                 int' may alter its value
      smb.c:323: warning: conversion to 'short unsigned int' from 'unsigned
                 int' may alter its value
      smb.c:482: warning: conversion to 'short unsigned int' from 'int' may
                 alter its value
      smb.c:521: warning: conversion to 'unsigned int' from 'curl_off_t' may
                 alter its value
      smb.c:549: warning: conversion to 'unsigned int' from 'curl_off_t' may
                 alter its value
      smb.c:550: warning: conversion to 'short unsigned int' from 'int' may
                 alter its value
      d95cb3ed
    • Steve Holme's avatar
      smb.c: Renamed SMB command message variables to avoid compiler warnings · 99c2bad2
      Steve Holme authored
      smb.c:489: warning: declaration of 'close' shadows a global declaration
      smb.c:511: warning: declaration of 'read' shadows a global declaration
      smb.c:528: warning: declaration of 'write' shadows a global declaration
      99c2bad2
    • Steve Holme's avatar
      smb.c: Fixed compilation warnings · 069f63c8
      Steve Holme authored
      smb.c:212: warning: unused parameter 'done'
      smb.c:380: warning: ISO C does not allow extra ';' outside of a function
      smb.c:812: warning: unused parameter 'premature'
      smb.c:822: warning: unused parameter 'dead'
      069f63c8
    • Steve Holme's avatar
      smb.c: Fixed compilation warnings · 676f79f8
      Steve Holme authored
      smb.c:311: warning: conversion from 'unsigned __int64' to 'u_short',
                 possible loss of data
      smb.c:425: warning: conversion from '__int64' to 'unsigned short',
                 possible loss of data
      smb.c:452: warning: conversion from '__int64' to 'unsigned short',
                 possible loss of data
      676f79f8
    • Steve Holme's avatar
      smb.c: Fixed compilation warnings · cef28131
      Steve Holme authored
      smb.c:162: error: comma at end of enumerator list
      smb.c:469: warning: conversion from 'size_t' to 'unsigned short',
                 possible loss of data
      smb.c:517: warning: conversion from 'curl_off_t' to 'unsigned int',
                 possible loss of data
      smb.c:545: warning: conversion from 'curl_off_t' to 'unsigned int',
                 possible loss of data
      cef28131
    • Bill Nagel's avatar
      smb: Added initial SMB functionality · 02d2c0a0
      Bill Nagel authored
      Initial implementation of the SMB/CIFS protocol.
      02d2c0a0
    • Bill Nagel's avatar
      smb: Added SMB handler interfaces · aec2e865
      Bill Nagel authored
      Added the SMB and SMBS handler interface structures and associated
      functions required for SMB/CIFS operation.
      aec2e865
    • Steve Holme's avatar
      transfer: Code style policing · 56120ca0
      Steve Holme authored
      Prefer ! rather than NULL in if statements, added comments and updated
      function spacing, argument spacing and line spacing to be more readble.
      56120ca0
    • Steve Holme's avatar
      transfer: Fixed existing scratch buffer being checked for NULL twice · 785d76d6
      Steve Holme authored
      If the scratch buffer already existed when the CRLF conversion was
      performed then the buffer pointer would be checked twice for NULL. This
      second check is only necessary if the call to malloc() was performed by
      the first check.
      785d76d6
    • Steve Holme's avatar
      smtp: Fixed dot stuffing being performed when no new data read · 9afd9702
      Steve Holme authored
      Whilst I had moved the dot stuffing code from being performed before
      CRLF conversion takes place to after it, in commit 4bd860a0, I had
      moved it outside the 'when something read' block of code when meant
      it could perform the dot stuffing twice on partial send if nread
      happened to contain the right values. It also meant the function could
      potentially read past the end of buffer. This was highlighted by the
      following warning:
      
      warning: `nread' might be used uninitialized in this function
      9afd9702
  6. Nov 29, 2014
  7. Nov 27, 2014
  8. Nov 26, 2014
  9. Nov 25, 2014
  10. Nov 24, 2014
  11. Nov 23, 2014