5 \___|\___/|_| \_\_____|
7 How cURL Became Like This
10 In the second half of 1997, Daniel Stenberg came up with the idea to make
11 currency-exchange calculations available to Internet Relay Chat (IRC)
12 users. All the necessary data are published on the Web; he just needed to
13 automate their retrieval.
15 Daniel simply adopted an existing command-line open-source tool, httpget, that
16 Brazilian Rafael Sagula had written. After a few minor adjustments, it did
19 Soon, he found currencies on a GOPHER site, so support for that had to go in,
20 and not before long FTP download support was added as well. The name of the
21 project was changed to urlget to better fit what it actually did now, since
22 the http-only days were already passed.
24 The project slowly grew bigger. When upload capabilities were added and the
25 name once again was misleading, a second name change was made and on March 20,
26 1998 curl 4 was released. (The version numbering from the previous names was
29 (Unrelated to this project a company called Curl Corporation registered a US
30 trademark on the name "CURL" on May 18 1998. That company had then already
31 registered the curl.com domain back in November of the previous year. All this
32 was revealed to us much later.)
34 SSL support was added, powered by the SSLeay library.
36 August 1998, first announcement of curl on freshmeat.net.
38 October 1998, with the curl 4.9 release and the introduction of cookie
39 support, curl was no longer released under the GPL license. Now we're at 4000
40 lines of code, we switched over to the MPL license to restrict the effects of
43 November 1998, configure script and reported successful compiles on several
44 major operating systems. The never-quite-understood -F option was added and
45 curl could now simulate quite a lot of a browser. TELNET support was added.
47 Curl 5 was released in December 1998 and introduced the first ever curl man
48 page. People started making Linux RPM packages out of it.
50 January 1999, DICT support added.
52 OpenSSL took over where SSLeay was abandoned.
54 May 1999, first Debian package.
56 August 1999, LDAP:// and FILE:// support added. The curl web site gets 1300
59 Released curl 6.0 in September. 15000 lines of code.
61 December 28 1999, added the project on Sourceforge and started using its
62 services for managing the project.
64 Spring 2000, major internal overhaul to provide a suitable library interface.
65 The first non-beta release was named 7.1 and arrived in August. This offered
66 the easy interface and turned out to be the beginning of actually getting
67 other software and programs to get based on and powered by libcurl. Almost
70 August 2000, the curl web site gets 4000 visits weekly.
72 The PHP guys adopted libcurl already the same month, when the first ever third
73 party libcurl binding showed up. CURL has been a supported module in PHP since
74 the release of PHP 4.0.2. This would soon get followers. More than 16
75 different bindings exist at the time of this writing.
77 September 2000, kerberos4 support was added.
79 In November 2000 started the work on a test suite for curl. It was later
80 re-written from scratch again. The libcurl major SONAME number was set to 1.
82 January 2001, Daniel released curl 7.5.2 under a new license again: MIT (or
83 MPL). The MIT license is extremely liberal and can be used combined with GPL
84 in other projects. This would finally put an end to the "complaints" from
85 people involved in GPLed projects that previously were prohibited from using
86 libcurl while it was released under MPL only. (Due to the fact that MPL is
87 deemed "GPL incompatible".)
89 curl supports HTTP 1.1 starting with the release of 7.7, March 22 2001. This
90 also introduced libcurl's ability to do persistent connections. 24000 lines of
91 code. The libcurl major SONAME number was bumped to 2 due to this overhaul.
93 The first experimental ftps:// support was added in March 2001.
95 August 2001. curl is bundled in Mac OS X, 10.1. It was already becoming more
96 and more of a standard utility of Linux distributions and a regular in the BSD
97 ports collections. The curl web site gets 8000 visits weekly. Curl Corporation
98 contacted Daniel to discuss "the name issue". After Daniel's reply, they have
99 never since got in touch again.
101 September 2001, libcurl 7.9 introduces cookie jar and curl_formadd(). During
102 the forthcoming 7.9.x releases, we introduced the multi interface slowly and
103 without much whistles.
105 June 2002, the curl web site gets 13000 visits weekly. curl and libcurl is
106 35000 lines of code. Reported successful compiles on more than 40 combinations
107 of CPUs and operating systems.
109 To estimate number of users of the curl tool or libcurl library is next to
110 impossible. Around 5000 downloaded packages each week from the main site gives
111 a hint, but the packages are mirrored extensively, bundled with numerous OS
112 distributions and otherwise retrieved as part of other software.
114 September 2002, with the release of curl 7.10 it is released under the MIT
117 January 2003. Started working on the distributed curl tests. The autobuilds.
119 February 2003, the curl site averages at 20000 visits weekly. At any given
120 moment, there's an average of 3 people browsing the curl.haxx.se site.
122 Multiple new authentication schemes are supported: Digest (May), NTLM (June)
123 and Negotiate (June).
125 November 2003: curl 7.10.8 is released. 45000 lines of code. ~55000 unique
126 visitors to the curl.haxx.se site. Five official web mirrors.
128 December 2003, full-fledged SSL for FTP is supported.
130 January 2004: curl 7.11.0 introduced large file support.
134 curl 7.12.0 introduced IDN support. 10 official web mirrors.
136 This release bumped the major SONAME to 3 due to the removal of the
137 curl_formparse() function
140 Curl and libcurl 7.12.1
142 Public curl release number: 82
143 Releases counted from the very beginning: 109
144 Available command line options: 96
145 Available curl_easy_setopt() options: 120
146 Number of public functions in libcurl: 36
147 Amount of public web site mirrors: 12
148 Number of known libcurl bindings: 26
152 GnuTLS can now optionally be used for the secure layer when curl is built.
156 TFTP support was added.
158 More than 100,000 unique visitors of the curl web site. 25 mirrors.
162 security vulnerability: libcurl URL Buffer Overflow
166 We dropped support for Gopher. We found bugs in the implementation that
167 turned out having been introduced years ago, so with the conclusion that
168 nobody had found out in all this time we removed it instead of fixing it.
172 security vulnerability: libcurl TFTP Packet Buffer Overflow
176 Added the multi_socket() API
180 The major SONAME number for libcurl was bumped to 4 due to the removal of
181 ftp third party transfer support.
185 Added SCP and SFTP support
189 Added support for the Mozilla NSS library to do the SSL/TLS stuff
193 security vulnerability: libcurl GnuTLS insufficient cert verification
197 Command line options: 128
198 curl_easy_setopt() options: 158
199 Public functions in libcurl: 58
200 Known libcurl bindings: 37
203 145,000 unique visitors. >100 GB downloaded.
207 security vulnerability: libcurl Arbitrary File Access
211 security vulnerability: libcurl embedded zero in cert name
215 Added support for IMAP, POP3 and SMTP
219 Added support for RTSP
223 security vulnerability: libcurl data callback excessive length
227 The project switched over to use git instead of CVS for source code control
231 Added support for RTMP
233 Added support for PolarSSL to do the SSL/TLS stuff
237 Public curl releases: 117
238 Command line options: 138
239 curl_easy_setopt() options: 180
240 Public functions in libcurl: 58
241 Known libcurl bindings: 39
244 Gopher support added (re-added actually)