Allow autogening even without AM_PATH_LIBGCRYPT available
[platform/upstream/libsoup.git] / ChangeLog
1 2008-01-23  Tor Lillqvist  <tml@novell.com>
2
3         * configure.in: Allow autogening even without AM_PATH_LIBGCRYPT
4         available
5
6         * libsoup/soup-date.c (soup_date_new_from_time_t): Correct use of
7         gmtime().
8
9         * libsoup/soup-headers.c (soup_headers_parse_status_line): Return
10         FALSE if neither HTTP nor ICY. Avoids crash in
11         tests/header-parsing.
12
13         * libsoup/soup-socket.c: On Windows SHUT_RDWR is called SD_BOTH.
14         (set_nonblocking): Fix typo.
15
16         * tests/continue-test.c: Seems to build fine without <pthread.h>,
17         so drop that.
18
19 2008-01-18  Dan Winship  <danw@gnome.org>
20
21         * tests/server-auth-test.c: test SOUP_AUTH_DOMAIN_REMOVE_PATH
22
23 2008-01-18  Dan Winship  <danw@gnome.org>
24
25         * configure.in: require glib 2.15.3, not 2.15.0, since
26         AM_PATH_GLIB_2_0 didn't know about gio until post-2.15.2. Pointed
27         out by Matthew Barnes, #510216.
28
29 2008-01-18  Dan Winship  <danw@gnome.org>
30
31         * libsoup/soup-auth-domain.c
32         (soup_auth_domain_set_generic_auth_callback):
33         (soup_auth_domain_check_password): add a new generic auth callback
34         that can be used with any subclass to do cleartext password
35         checking against messages. Suggested by Mathias Hasselmann.
36
37         * libsoup/soup-auth-domain-basic.c: Implement generic auth
38
39         * libsoup/soup-auth-domain-digest.c: Implement generic auth.
40         (soup_auth_domain_digest_evil_check_password): Gone, use the
41         generic version now.
42
43 2008-01-17  Dan Winship  <danw@gnome.org>
44
45         * libsoup/soup-auth-digest.c (soup_auth_digest_compute_hex_urp)
46         (soup_auth_digest_compute_hex_a1)
47         (soup_auth_digest_compute_response): cast the second arg to
48         g_checksum_update to (guchar *) to avoid warnings
49
50 2008-01-16  Dan Winship  <danw@gnome.org>
51
52         * libsoup/soup-headers.c (soup_headers_parse_status_line): Deal
53         with Shoutcast servers, which return "ICY 200 OK", but are
54         otherwise straight HTTP/1.0. #502325, Wouter Cloetens.
55
56         * tests/header-parsing.c (resptests): add a test for it
57
58 2008-01-16  Dan Winship  <danw@gnome.org>
59
60         * libsoup/soup-auth-manager.c (authorize_handler, etc): Allow the
61         session authenticate signal to be handled asynchronously, by
62         pausing the message and then authenticating the auth later.
63         (auth_type_compare_func): make this work. oops.
64         (extract_challenge): plug leak
65
66         * libsoup/soup-auth-manager-ntlm.c: Make this work async too.
67
68         * libsoup/soup-headers.c (soup_header_parse_list):
69         (soup_header_parse_param_list): plug leaks
70
71         * tests/auth-test.c (do_async_auth_test): test async auth
72
73         * docs/reference/client-howto.xml (Handling Authentication):
74         mention async auth
75
76 2008-01-16  Dan Winship  <danw@gnome.org>
77
78         * configure.in: Bomb out if glib 2.15.0 isn't found.
79         (AM_PATH_GLIB_2_0 doesn't do this itself.)
80
81 2008-01-15  Dan Winship  <danw@gnome.org>
82
83         * libsoup/soup-auth-manager-ntlm.c: Replaces SoupConnectionNTLM;
84         now works as a SoupSession::request_started watcher.
85
86         * libsoup/soup-connection.c: remove the no-longer-needed
87         "authenticate" signal
88
89         * libsoup/soup-session.c: Use a SoupAuthManagerNTLM if USE_NTLM is
90         set. Remove connection-authenticate-signal references.
91
92 2008-01-15  Dan Winship  <danw@gnome.org>
93
94         * Merge libsoup-2.4 branch to trunk
95         
96 2008-01-15  Dan Winship  <danw@gnome.org>
97
98         * libsoup/soup-dns.c (resolve_status): Fix the logic here
99
100 2008-01-15  Dan Winship  <danw@gnome.org>
101
102         * docs/reference/porting-2.2-2.4.xml: add a few more updates
103
104 2008-01-15  Dan Winship  <danw@gnome.org>
105
106         * libsoup/soup-auth-digest.c: Use GChecksum for MD5
107
108         * libsoup/soup-md5-utils.[ch]: gone
109
110 2008-01-15  Dan Winship  <danw@gnome.org>
111
112         * libsoup/soup-server.c (soup_server_run_async):
113         (soup_server_quit): Don't ref/unref the server here. It doesn't
114         match the way other things work. #494128, Mathias Hasselmann.
115
116 2008-01-14  Dan Winship  <danw@gnome.org>
117
118         * libsoup/soup-address.h:
119         * libsoup/soup-auth-domain-basic.h:
120         * libsoup/soup-auth-domain-digest.h:
121         * libsoup/soup-auth-domain.h:
122         * libsoup/soup-auth.h:
123         * libsoup/soup-logger.h:
124         * libsoup/soup-message.h:
125         * libsoup/soup-server.h:
126         * libsoup/soup-session-async.h:
127         * libsoup/soup-session-sync.h:
128         * libsoup/soup-session.h:
129         * libsoup/soup-socket.h: Add padding for future expansion to class
130         structs
131
132 2008-01-14  Dan Winship  <danw@gnome.org>
133
134         * libsoup/soup-uri.c: Add more documentation.
135         (soup_uri_is_https): gone, replaced by SOUP_URI_SCHEME_HTTP /
136         SOUP_URI_SCHEME_HTTPS
137         (soup_uri_new): allow passing NULL to get back an "empty" SoupURI.
138         (soup_uri_to_string): rename just_path to just_path_and_query, to
139         avoid fooling people.
140         (soup_uri_decode, soup_uri_normalize): Change these to return the
141         decoded/normalized string rather than modifying it in place.
142         (soup_uri_set_scheme, etc): provide setters for SoupURI parts.
143         (soup_uri_set_query_from_form): set uri->query via
144         soup_form_encode_urlencoded().
145
146 2008-01-14  Dan Winship  <danw@gnome.org>
147
148         * configure.in: require glib 2.15.0, and gio
149
150         * libsoup/soup-dns.c (soup_dns_lookup_resolve)
151         (soup_dns_lookup_resolve_async): Add GCancellables, and support
152         cancellation of DNS lookups.
153         (resolve_address, resolve_name): If we get a DNS failure (eg,
154         because we're disconnected from the network), don't cache that
155         result, just try again next time someone asks. [#508593]
156
157         * libsoup/soup-address.c (soup_address_resolve_async)
158         (soup_address_resolve_sync): Add GCancellables, pass them to
159         soup-dns.
160
161         * libsoup/soup-socket.c (soup_socket_connect_async)
162         (soup_socket_connect_sync): Add GCancellables and implement
163         cancellation.
164         (soup_socket_start_ssl, soup_socket_start_proxy_ssl)
165         (soup_socket_read, soup_socket_read_until, soup_socket_write): add
166         GCancellables, though these routines don't actually implement
167         cancellation yet.
168         (soup_socket_disconnect): Don't close() the socket if someone is
169         doing I/O on it, as that creates a race condition. (The fd number
170         might be quickly recycled.) Instead, keep the socket open but
171         dead, via shutdown().
172
173 2008-01-14  Benjamin Otte  <otte@gnome.org>
174
175         * libsoup/soup-socket.c: (soup_socket_class_init): clarify docs for
176         new-connection signal.
177
178 2008-01-14  Dan Winship  <danw@gnome.org>
179
180         * tests/test-utils.c: renamed from apache-wrappers and expanded.
181         (test_init): do option parsing and general setup
182         (test_cleanup): print error count and do cleanup
183         (debug_printf): define here rather than in each test, and rename
184         from dprintf [#501631]
185         (soup_test_server_new): create a SoupServer, optionally in its own
186         thread, and clean it up when exiting.
187         (soup_test_session_new): create a SoupSession, optionally with
188         an attached SoupLogger (if requested via command line)
189         
190         * tests/*.c: use test-utils
191
192 2008-01-13  Dan Winship  <danw@gnome.org>
193
194         * libsoup/soup-logger.c: New HTTP debug logging object. (Based on
195         E2K_DEBUG and its clones.)
196
197         * libsoup/soup-message.c (soup_message_class_init)
198         (soup_message_add_header_handler)
199         (soup_message_add_status_code_handler): Change things around a
200         little; remove the "requeuing or cancelling the message stops
201         signal emission" rule, and instead make that be a feature of just
202         the header and status code handlers. (Makes the basic signal
203         handlers behave more predictably.)
204
205 2008-01-11  Dan Winship  <danw@gnome.org>
206
207         * libsoup/soup-auth-domain.c (soup_auth_domain_set_filter):
208         * libsoup/soup-auth-domain-basic.c
209         (soup_auth_domain_basic_set_auth_callback):
210         * libsoup/soup-auth-domain-digest.c
211         (soup_auth_domain_digest_set_auth_callback):
212         * libsoup/soup-message.c (soup_message_cleanup_response)
213         (soup_message_set_flags, soup_message_set_http_version)
214         (soup_message_set_uri, soup_message_set_status)
215         (soup_message_set_status_full): 
216         * libsoup/soup-message-client-io.c (parse_response_headers): 
217         * libsoup/soup-message-server-io.c (parse_request_headers):
218         Call g_object_notify() when changing properties.        
219
220         * libsoup/soup-session.c (soup_session_class_init): bump the
221         default value of SOUP_SESSION_MAX_CONNS_PER_HOST down to 2, per
222         RFC 2616.
223
224         * libsoup/soup-message-body.c (soup_buffer_copy): When copying a
225         TEMPORARY buffer, keep a reference to the copy, so that a second
226         copy will get that same buffer, rather than actually copying it
227         again.
228
229         * libsoup/soup-types.h: remove SoupMessageFilter, which doesn't
230         exist any more
231
232 2008-01-07  Dan Winship  <danw@gnome.org>
233
234         * libsoup/soup-session.c (soup_session_class_init): Change
235         request_started signal to have a SoupSocket as its last parameter.
236
237         * libsoup/soup-server.c: Fix request_* signals to all be (server,
238         msg, client) rather than (server, client, msg).
239
240 2008-01-07  Dan Winship  <danw@gnome.org>
241
242         * docs/reference/porting-2.2-2.4.xml: Notes on porting from 2.2 to
243         2.4
244
245 2008-01-07  Dan Winship  <danw@gnome.org>
246
247         * libsoup/*.c: Move gtk-doc stuff from docs/reference/tmpl/ to the
248         C files themselves. Some updates.
249
250         * docs/reference/Makefile.am: fix (kludge?) this up to not require
251         tmpl/ to exist
252
253         * docs/reference/client-howto.xml: 
254         * docs/reference/server-howto.xml: update
255
256 2008-01-06  Dan Winship  <danw@gnome.org>
257
258         * libsoup/soup-soap-message.c:
259         * libsoup/soup-soap-response.c: For the second time, remove SOAP
260         support from libsoup... These APIs are not really all that helpful
261         in the grand scheme of SOAPiness, and are only used by the
262         Evolution GroupWise backend, which can just import this code and
263         integrate it better there.
264
265         * libsoup/soup-misc.c (soup_xml_real_node): 
266         * libsoup/soup-xmlrpc.c: Move soup_xml_real_node out of soup-misc
267         to soup-xmlrpc, and make it private. libxml is no longer exposed
268         in the public API.
269
270 2008-01-06  Dan Winship  <danw@gnome.org>
271
272         * libsoup/soup-date.c (soup_date_new_from_now): new method to
273         generate a date relative to now.
274         (soup_date_new, etc): document SoupDate methods
275
276         * libsoup/soup-server.c (got_headers): set Date header, as
277         required by RFC 2616
278
279 2008-01-06  Dan Winship  <danw@gnome.org>
280
281         * libsoup/soup-server.c (got_headers): if raw_paths isn't set,
282         decode the request's uri->path before doing anything else
283         (soup_server_class_init): add "raw-paths" property, to tell
284         SoupServer to NOT decode the Request-URI path.
285
286         * libsoup/soup-auth-domain.c (soup_auth_domain_covers): Revert
287         earlier path-decoding change; that happens at the SoupServer level
288         now.
289
290 2008-01-06  Dan Winship  <danw@gnome.org>
291
292         * libsoup/soup-message-body.c (soup_buffer_get_type): Register
293         SoupBuffer as a boxed type.
294
295         * libsoup/soup-message.c (soup_message_class_init): Use
296         SOUP_TYPE_BUFFER in got_chunk signal definition
297
298         * libsoup/soup-server.c (soup_client_context_get_type): Register
299         SoupClientContext as a pointer type
300         (soup_server_class_init): use SOUP_TYPE_CLIENT_CONTEXT in signal
301         definitions.
302
303         * libsoup/soup-marshal.list: clean this up
304
305 2008-01-06  Dan Winship  <danw@gnome.org>
306
307         * libsoup/soup-server.c (SoupClientContext): Make this opaque.
308         (soup_client_context_get_socket)
309         (soup_client_context_get_auth_domain)
310         (soup_client_context_get_auth_user): New accessors
311         (soup_server_class_init): Make the signals take a
312         SoupClientContext rather than a SoupSocket.
313         (start_request, check_auth, call_handler, request_finished): Clean
314         these up by using a SoupClientContext to communicate between them.
315         (soup_server_add_handler): tweak the argument order to match the
316         gtk standard (callback, user_data, destroynotify).
317
318 2008-01-06  Dan Winship  <danw@gnome.org>
319
320         * libsoup/soup-address.c: remove the "dns_result" signal, which
321         was just an implementation detail of soup_address_resolve_async().
322
323 2008-01-06  Dan Winship  <danw@gnome.org>
324
325         * libsoup/*.c: misc documentation updates/gtk-doc fixes
326
327         * libsoup/soup-server.c: finally start documenting this properly.
328
329         * libsoup/soup-status.h (SoupStatusClass): kill this, since
330         soup_message_add_status_class_handler() is gone now.
331
332         * libsoup/soup-status.c (soup_status_get_phrase): Update docs to
333         explain that you probably don't want to use this.
334
335         * libsoup/soup-misc.h (SOUP_SSL_ERROR, SoupSSLError): Move these
336         here, since soup-ssl.h isn't installed.
337
338         * docs/references: start updating this...
339
340 2008-01-04  Dan Winship  <danw@gnome.org>
341
342         * libsoup/soup-message-body.c (soup_buffer_new)
343         (soup_message_body_append): Reorder the arguments to match
344         soup_message_set_request/response, so it's not confusing.
345
346         * libsoup/soup-message.c (wrote_chunk): remove the "chunk" arg
347         from the signal, as it turns out to be *in*convenient, since most
348         callers use this signal to mean "need another chunk", so they want
349         it to have the same prototype as "wrote_headers", which means
350         "need first chunk".
351
352 2008-01-04  Dan Winship  <danw@gnome.org>
353
354         * libsoup/soup-auth-domain.c: add documentation
355         (soup_auth_domain_set_filter): take a GDestroyNotify, for better
356         bindability
357
358         * libsoup/soup-auth-domain-basic.c:
359         * libsoup/soup-auth-domain-digest.c: Add documentation. Replace
360         authentication signals with more-easily-bindable authentication
361         callbacks (with GDestroyNotifys).
362         (soup_auth_domain_digest_evil_check_password): Add this for the
363         benefit of code that depends on being able to do the equivalent
364         of the old soup_server_auth_check_passwd().
365
366 2008-01-02  Dan Winship  <danw@gnome.org>
367
368         * libsoup/soup-message-body.h (SoupMessageBody): add data and
369         length parameters like SoupBuffer, to make this easier for callers
370         to use.
371
372         * libsoup/soup-message-body.c (soup_message_body_append)
373         (soup_message_body_append_buffer)
374         (soup_message_body_truncate): Update body->length
375         (soup_message_body_flatten): Fill in body->data (and NUL-terminate
376         it as an added bonus).
377
378         * libsoup/soup-message.c (got_body): flatten the newly-gotten
379         body.
380         (soup_message_get_request, soup_message_get_response): gone
381         
382         * libsoup/soup-message-client-io.c (get_request_headers): 
383         * libsoup/soup-message-server-io.c (get_response_headers): 
384         * libsoup/soup-soap-message.c (soup_soap_message_parse_response):
385         * tests/*.c: simplify
386
387 2008-01-02  Dan Winship  <danw@gnome.org>
388
389         * libsoup/Makefile.am (soup_headers): oops, move soup-auth.h here
390
391 2008-01-02  Dan Winship  <danw@gnome.org>
392
393         * libsoup/soup-form.c: new HTML-form-related methods (just URI
394         decoding/encoding at the moment).
395
396         * libsoup/soup-server.h (SoupServerCallback): change the prototype
397         to include the decoded path and query rather than the undecoded
398         URI.
399
400         * libsoup/soup-server.c (call_handler): %-decode the URI path
401         before looking up a handler. Decode query if available. Pass path
402         and query to the callback.
403
404         * libsoup/soup-auth-domain.c (soup_auth_domain_covers): fix this
405         to %-decode the URI path before testing it
406
407         * libsoup/soup-message-body.c (soup_message_body_append): allow
408         0-length appends
409
410         * tests/query-test.c: URI query parsing test
411
412 2008-01-02  Dan Winship  <danw@gnome.org>
413
414         * libsoup/soup-uri.c:
415         * libsoup/soup-uri.h: Change all the "const SoupURI *" to just
416         "SoupURI *", since the const is just there to be annoying.
417
418         * */*.c: update
419
420 2008-01-02  Dan Winship  <danw@gnome.org>
421
422         * libsoup/soup-message-body.c (soup_message_body_get_length)
423         (soup_message_body_get_chunk): Use goffset rather than gsize for
424         references to the entire size of the message body. (SoupBuffer
425         still uses gsize, so individual chunks can only be G_MAXSIZE
426         long.)
427         
428         * libsoup/soup-message-headers.c
429         (soup_message_headers_get_content_length):
430         (soup_message_headers_set_content_length): Likewise, use goffset.
431
432 2008-01-02  Dan Winship  <danw@gnome.org>
433
434         * libsoup/soup-message-headers.c (soup_message_headers_get):
435         Renamed from soup_message_headers_find, and with new behavior; now
436         multiple headers with the same name are automatically merged
437         together into a single comma-separated value, to ensure that apps
438         treat multivalued headers the same regardless of how upstream
439         servers generate them.
440         (soup_message_headers_find_nth): no longer needed/wanted
441
442         * libsoup/soup-auth-manager.c: Update to deal with
443         SoupMessageHeaders change. (Ugh.)
444
445         * tests/header-parsing.c: Update multiple-values test, and undo a
446         change that mistakenly got committed while debugging something
447         earlier.
448
449 2008-01-01  Dan Winship  <danw@gnome.org>
450
451         * libsoup/soup-auth-manager.c:
452         * libsoup/soup-dns.c: 
453         * libsoup/soup-gnutls.c: 
454         * libsoup/soup-message.c: 
455         * libsoup/soup-message-io.c: 
456         * libsoup/soup-message-queue.c: 
457         * libsoup/soup-misc.c: 
458         * libsoup/soup-path-map.c: 
459         * libsoup/soup-server.c: 
460         * libsoup/soup-session.c: 
461         * libsoup/soup-session-sync.c: 
462         * libsoup/soup-socket.c: Use g_slice.
463
464 2008-01-01  Dan Winship  <danw@gnome.org>
465
466         * libsoup/soup-session.c (soup_session_cancel_message): add a
467         "status_code" argument rather than having the caller set the
468         status code separately, to prevent a race condition.
469
470 2008-01-01  Dan Winship  <danw@gnome.org>
471
472         * libsoup/soup-session.c (soup_session_queue_message): change the
473         callback type to include the SoupSession as a parameter as well.
474
475         * *.c: update
476
477 2007-12-31  Dan Winship  <danw@gnome.org>
478
479         * libsoup/soup-session.c (soup_session_class_init): change
480         the "authenticate" signal to include a SoupAuth rather than its
481         components, and to have a "retrying" parameter rather than
482         separating "authenticate" and "reauthenticate".
483
484         * libsoup/soup-connection.c (soup_connection_class_init): Likewise
485
486         * libsoup/soup-auth-manager.c (authenticate_auth): update
487
488         * libsoup/soup-auth.c: make various attributes into gobject
489         properties.
490         (soup_auth_is_for_proxy): check whether an auth is plain or proxy
491         (soup_auth_get_host): get the hostname associated with an auth
492
493         * libsoup/soup-auth-ntlm.c: dummy class used by SoupConnectionNTLM
494         in the authenticate signal
495
496         * libsoup/soup-connection-ntlm.c (ntlm_authorize_pre): update for
497         authenticate signals changes; use a fake SoupAuthNTLM to assist.
498
499 2007-12-20  Dan Winship  <danw@gnome.org>
500
501         * libsoup/soup-message.c (soup_message_add_header_handler)
502         (soup_message_add_status_code_handler): Make these be wrappers
503         around g_signal_connect() rather than having a completely separate
504         system.
505         (soup_message_class_init): improve signal docs. Use
506         "got_foo_signal_wrapper" to wrap the got-foo signals.
507         (got_foo_signal_wrapper): Wraps the marshaller for the got-foo
508         signals and cancels the signal emission if the message gets
509         cancelled or requeued.
510         (got_informational, got_headers, got_chunk, got_body): remove
511         no-longer-needed default implementations.
512
513         * libsoup/soup-message-handlers.c: gone
514
515         * tests/ntlm-test.c (do_message): Simplify now that callback
516         processing doesn't happen in two separate phases.
517
518 2007-12-20  Dan Winship  <danw@gnome.org>
519
520         * libsoup/soup-auth-domain.c:
521         * libsoup/soup-auth-domain-basic.c:
522         * libsoup/soup-auth-domain-digest.c: New server-side auth system.
523
524         * libsoup/soup-server.c: remove SoupServerAuth / SoupAuthContext
525         stuff, add SoupAuthDomain support.
526         (SoupServerCallbackFn): improve the args here
527         (SoupClientContext): renamed from SoupServerContext and made less
528         redundant
529
530         * libsoup/soup-server-auth.c: gone!
531
532         * libsoup/soup-auth-digest.c (soup_auth_digest_parse_algorithm)
533         (soup_auth_digest_get_algorithm, soup_auth_digest_parse_qop)
534         (soup_auth_digest_get_qop, soup_auth_digest_compute_hex_urp)
535         (soup_auth_digest_compute_hex_a1)
536         (soup_auth_digest_compute_response): New routines shared between
537         client-side and server-side digest auth.
538
539         * tests/server-auth-test.c: test server-side auth, using curl for
540         the client side
541
542         * configure.in: check for curl, for server-auth-test
543
544 2007-12-20  Dan Winship  <danw@gnome.org>
545
546         * libsoup/soup-headers.c (soup_header_parse_list)
547         (soup_header_parse_quality_list): New methods to parse list-type
548         headers (with optional qvalues) correctly.
549         (soup_header_parse_param_list): Rename to match the other methods,
550         and update the semantics a bit.
551         (soup_header_contains): Correctly check for a token in a list
552
553         * libsoup/soup-message.c (soup_message_is_keepalive):
554         * libsoup/soup-message-client-io.c (get_request_headers):
555         * libsoup/soup-message-server-io.c (parse_request_headers): Use
556         soup_header_contains() with Connection headers.
557
558         * tests/header-parsing.c (do_qvalue_tests): add
559         soup_header_parse_quality_list() test
560
561 2007-12-20  Dan Winship  <danw@gnome.org>
562
563         * libsoup/soup-auth-manager.c: Move auth-related code from
564         SoupSession and SoupAuth here, and make various cleanups and
565         beginnings of cleanups.
566
567         * libsoup/soup-session.c: lots of stuff moved to
568         soup-auth-manager.c
569
570         * libsoup/soup-auth.c (soup_auth_new_from_headers): partly moved
571         to soup-auth-manager.c, partly renamed to soup_auth_new().
572         (soup_auth_update): new method to update an existing auth based on
573         a new WWW-Authenticate/Proxy-Authenticate header. Also replaces
574         the old "construct" method.
575
576         * libsoup/soup-auth-digest.c (update): Implement. If the new auth
577         has stale=true, don't invalidate the auth, just update the nonce.
578         (get_authorization): add a header handler to the message to catch
579         Authentication-Info/Proxy-Authentication-Info headers so that if
580         there's a nextnonce, we can start using it. #471380.
581
582         * libsoup/soup-auth-basic.c (update): Implement. (Updating an
583         existing Basic auth always invalidates it.)
584
585         * tests/http.conf.in:
586         * tests/auth-test.c: add a test for digest nonce handling
587
588 2007-12-20  Dan Winship  <danw@gnome.org>
589
590         * libsoup/soup-path-map.c: New type representing a sparse
591         path->something mapping
592
593         * libsoup/soup-server.c: Use SoupPathMap to record handlers. Make
594         SoupServerHandler a private type.
595         (soup_server_new): Rewrite this to just be a thin wrapper, and put
596         all of the code into a constructor override. #491653
597         (soup_server_add_handler): Turn the "unregister" arg into a
598         GDestroyNotify, for better bindability.
599
600 2007-12-19  Dan Winship  <danw@gnome.org>
601
602         * libsoup/soup-server.c: define new request_started, request_read,
603         request_finished, and request_aborted signals, for finer-grained
604         tracking than normal handlers allow.
605         (check_auth): split this out of call_handler, and run it
606         immediately after "got_headers", not "got_body", so that we can
607         preemptively reject "Expect: 100-continue" messages that will
608         require auth.
609
610         * libsoup/soup-message-io.c (io_write, io_read): Fix up
611         100-continue processing
612
613         * tests/continue-test.c: new test of client/server 100-continue
614         processing
615
616 2007-12-19  Dan Winship  <danw@gnome.org>
617
618         * libsoup/soup-socket.c: Cleanup. Remove the "connect_result"
619         signal. Make local_address and remote_address
620         into (construct-only) properties.
621         (soup_socket_connect_async, soup_socket_connect_sync): Replace
622         soup_socket_connect. _async takes a callback+user_data (like the
623         old soup_socket_client_new_async), but doesn't implement the
624         callback in terms of a connect_result signal.
625         (soup_socket_client_new_async, soup_socket_client_new_sync): Gone.
626         (Unused since the async_context addition anyway). Replaced by the
627         new construct properties and connect methods.
628         (soup_socket_read, soup_socket_read_until, soup_socket_write):
629         Make these actually take a GError rather than doing an ugly hack
630         to preserve the old API.
631         (SOUP_SOCKET_FLAG_NODELAY, SOUP_SOCKET_FLAG_REUSEADDR)
632         (SOUP_SOCKET_FLAG_CLOEXEC): kill these off (all three are always
633         TRUE now); SoupSocket is libsoup's socket API; it's not
634         necessarily intended to be generically useful for everyone.
635
636         * *.c: Update for SoupSocket changes
637
638 2007-12-19  Dan Winship  <danw@gnome.org>
639
640         * libsoup/soup-server-message.c: Kill!
641
642         * libsoup/soup-message-server-io.c (parse_request_headers):
643         Generate the full request URL from the socket's data, since we no
644         longer have soup_server_message_get_server().
645
646         * libsoup/soup-server.c (request_finished, call_handler)
647         (start_request, new_connection): update
648
649 2007-12-19  Dan Winship  <danw@gnome.org>
650
651         * libsoup/soup-message-headers.c: Add some more fields to
652         SoupMessageHeaders, and start caching the parsed values of certain
653         important headers.
654         (soup_message_headers_get/set_encoding): replaces old SoupMessage
655         methods, and only deals with the declared transfer encoding, not
656         the wire encoding.
657         (soup_message_headers_get/set_content_length): Handle
658         Content-Length.
659         (soup_message_headers_get_expectations): Handle Expect. (Replaces
660         the SOUP_MESSAGE_EXPECT_CONTINUE flag).
661
662         * libsoup/soup-message.c (soup_message_get_request_encoding):
663         (soup_message_get_response_encoding):
664         (soup_message_set_response_encoding): replaced by
665         SoupMessageHeaders methods.
666
667         * libsoup/soup-message-client-io.c:
668         * libsoup/soup-message-server-io.c:
669         * libsoup/soup-message-io.c: Update for SoupMessageHeaders changes
670         with encoding/content-length stuff.
671
672 2007-12-19  Dan Winship  <danw@gnome.org>
673
674         * libsoup/soup-message-body.c (SoupMessageBody): new opaque type
675         for request/response bodies allowing less hacky handling of
676         chunked encoding.
677         (SoupBuffer): refcounted buffer type
678
679         * libsoup/soup-message.h (SoupMessage): turn request and response
680         members into SoupMessageBody.
681         (SoupOwnership, SoupDataBuffer): gone, replaced by
682         SoupMessageBody/SoupBuffer.
683
684         * libsoup/soup-message.c (soup_message_wrote_chunk)
685         (soup_message_got_chunk): add the chunk as a signal param rather
686         than having it be visible in msg->request/response.
687         (soup_message_add_chunk, soup_message_add_final_chunk)
688         (soup_message_pop_chunk): replaced by SoupMessageBody methods now.
689
690 2007-12-19  Dan Winship  <danw@gnome.org>
691
692         * libsoup/soup-xmlrpc.c:
693         * libsoup/soup-value-utils.c: Oops. Change the API a bunch so this
694         works on x86; apparently I was doing illegal things with va_lists
695         before that only work on x86_64.
696
697 2007-12-14  Dan Winship  <danw@gnome.org>
698
699         * libsoup/soup-message.c: use GObject properties for SoupMessage
700         fields.
701
702         * libsoup/soup-message-server-io.c: 
703         * libsoup/soup-soap-message.c: update for that
704
705 2007-12-14  Dan Winship  <danw@gnome.org>
706
707         * libsoup/soup-uri.c: Rename from SoupUri to SoupURI. Use the
708         slice allocator and register as a boxed type.
709         (SoupURI): Rename "protocol" field to "scheme" and "passwd" to
710         "password". Make scheme an interned string. Replace
711         SOUP_PROTOCOL_HTTPS with soup_uri_is_https().
712
713         * *.c: update
714         
715 2007-12-14  Dan Winship  <danw@gnome.org>
716
717         * libsoup/Makefile.am: Use glib-mkenums to build soup-enum-types.c
718         and soup-enum-types.h
719
720         * libsoup/soup-address.h (SoupAddressFamily): redo this definition
721         again, to make glib-mkenums happy.
722
723 2007-12-13  Dan Winship  <danw@gnome.org>
724
725         * libsoup/soup-xmlrpc.c: New easier-to-use and
726         easier-to-do-language-bindings-of XML-RPC code.
727
728         * libsoup/soup-xmlrpc-message.c: 
729         * libsoup/soup-xmlrpc-response.c: gone
730
731         * libsoup/soup-value-utils.c: Utilites for working with
732         GValueArray, and GHashTables of GValues, used by soup-xmlrpc.
733
734         * tests/getbug.c: 
735         * tests/xmlrpc-test.c: Update to use new XML-RPC stuff
736
737 2007-12-13  Dan Winship  <danw@gnome.org>
738
739         * libsoup/soup-date.c: Make a SoupDate type, and redo in terms of
740         that rather than struct tm and time_t. Also be much more liberal
741         when parsing.
742
743         * libsoup/soup-xmlrpc-message.c (soup_xmlrpc_message_write_datetime): 
744         * libsoup/soup-xmlrpc-response.c (soup_xmlrpc_value_get_datetime):
745         Use SoupDate.
746
747         * tests/date.c: Use SoupDate, test parsing lots more formats
748
749         * tests/xmlrpc-test.c: update for SoupDate
750
751 2007-12-12  Dan Winship  <danw@gnome.org>
752
753         * libsoup/soup-message.c: 
754         * libsoup/soup-message-private.h: Remove SoupMessageStatus,
755         msg->status, and soup_message_io_* from the public API, as they
756         all really belong to the session, not the message. (For now
757         they've just been moved to soup-message-private.h, but some day
758         they'll be fully refactored away from SoupMessage.)
759
760         * libsoup/soup-server.c (soup_server_pause_message)
761         (soup_server_unpause_message): 
762         * libsoup/soup-session.c (soup_session_pause_message)
763         (soup_session_unpause_message): session/server-level methods to
764         replace soup_message_io_pause() and soup_message_io_unpause().
765
766         * libsoup/soup-server-message.c: Remove some unused methods
767
768         * */*.c: Update
769
770 2007-12-05  Dan Winship  <danw@gnome.org>
771
772         * libsoup/soup-connection.c:
773         * libsoup/soup-session.c: replace message filters with a
774         "request_started" signal
775
776         * libsoup/soup-message-filter.c: gone
777
778         * libsoup/soup-types.h (SOUP_MAKE_INTERFACE): no longer needed
779
780 2007-12-05  Dan Winship  <danw@gnome.org>
781
782         * libsoup/soup-uri.c: Update for RFC 3986 changes, bgo 266516, and
783         general conformance
784         (soup_uri_get_protocol): match protocols case-insensitively
785         (soup_uri_new_with_base): Don't fully %-decode the fragment,
786         query, and path, but do %-decode anything which isn't supposed to
787         be encoded. Recognize IPv6 address literals. Use stricter
788         "../"-stripping rules on the path. Reject URIs with junk between
789         the port number and the path.
790         (soup_uri_to_string): Update for the fact that the host might be
791         an IPv6 literal, and for the fact that path, query, and fragment
792         are now pre-escaped.
793         (soup_uri_equal): compare hostnames case-insensitively
794         (uri_encoded_char): update to match RFC 3986
795         (append_uri_encoded): use uppercase hex letters as recommended by
796         RFC 3986.
797         (soup_uri_normalize): decode only %-escapes that don't belong
798         there.
799
800         * docs/reference/tmpl/soup-uri.sgml: add some more SoupUri docs
801
802         * tests/uri-parsing.c: Add new tests from RFC 3986, RFC 2732, RFC
803         2616, bgo 266516, and elsewhere. Update some tests to match new
804         parsing/unparsing rules.
805
806 2007-12-05  Dan Winship  <danw@gnome.org>
807
808         * libsoup/soup-message.c (soup_message_new)
809         (soup_message_new_from_uri): g_intern_string() the method name
810         rather than assuming it's static. Also remove the NULL==GET
811         assumption.
812
813         * libsoup/soup-method.c:
814         * libsoup/soup-method.h: remove the SOUP_METHOD_ID_* macros, and
815         have the SOUP_METHOD_* macros return interned strings
816
817         * libsoup/soup-server.h (SoupServerContext): remove method_id
818         field.
819
820         * libsoup/soup-server-message.c (finalize): no longer needed,
821         since smsg->method is now an interned string just like with a
822         normal SoupMessage.
823
824         * libsoup/soup-soap-message.c (soup_soap_message_new_from_uri):
825         remove NULL==GET assumption
826
827         * *.c: update
828
829 2007-12-05  Dan Winship  <danw@gnome.org>
830
831         * libsoup/soup-message.h (SoupHTTPVersion): rename (from
832         SoupHttpVersion)
833
834         * libsoup/soup-message-headers.c: New opaque type representing
835         message headers, and new methods that work on it. Uses an array
836         rather than a hash table, to preserve header ordering as required
837         by RFC 2616. (Also fixes the API wart that
838         "soup_message_get_header", etc, did not actually take a
839         SoupMessage.)
840
841         * libsoup/soup-message.c: Kill off old header-manipulating
842         methods.
843
844         * libsoup/soup-headers.c (soup_headers_parse_request): return a
845         guint rather than gboolean, so we can properly return
846         SOUP_STATUS_HTTP_VERSION_NOT_SUPPORTED where appropriate. Also fix
847         up HTTP-Version parsing to conform with the RFC.
848         (soup_headers_parse_status_line): Likewise update HTTP-Version
849         parsing.
850         
851         * libsoup/soup-message-server-io.c (parse_request_headers): set
852         return status appropriately on parse errors
853
854         * tests/header-parsing.c: update / add more tests
855
856         * *.c: update
857
858 2007-12-05  Dan Winship  <danw@gnome.org>
859
860         * libsoup/soup-misc.c: remove deprecated base64 methods
861
862         * tests/auth-test.c (identify_auth): oops, update to use
863         g_base64_decode.
864
865 2007-12-05  Dan Winship  <danw@gnome.org>
866
867         * libsoup/Makefile.am (libsoupinclude_HEADERS): remove
868         soup-connection.h and soup-message-queue.h
869
870         * libsoup/soup-types.h: remove SoupConnection and SoupMessageQueue
871         which are no longer public
872
873         * libsoup/soup.h: sync this to reality for the first time in years
874
875         * libsoup/soup-session.c (soup_session_get_queue): Add this, for
876         subclasses, as the queue is no longer a public part of the session
877         struct.
878
879         * libsoup/soup-message.h:
880         * libsoup/soup-message-private.h: Move soup_message_send_request()
881         and soup_message_receive_request() to soup-message-private.h,
882         remove soup_message_send_request_internal().
883
884         * libsoup/soup-session-private.h: Move "protected" SoupSession
885         methods (soup_session_get_connection,
886         soup_session_try_prune_connection) here from soup-session.h
887         Add soup_session_get_queue.
888
889 2007-12-05  Dan Winship  <danw@gnome.org>
890
891         * configure.in: bump version to 2.3.0 and SOUP_API_VERSION to 2.4,
892         and drop AGE/CURRENT/REVISION all to 0.
893
894         * libsoup/Makefile.am: Rename library to libsoup-2.4.la
895
896         (start of libsoup-2.4 branch)
897
898 2007-11-26  Dan Winship  <danw@gnome.org>
899
900         * configure.in: 2.2.104
901
902         * NEWS: update
903
904 2007-11-21  Dan Winship  <danw@gnome.org>
905
906         * libsoup/soup-message-io.c (soup_message_io_cleanup): make this
907         non-static.
908
909         * libsoup/soup-message.c (finalize): Use soup_message_io_cleanup()
910         rather than soup_message_io_stop(), to avoid leaks when finalizing
911         an unfinished message. (Another part of #498509, Wouter Cloetens.)
912
913 2007-11-20  Dan Winship  <danw@gnome.org>
914
915         Fix up SOUP_SESSION_ASYNC_CONTEXT. #498509, Wouter Cloetens
916
917         * libsoup/soup-message-io.c (soup_message_io_unpause): don't leak
918         the async_context
919
920         * libsoup/soup-server.c (soup_server_quit): disconnect the
921         "new_connection" handler.
922         (soup_server_get_async_context): Convenience method to return the
923         server's async_context.
924
925         * libsoup/soup-server-message.c: don't circularly ref the server,
926         there's no need anyway.
927
928         * libsoup/soup-session.c (soup_session_get_async_context):
929         Convenience method to return the session's async_context.
930
931         * libsoup/soup-session-async.c (queue_message): call run_queue in
932         the session's async_context, not the main context.
933         (send_message): don't leak the async_context
934
935         * libsoup/soup-session-sync.c (queue_message_thread): don't leak
936         the async_context
937
938         * tests/context-test.c: test that SOUP_SESSION_ASYNC_CONTEXT works
939         and doesn't leak
940
941 2007-11-20  Dan Winship  <danw@gnome.org>
942
943         * libsoup/soup-connection.c (soup_connection_connect_async): don't
944         leak the SoupAddress.
945
946         * libsoup/soup-dns.c (soup_dns_lookup_resolve_async): fix a leak
947         when re-looking up an address
948
949         * libsoup/soup-session.c (soup_session_abort): close all
950         connections in addition to cancelling messages (needed because
951         connections currently end up holding a ref on their session,
952         preventing them from being destroyed).
953
954         * tests/auth-test.c:
955         * tests/ntlm-test.c:
956         * tests/proxy-test.c:
957         * tests/pull-api.c:
958         * tests/ssl-test.c:
959         * tests/xmlrpc-test.c: clean up more memory on exit, to help find
960         leaks in the library
961
962         * tests/libsoup.supp: add a zillion new suppressions so we
963         can use --leak-resolution=med
964
965 2007-11-16  Dan Winship  <danw@gnome.org>
966
967         * libsoup/soup-message-io.c (read_body_chunk): Fix the guards
968         around the got_chunk emission so that it doesn't get messed up if
969         you pause the I/O from the got_chunk handler. (#452280, Marco
970         Barisione).
971         (soup_message_io_pause, soup_message_io_unpause): Update docs
972         again; these are now allowed with client-side I/O as well. Fix
973         unpause() to unpause asynchronously on async sockets.
974         
975         * libsoup/soup-session-async.c (send_message): Iterate session's
976         async_context, not the default main context.
977
978         * tests/pull-api.c: Test/sample of creating a pull-style API using
979         SoupSessionAsync.
980
981         * tests/index.txt: new file to act as DirectoryIndex for the
982         tests. (In particular, pull-api wants this to be largeish.)
983
984 2007-10-28  Dan Winship  <danw@gnome.org>
985
986         * configure.in: 2.2.103
987
988         * NEWS: update
989
990 2007-10-28  Dan Winship  <danw@gnome.org>
991
992         * libsoup/soup-server.c (start_request, request_finished): ref the
993         socket around the processing of the message, since otherwise it
994         might already be freed when request_finished runs. #459896.
995
996         * libsoup/soup-message-io.c (soup_message_io_pause)
997         (soup_message_io_unpause): Clarify the docs here; this is for
998         server-side use only. Inspired by #452280.
999
1000         * docs/reference/server-howto.xml: You need to watch the
1001         "finished" signal on the message if using soup_message_io_pause()
1002         or chunked encoding, because the client might disconnect while
1003         you're paused. Clarification inspired by #471385.
1004
1005         * tests/simple-proxy.c (client_msg_failed): Fix this to DTRT since
1006         server-howto.xml points to it as an example of what to do.
1007
1008 2007-10-28  Dan Winship  <danw@gnome.org>
1009
1010         * libsoup/soup-session.c (finalize): free proxy-related stuff
1011
1012         * libsoup/soup-session-async.c (idle_run_queue): clean up the weak
1013         pointer. (From the dev repo, but identical to a patch from Rob
1014         Bradford in #484988.)
1015
1016         * tests/*.c: fix leaks
1017
1018 2007-10-28  Dan Winship  <danw@gnome.org>
1019
1020         * tests/auth-test.c:
1021         * tests/date.c:
1022         * tests/header-parsing.c:
1023         * tests/ntlm-test.c:
1024         * tests/proxy-test.c:
1025         * tests/uri-parsing.c:
1026         * tests/xmlrpc-test.c: Make these less verbose by default (to make
1027         it easier to see what failed when a "make check" fails).
1028
1029 2007-10-15  Dan Winship  <danw@gnome.org>
1030
1031         * configure.in: 2.2.102
1032
1033         * NEWS: update
1034
1035 2007-10-08  Dan Winship  <danw@gnome.org>
1036
1037         * libsoup/soup-nossl.c: Update for current soup-ssl.h prototypes
1038
1039         * tests/proxy-test.c (run_test): wrap https tests in #if HAVE_SSL
1040
1041 2007-10-05  Dan Winship  <danw@gnome.org>
1042
1043         * configure.in: 2.2.101
1044
1045         * NEWS: update
1046
1047         * tests/httpd.conf.in: 
1048         * tests/Makefile.am: 
1049         * tests/ssl-test.c: srcdir != builddir fixes
1050
1051 2007-10-05  Dan Winship  <danw@gnome.org>
1052
1053         * libsoup/soup-connection-ntlm.c (ntlm_authorize_pre): Don't crash
1054         if the authenticate callback returns a username and no password
1055         (even though it's not supposed to do that). #480987
1056
1057 2007-09-24  Dan Winship  <danw@gnome.org>
1058
1059         * libsoup/soup-auth.h (SoupAuth): add "realm" field to the struct.
1060         (SoupAuthClass) remove "get_realm" virtual method.
1061
1062         * libsoup/soup-auth.c (soup_auth_new_from_header_list): Parse the
1063         WWW-Authenticate/Proxy-Authenticate header here, set realm, and
1064         pass the params hash to the construct method.
1065         (soup_auth_get_info): Return an identifier for the auth:
1066         "SCHEME:REALM"
1067
1068         * libsoup/soup-auth-basic.c:
1069         * libsoup/soup-auth-digest.c: update
1070
1071         * libsoup/soup-session.c (invalidate_auth, update_auth_internal):
1072         use soup_auth_get_info().
1073
1074 2007-09-24  Dan Winship  <danw@gnome.org>
1075
1076         * libsoup/soup-date.c (soup_date_parse): minor rfc850-date parsing
1077         improvement suggested by RFC2616 19.3.
1078
1079         * libsoup/soup-headers.c (soup_headers_parse_request): allow
1080         erroneous trailing whitespace after HTTP version. #475169
1081
1082         * libsoup/soup-message-server-io.c (parse_request_headers): fix
1083         the parsing of the Host header to assume it already includes the
1084         port (which it should; the only reason this ever worked is because
1085         SoupUri ignores the second port number when parse_request_headers
1086         generates a URL like "http://localhost:9999:9999/").
1087
1088         * tests/header-parsing.c (reqtests): add a test for #475169
1089
1090 2007-09-23  Dan Winship  <danw@gnome.org>
1091
1092         * libsoup/soup-message.c (soup_message_class_init): remove a
1093         mysterious partial sentence in the ::wrote-chunk docstring.
1094         #458116
1095
1096         * docs/reference/libsoup-sections.txt: Remove documentation of MD5
1097         methods, which are not public. #440092
1098
1099 2007-09-23  Dan Winship  <danw@gnome.org>
1100
1101         * libsoup/soup-message.c (soup_message_set_auth)
1102         (soup_message_set_proxy_auth): Only remove the Authorization /
1103         Proxy-Authorization header from the message if it was previously
1104         set by soup_message_set_auth(). (Eg, not if it was added by
1105         SoupConnectionNTLM.) #471389
1106
1107         * libsoup/soup-connection-ntlm.h: fix a search-and-replace-o
1108
1109         * tests/ntlm-test.c: Simple NTLM regression test; doesn't really
1110         test the crypto/encoding bits, just that the right headers are
1111         being sent at the right times.
1112
1113 2007-09-14  Dan Winship  <danw@gnome.org>
1114
1115         Make "make check" pass on Fedora 7:
1116
1117         * configure.in: update apache/php tests with additional filenames
1118
1119         * tests/httpd.conf.in: updates for configure.in changes and
1120         slightly-more-recent apache
1121
1122         * tests/ssl-test.c (start_writing): fix uninitialized struct field
1123         (main): start server after setting up client since otherwise
1124         there's a race condition since soup_gnutls_init() isn't actually
1125         thread-safe. (FIXME)
1126
1127         * tests/xmlrpc-server.php: rewrite to not use $HTTP_RAW_POST_DATA
1128         (which only exists if register_globals is set)
1129
1130 2007-06-01  Dan Winship  <danw@novell.com>
1131
1132         * libsoup/soup-message-filter.h (SOUP_IS_MESSAGE_FILTER_CLASS):
1133         fix. noted by "cascardo" on libsoup-list.
1134
1135 2007-05-16  Jonathon Jongsma  <jjongsma@gnome.org>
1136
1137         * libsoup/*.h: add G_BEGIN_DECLS / G_END_DECLS to all installed
1138         headers so that libsoup can be used from C++ programs. #438776
1139
1140 2007-04-16  Dan Winship  <danw@novell.com>
1141
1142         * libsoup/soup-ssl.h: Make a real SoupSSLCredentials type rather
1143         than just using gpointer
1144
1145         * libsoup/soup-server.c (SoupServerPrivate): use it
1146
1147         * libsoup/soup-session.c (SoupSessionPrivate): use it
1148
1149         * libsoup/soup-gnutls.c: Use it, and consistently use "creds"
1150         rather than "cred" as the abbreviation for "credentials".
1151
1152         * docs/reference/libsoup-sections.txt:
1153         * docs/reference/tmpl/soup-misc.sgml: 
1154         * docs/reference/tmpl/soup-ssl.sgml: update
1155         
1156 2007-03-29  Dan Winship  <danw@novell.com>
1157
1158         * libsoup/soup-session-sync.c (queue_message): Implement this by
1159         sending the message (synchronously) in another thread and then
1160         queueing the callback back in the main thread.
1161
1162         * libsoup/soup-session.c (soup_session_queue_message): update docs
1163         to be more explicit about what thread the callback occurs in
1164
1165 2007-03-17  Dan Winship  <danw@novell.com>
1166
1167         * libsoup/soup-message.c (soup_message_set_auth)
1168         (soup_message_get_auth, soup_message_set_proxy_auth)
1169         (soup_message_get_proxy_auth): get/set auth/proxy_auth info for a
1170         message.
1171
1172         * libsoup/soup-session.c (add_auth): Use soup_message_set_auth and
1173         soup_message_set_proxy_auth.
1174         (update_auth_internal): Call soup_message_get_auth or
1175         soup_message_get_proxy_auth to determine the message's prior auth,
1176         rather than calling lookup_auth() again, since it isn't guaranteed
1177         to return the same thing now as it did when the message was
1178         originally sent. Fixes erroneous 401s when queuing multiple
1179         messages at once to an as-yet-unauthenticated-to server. #271540
1180
1181         * libsoup/soup-session-async.c (queue_message): don't run the
1182         queue right away, do it at idle time. Otherwise in some cases
1183         (especially errors), the message callbacks could be invoked before
1184         queue_message returns.
1185
1186         * tests/auth-test.c: add a regression test for #271540.
1187
1188 2007-03-17  Dan Winship  <danw@novell.com>
1189
1190         * configure.in: require glib 2.12. check for timegm().
1191
1192         * libsoup/soup-date.c (soup_mktime_utc): Use timegm if available.
1193         (soup_date_iso8601_parse): use g_time_val_from_iso8601. #337010,
1194         patch from Emmanuele Bassi.
1195
1196         * libsoup/soup-types.h: remove local copy of
1197         G_GNUC_NULL_TERMINATED since we now depend on a new-enough copy of
1198         glib.
1199
1200         * libsoup/soup-misc.c (soup_base64_encode_close)
1201         (soup_base64_encode_step, soup_base64_encode)
1202         (soup_base64_decode_step): Make these just be wrappers around the
1203         glib base64 methods. (For now; eventually they'll just go away.)
1204
1205         * libsoup/soup-auth-basic.c (authenticate): 
1206         * libsoup/soup-auth-digest.c (authenticate):
1207         * libsoup/soup-connection-ntlm.c (soup_ntlm_parse_challenge)
1208         (soup_ntlm_response): 
1209         * libsoup/soup-server-auth.c (soup_server_auth_new): 
1210         * libsoup/soup-soap-message.c (soup_soap_message_write_base64): 
1211         * libsoup/soup-xmlrpc-message.c
1212         (soup_xmlrpc_message_write_base64): 
1213         * libsoup/soup-xmlrpc-response.c (soup_xmlrpc_value_get_base64):
1214         Use glib base64 methods
1215
1216 2007-03-16  Dan Winship  <danw@novell.com>
1217
1218         * libsoup/soup-message.c (soup_message_get_response_encoding):
1219         update the handling of CONNECT: it has no response body by
1220         default, but does have a body if its headers say so.
1221
1222         * tests/proxy-test.c: test libsoup's behavior when talking to
1223         proxies.
1224
1225         * tests/httpd.conf.in: Load mod_proxy and mod_ssl, and add
1226         sections configuring them, for proxy-test
1227
1228         * configure.in: update the apache-module-dir-finding code to deal
1229         with the fact that some modules (eg, mod_ssl) might only be in the
1230         mpm-specific module dir, while others (eg, mod_php5) might only be
1231         in the generic module dir.
1232
1233 2007-03-12  Dan Winship  <danw@novell.com>
1234
1235         * tests/Makefile.am (INCLUDES): add $(LIBGNUTLS_CFLAGS) for
1236         ssl-test. #417617, patch from Elijah Newren.
1237
1238 2007-03-12  Dan Winship  <danw@novell.com>
1239
1240         * libsoup/soup-session-sync.c (wait_for_connection): if
1241         soup_connection_connect_sync() returns SOUP_STATUS_TRY_AGAIN, then
1242         try again. (Duh.) Fixes SSL-via-proxy-when-using-synchronous-I/O-
1243         where-the-proxy-closes-the-connection-when-returning-407. (Reported
1244         by Varadhan.)
1245
1246         * tests/get.c: Rewrite to use soup_session_send_message rather
1247         than soup_session_queue_message, and add a "-s" flag to use
1248         SoupSessionSync rather than SoupSessionAsync (so we can test bugs
1249         in the sync code paths).
1250
1251 2007-03-08  Dan Winship  <danw@novell.com>
1252
1253         * libsoup/soup-gnutls.c (do_handshake): don't return
1254         G_IO_STATUS_AGAIN if we're doing blocking I/O; just keep retrying
1255         until the handshake is complete.
1256         (soup_gnutls_read, soup_gnutls_write): if we get
1257         GNUTLS_E_REHANDSHAKE, call do_handshake() immediately rather than
1258         returning G_IO_STATUS_AGAIN; if the socket is blocking then
1259         G_IO_STATUS_AGAIN is wrong, and if the socket is non-blocking, we
1260         might already need to return SOUP_SSL_ERROR_HANDSHAKE_NEEDS_WRITE
1261         or SOUP_SSL_ERROR_HANDSHAKE_NEEDS_READ.
1262
1263         #415402, based on a patch from Jacob Berkman.
1264
1265         * tests/ssl-test.c: basic ssl test. In particular, tests that
1266         rehandshake requests are handled correctly during both synchronous
1267         and asynchronous I/O. Might eventually test other stuff too...
1268
1269         * configure.in: 
1270         * tests/Makefile.am: updates for ssl-test
1271
1272 2007-02-19  Dan Winship  <danw@novell.com>
1273
1274         * configure.in: Get gcrypt libs/cflags.
1275
1276         * libsoup/Makefile.am (INCLUDES, libsoup_2_2_la_LIBADD): add
1277         gcrypt flags. Patch from "Cygwin Ports Maintainer", #384498
1278
1279 2007-02-12  Dan Winship  <danw@novell.com>
1280
1281         * configure.in: 2.2.100
1282
1283 2007-02-12  Dan Winship  <danw@novell.com>
1284
1285         * libsoup/soup-headers.c (soup_headers_parse_status_line): Fix
1286         this to handle "\0"-terminated status lines (eg, from WebDAV
1287         responses), like the docs say it does. #406997
1288         (soup_headers_parse): Balance that out by rejecting internal "\0"s
1289         here.
1290         (soup_headers_parse_request, soup_headers_parse_response): Update
1291         docs to warn that @dest may be modified even on error. (This was
1292         always true, it just wasn't documented.)
1293
1294 2007-01-16  Dan Winship  <danw@novell.com>
1295
1296         * tests/header-parsing.c (do_request_tests, do_response_tests):
1297         initialize "errors" to 0. duh. Pointed out by Michael Wolf.
1298
1299 2007-01-08  Dan Winship  <danw@novell.com>
1300
1301         * configure.in: 2.2.99
1302
1303         * NEWS: update
1304
1305 2007-01-06  Dan Winship  <danw@novell.com>
1306
1307         * libsoup/soup-headers.c (soup_headers_parse): Rewrite this to be
1308         easier to understand and more correct, and make the "str" param
1309         const rather than overwriting it during parsing.
1310         (soup_headers_parse_request, soup_headers_parse_response):
1311         Likewise, make "str" param const. Fix the doc comment to describe
1312         the correct constraint on str. Make the parsing slightly more
1313         lenient as per sections 4.1 and 19.3 of RFC 2616.
1314
1315         * tests/header-parsing.c: new regression test, for Request-Line,
1316         Status-Line, and message-header parsing.
1317
1318         Inspired by #391970 (crash in SoupServer when certain invalid
1319         requests are received).
1320
1321 2006-12-05  Dan Winship  <danw@novell.com>
1322
1323         * libsoup/soup-message.c (soup_message_set_uri): Remove the calls
1324         to soup_message_io_stop() here; the corresponding calls were
1325         needed back in the SoupContext days, but they are wrong now and
1326         cause async-redirects-to-other-hosts to fail. #382251. Also
1327         clarify docs with respect to soup_session_requeue_message().
1328
1329         * libsoup/soup-message-io.c (soup_message_io_stop): Clarify docs
1330
1331         * libsoup/soup-session.c (finalize): Free ssl_creds. Pointed out
1332         by Chris Austin.
1333
1334 2006-11-20  Dan Winship  <danw@novell.com>
1335
1336         * configure.in: 2.2.98
1337
1338         * NEWS: update
1339
1340 2006-11-20  Dan Winship  <danw@novell.com>
1341
1342         Patch from Andrew W. Nosenko:
1343
1344         * libsoup/soup-message-client-io.c (parse_response_headers): Avoid
1345         memory leak when parse_response_headers() is called on a message
1346         that has a 'reason_phrase' already for some reason.
1347
1348         * libsoup/soup-gnutls.c (soup_gnutls_free): Avoid memory leak:
1349         hostname was not freed.
1350         (soup_ssl_wrap_iochannel): Avoid memory leak: SoupGNUTLSChannel
1351         'chan' was not freed in case of initialization error. Avoid double
1352         close of the "real" (plain, non-ssl) channel FD.
1353         
1354         * libsoup/soup-socket.c (soup_socket_start_proxy_ssl): Avoid
1355         memory leak: the "real" (plain, non-ssl) GIOChannel was never
1356         "finally" unreffed (one more *_ref() than *_unref()) in case of
1357         ssl-wrapping.
1358
1359 2006-11-20  Dan Winship  <danw@novell.com>
1360
1361         * libsoup/soup-connection-ntlm.c (send_request): 
1362         * libsoup/soup-session-sync.c (queue_message): 
1363         * libsoup/soup-status.c (reason_phrases): Add some missing
1364         "static"s. Patch from Matthias Clasen, #376387
1365
1366         * libsoup/soup-xmlrpc-response.c (soup_xmlrpc_value_get_type)
1367         (soup_xmlrpc_value_get_string): <value>foo</value> should mean the
1368         same thing as <value><string>foo</string></value>. Pointed out by
1369         Todd Kulesza. #364490
1370
1371 2006-11-06  Dan Winship  <danw@novell.com>
1372
1373         * configure.in: Bump version to 2.2.97. Bump AGE and CURRENT for
1374         addition of soup_xml_real_node.
1375
1376         * NEWS: update
1377
1378 2006-11-06  Dan Winship  <danw@novell.com>
1379
1380         * libsoup/soup-misc.c (soup_xml_real_node): new method to find a
1381         "real" (ie, not comment or whitespace) xml node
1382
1383         * libsoup/soup-soap-response.c (parse_parameters) 
1384         (soup_soap_response_from_string) 
1385         (soup_soap_parameter_get_first_child) 
1386         (soup_soap_parameter_get_next_child): Use soup_xml_real_node.
1387         Based on a patch from Andrew W. Nosenko.
1388
1389         * libsoup/soup-xmlrpc-message.c (soup_xmlrpc_message_from_string):
1390         don't call xmlKeepBlanksDefault, which changes libxml's behavior
1391         globally! Instead, use soup_xml_real_node() when traversing the
1392         xml tree.
1393
1394         * libsoup/soup-xmlrpc-response.c
1395         (soup_xmlrpc_response_from_string): don't call
1396         xmlKeepBlanksDefault.
1397         (exactly_one_child): rewrite in terms of soup_xml_real_node()
1398         (which means it handles comments now as well)
1399         (soup_xmlrpc_value_get_struct)
1400         (soup_xmlrpc_value_array_get_iterator)
1401         (soup_xmlrpc_value_array_iterator_prev)
1402         (soup_xmlrpc_value_array_iterator_next): Use soup_xml_real_node.
1403
1404 2006-11-05  Dan Winship  <danw@novell.com>
1405
1406         * libsoup/soup-headers.c (soup_headers_parse_request): document
1407         this (in particular, point out that str+len must point to exactly
1408         the right place). Allow req_method and req_path to be NULL.
1409         (soup_headers_parse_status_line, soup_headers_parse_response):
1410         document. Also, change "status_phrase" argument to "reason_phrase"
1411         to match the spec. Inspired by #339889.
1412
1413 2006-11-03  Dan Winship  <danw@novell.com>
1414
1415         * libsoup/*.c: fix lots of warnings. Partially from patches from
1416         Andrew W. Nosenko, and also some fixes from libsoup-pre214-branch.
1417         
1418 2006-11-03  Dan Winship  <danw@novell.com>
1419
1420         * Makefile.am (uninstall-local): uninstall the pkgconfig file.
1421         Based on #356809 from Matthew Barnes.
1422
1423         * libsoup/soup-server.c (get_property): Fix leaks pointed out by
1424         Paolo Borelli. #351500
1425
1426         * libsoup/soup-uri.c (soup_uri_get_protocol): Fix an off by one
1427         pointed out by Andrew W. Nosenko.
1428
1429         * configure.in: Use pkgconfig to find gnutls. Remove old static
1430         linking stuff that was only needed for rcd.
1431
1432         * acinclude.m4: remove gnutls stuff
1433
1434         * libsoup.pc.in: Use Requires rather than putting xml/ssl
1435         dependencies directly into Libs/Cflags. From Mikhail Zabaluev.
1436         #343340.
1437
1438         * libsoup/Makefile.am (libsoup_2_2_la_LDFLAGS): fix build on
1439         cygwin. From "Cygwin Ports maintainer", #321827.
1440
1441 2006-07-24  Dan Winship  <danw@novell.com>
1442
1443         * configure.in: 2.2.96. bump AGE and CURRENT for new API
1444
1445         * NEWS: update
1446
1447         * libsoup/soup-xmlrpc-message.c (soup_xmlrpc_message_from_string):
1448         New, from Fernando Herrera, bug 348532.
1449
1450 2006-07-21  Dan Winship  <danw@novell.com>
1451
1452         * libsoup/soup-auth.c (soup_auth_new_from_header_list): if the
1453         constructed auth doesn't have a realm, it's invalid, as per RFC
1454         2617. Based on a patch from Nate Nielsen on libsoup-list.
1455         (soup_auth_get_realm): remove "if available" from docs; all auths
1456         always have a realm.
1457
1458         * libsoup/soup-message-server-io.c (get_response_headers): If the
1459         server handler set a Content-Length header on the message, don't
1460         add a second one. (Preserves compatibility with an old hacky way
1461         that people might have been handling HEAD from SoupServer.)
1462
1463         * README: update to mention mailing list and bugzilla
1464
1465         * HACKING: kill this since there's nothing here that isn't either
1466         obvious, or redundant with the README
1467
1468 2006-07-21  Dan Winship  <danw@novell.com>
1469
1470         * libsoup/soup-server-message.c (soup_server_message_init):
1471         initialize encoding to SOUP_TRANSFER_CONTENT_LENGTH rather than
1472         SOUP_TRANSFER_UNKNOWN, since SOUP_TRANSFER_UNKNOWN has never
1473         actually worked here, and so there was an undocumented requirement
1474         that you manually set the encoding on every response
1475         (which SoupServer itself was not doing on internal errors).
1476         Problem pointed out by Dennis Jacobfeuerborn on libsoup-list.
1477         (soup_server_message_set_encoding): reject the new
1478         SoupTransferEncoding values, for compatibility
1479
1480         * libsoup/soup-message.h (SoupTransferEncoding): Clarify that
1481         SOUP_TRANSFER_UNKNOWN is essentially an error value, since in the
1482         public API, it always has been, due to bugs. Add some new values,
1483         currently just for internal use: SOUP_TRANSFER_NONE (for cases
1484         like HEAD which never have a body), SOUP_TRANSFER_EOF (to replace
1485         SOUP_TRANSFER_UNKNOWN), and SOUP_TRANSFER_BYTERANGES (which isn't
1486         actually implemented yet).
1487
1488         * libsoup/soup-message.c (soup_message_get_request_encoding,
1489         soup_message_get_response_encoding): figure out the body encoding
1490         being used by the request/response, including all the tricky
1491         cases like HEAD/1xx/etc.
1492         (soup_message_is_keepalive): if the response encoding is
1493         SOUP_TRANSFER_EOF, then the message isn't keepalive.
1494
1495         * libsoup/soup-message-client-io.c (parse_response_headers): use
1496         soup_message_get_response_encoding.
1497
1498         * libsoup/soup-message-server-io.c (parse_request_headers): use
1499         soup_message_get_request_encoding.
1500         (get_response_headers): use both soup_server_message_get_encoding
1501         and soup_message_get_response_encoding, to properly distinguish
1502         between the wire encoding and the alleged-by-headers encoding
1503         (which differ for HEAD, etc).
1504
1505         * libsoup/soup-message-io.c (io_error, read_body_chunk):
1506         s/SOUP_TRANSFER_UNKNOWN/SOUP_TRANSFER_EOF/.
1507         (io_body_state): if encoding is SOUP_TRANSFER_NONE, jump right to
1508         SOUP_MESSAGE_IO_STATE_FINISHING.
1509
1510         * libsoup/soup-server.c (request_finished): Check
1511         soup_socket_is_connected() *before* soup_message_is_keepalive(),
1512         since the message will be invalid if the client unexpectedly
1513         dropped the connection.
1514
1515         * tests/simple-httpd.c (server_callback): handle HEAD requests.
1516         Remove no-longer-necessary soup_server_message_set_encoding()
1517         call.
1518
1519         * tests/get.c: add -d (debug) flag to print headers, and -h flag
1520         to do a HEAD rather than GET
1521
1522 2006-07-10  Dan Winship  <danw@novell.com>
1523
1524         * configure.in: 2.2.95.1, and bump SOUP_AGE/SOUP_CURRENT this
1525         time. Pointed out by Daniel Holbach.
1526         
1527 2006-07-10  Dan Winship  <danw@novell.com>
1528
1529         * configure.in: 2.2.95
1530
1531         * NEWS: update
1532
1533 2006-06-19  Dan Winship  <danw@novell.com>
1534
1535         * tests/Makefile.am (noinst_PROGRAMS): don't build xmlrpc-test
1536         unless we have apache/php/xmlrpc-epi. Fixes the build. #345342
1537
1538         * configure.in: fix some quoting
1539
1540 2006-06-14  Dan Winship  <danw@novell.com>
1541
1542         * configure.in: add tests for apache mod_php5 and xmlrpc-epi-php
1543
1544         * tests/xmlrpc-test.c: XML-RPC regression test
1545
1546         * tests/xmlrpc-server.php: PHP server for xmlrpc-test
1547
1548         * tests/httpd.conf.in: add php stuff
1549
1550         * tests/apache-wrapper.c (apache_cleanup): Use "graceful-stop"
1551         rather than "stop", so that it stops listening on the socket
1552         before exiting, so that we can immediately start another apache
1553         (eg, in "make check").
1554
1555         * libsoup/soup-date.c (soup_mktime_utc): Fix a bug in leap-year
1556         counting.
1557
1558         * libsoup/soup-xmlrpc-message.c
1559         (soup_xmlrpc_message_write_datetime): rename from
1560         "..._write_time", to make it consistent with the XML-RPC type name
1561         and the corresponding SoupXmlrpcResponse method. Also, fix it to
1562         use the same ISO 8601 format as the spec, and use the right value
1563         for the seconds field.
1564         (soup_xmlrpc_message_write_base64): Change the buf arg to a
1565         gconstpointer rather than a const char *.
1566
1567         * libsoup/soup-xmlrpc-response.c (soup_xmlrpc_value_get_base64):
1568         Return a GByteArray containing the decoded data, rather than
1569         the base64-encoded string.
1570         (soup_xmlrpc_value_dump_internal): Update for that (and don't
1571         leak it).
1572         (soup_xmlrpc_value_array_get_iterator,
1573         soup_xmlrpc_value_array_iterator_get_value): Make these actually
1574         work.
1575
1576 2006-06-12  Dan Winship  <danw@novell.com>
1577
1578         * configure.in: 2.2.94
1579
1580         * NEWS: update
1581
1582 2006-06-12  Dan Winship  <danw@novell.com>
1583
1584         * docs/reference/client-howto.xml: 
1585         * docs/reference/server-howto.xml: New client and server API
1586         tutorials.
1587
1588         * docs/reference/*: reorganize, regenerate, fill in some missing
1589         pieces, etc
1590
1591         * libsoup/soup-connection.c (soup_connection_new): document the
1592         varargs param
1593
1594         * libsoup/soup-date.h: sync prototypes to declarations for gtk-doc.
1595
1596         * libsoup/soup-headers.c (soup_headers_parse_response): fix typo
1597         in doc.
1598
1599 2006-06-12  Dan Winship  <danw@novell.com>
1600
1601         * libsoup/soup-xmlrpc-response.c (soup_xmlrpc_value_get_int,
1602         soup_xmlrpc_value_get_double): Further fixes from Brent Smith.
1603         #344458.
1604         (soup_xmlrpc_value_get_boolean): Similar fix, plus actually set
1605         the output parameter and make the return value match the other
1606         get_* methods.
1607
1608 2006-06-09  Dan Winship  <danw@novell.com>
1609
1610         * configure.in: Add tests for apache, output tests/httpd.conf
1611
1612         * tests/htdigest: 
1613         * tests/htpasswd: 
1614         * tests/httpd.conf.in: Apache 2.2 config files for auth-test
1615
1616         * tests/apache-wrapper.c (apache_init, apache_cleanup): functions
1617         to start/stop apache
1618
1619         * tests/auth-test.c: Use apache-wrapper functions to start a local
1620         apache process to test authentication against, since the auth-test
1621         tree at developer.ximian.com went missing a long time ago. #311825
1622
1623         * tests/Makefile.am (auth_test_SOURCES): use apache-wrapper.c
1624         (TESTS): include auth-test if HAVE_APACHE.
1625
1626         * libsoup/soup-session.c (lookup_auth): Fix this in the case of a
1627         URI pointing to a directory rather than a file.
1628
1629 2006-06-08  Dan Winship  <danw@novell.com>
1630
1631         * libsoup/soup-xmlrpc-response.c (soup_xmlrpc_value_get_int,
1632         soup_xmlrpc_value_get_double, soup_xmlrpc_value_get_boolean):
1633         Check return value of strtol/g_ascii_strtod correctly. #344222,
1634         patch from Brent Smith.
1635
1636 2006-06-07  Dan Winship  <danw@novell.com>
1637
1638         * libsoup/soup-xmlrpc-response.c
1639         (soup_xmlrpc_response_from_string): record whether or not the
1640         response was a fault.
1641         (soup_xmlrpc_response_is_fault): test that. #343973, patch from
1642         Brent Smith.
1643
1644 2006-05-29  Dan Winship  <danw@novell.com>
1645
1646         * configure.in: 2.2.93
1647
1648         * NEWS: update
1649
1650 2006-05-29  Dan Winship  <danw@novell.com>
1651
1652         * libsoup/soup-message-io.c (SoupMessageIOState): add a new state
1653         "FINISHING" which means "done I/O, but not yet done processing and
1654         cleanup" before "DONE" (which now always means "completely done").
1655         (soup_message_io_stop): disconnect the socket if the read state is
1656         "< FINISHING", not "!= DONE".
1657         (io_error): on an EOF-that-signals-end-of-data, set state to
1658         FINISHING and run io_read().
1659         (io_read, io_write): remove the g_return_if_fails from before.
1660         s/DONE/FINISHING/ in most places. In the FINISHING handler, stop
1661         listening for the readable/writable signal (eg, so we don't end up
1662         reading a following pipelined request), and set the state to DONE.
1663         (soup_message_io_unpause): Only reconnect the readable/writable
1664         signals if the io state isn't DONE. Guard the calls to
1665         io_read/io_write better so that it's safe to call this even after
1666         they are both DONE, since it may be easier for us to test that
1667         than for the caller to.
1668
1669         Fixes 334469, 342640, and another bug caused by the earlier
1670         workaround to 334469. Based on patches and analysis from William
1671         Jon McCann and Armin Bauer.
1672
1673         * tests/simple-proxy.c (main): add g_thread_init (NULL) to make
1674         this work again. (Pointed out by Alex Larsson)
1675
1676 2006-05-26  Dan Winship  <danw@novell.com>
1677
1678         * libsoup/soup-socket.c: #include <sys/time.h> for struct timeval.
1679         #342048
1680
1681         * libsoup/soup-connection.c (soup_connection_connect_sync): Start
1682         SSL after CONNECTing! Doh. Part of bnc #174255.
1683         (SoupConnectionMode): new enum for the three types of
1684         SoupConnection (direct, proxy, tunnel).
1685         (set_property): set priv->mode according to proxy_uri and
1686         conn_uri.
1687         (socket_connect_result, soup_connection_connect_sync): use
1688         priv->mode to decide whether or not to tunnel.
1689         (send_request): Only pass TRUE for is_proxy to
1690         soup_message_send_request if mode is PROXY, not if it's TUNNEL.
1691         (Also part of bnc #174255).
1692
1693 2006-05-26  Dan Winship  <danw@novell.com>
1694
1695         * libsoup/soup-message-io.c (soup_message_io_in_progress): tests
1696         if IO is currently in progress on a message.
1697
1698         * libsoup/soup-session-async.c (run_queue): don't process messages
1699         that are io_in_progress. #342545, fix based on analysis from Wang
1700         Xin. (In the future we may want to re-fix this by adding a
1701         REQUEUED message status separate from QUEUED.)
1702
1703 2006-05-22  Dan Winship  <danw@novell.com>
1704
1705         * libsoup/soup-session.c (cleanup_hosts): Don't free the hosts
1706         while holding host_lock; that's not allowed and can cause
1707         deadlock. #309867. Based on a patch from Veerapuram Varadhan for
1708         part of bnc #174255.
1709
1710 2006-04-10  Dan Winship  <danw@novell.com>
1711
1712         * configure.in: bump version to 2.2.92
1713
1714         * NEWS: update
1715
1716 2006-04-10  Dan Winship  <danw@novell.com>
1717
1718         * libsoup/soup-message-io.c (io_write, io_read): g_return_if_fail
1719         if these get called after the IO is done. This isn't supposed to
1720         happen, but apparently does. Workaround for #334469.
1721
1722         * libsoup/soup-auth-digest.c (qop_types, algorithm_types):
1723         NULL-terminate these so we don't crash when trying to parse an
1724         invalid value. (Flip side of the previous #328615 patch.)
1725
1726 2006-04-02  Dan Winship  <danw@novell.com>
1727
1728         * libsoup/soup-server-auth.c (soup_server_auth_context_challenge):
1729         Write out correct digest algorithm value. #328615.
1730
1731         * libsoup/soup-headers.c (soup_headers_parse_request): Rewrite
1732         Request-Line-parsing code to not have a lame max length. #335040.
1733
1734         * Makefile.am (install-data-local): Install the .pc file mode 644,
1735         not 755. #330878
1736
1737         * libsoup/soup-auth-digest.c:
1738         * libsoup/soup-auth.c:
1739         * libsoup/soup-message-client-io.c:
1740         * libsoup/soup-message-server-io.c:
1741         * libsoup/soup-message.c:
1742         * libsoup/soup-method.c:
1743         * libsoup/soup-server-auth.c:
1744         * tests/get.c: replace locale-ish strcasecmps with
1745         g_ascii_strcasecmp
1746
1747         * libsoup/*.c: fix most signed/unsigned mismatch warnings
1748
1749 2006-03-03  Dan Winship  <danw@novell.com>
1750
1751         * configure.in: bump version to 2.2.91.
1752
1753         * NEWS: Update
1754
1755 2006-03-03  Dan Winship  <danw@novell.com>
1756
1757         * libsoup/soup-dns.c (soup_dns_lookup_resolve_async): Take a
1758         GMainContext as well, and update the resolution code to dispatch
1759         each lookup result in the correct context.
1760
1761         * libsoup/soup-address.c (soup_address_resolve_async_full): New
1762         method that takes a GMainContext to pass to
1763         soup_dns_lookup_resolve_async.
1764
1765         * libsoup/soup-socket.c (soup_socket_connect): Use
1766         soup_address_resolve_async_full. Fixes a problem reported by Armin
1767         Bauer.
1768
1769         * configure.in: update to require glib 2.6, since apparently the
1770         code does.
1771
1772 2006-02-25  Veerapuram Varadhan <vvaradhan@novell.com>
1773
1774         * libsoup/soup-connection.c:
1775         * libsoup/soup-session.c:
1776         * libsoup/soup-socket.c: add a "timeout" property,
1777         which gets passed from server to socket, and session to connection
1778         to socket, allowing blocking non-responsive sync connections to 
1779         return.  Combination of "EAGAIN" && "Blocking" connection is treated
1780         as error and the connection will be terminated and the control 
1781         is returned to the caller immediately.
1782                 
1783 2006-02-02  Tor Lillqvist  <tml@novell.com>
1784
1785         * configure.in: Don't use getaddrinfo() etc or try to support IPv6
1786         on Windows, as they are present by default on XP only. We do want
1787         to support Windows 2000, too.
1788
1789 2005-12-21  Dan Winship  <danw@novell.com>
1790
1791         * libsoup/soup-date.c (soup_date_iso8601_parse): fix two bugs in
1792         the YYYYMMDD case.
1793
1794         * tests/date.c: add three more ISO 8601 cases, to exercise all the
1795         code paths.
1796
1797         #324671, from Emmanuele Bassi
1798         
1799 2005-11-25  Dan Winship  <danw@novell.com>
1800
1801         * README: sync to text on wiki, and point to wiki
1802
1803         * TODO: moved to http://live.gnome.org/LibSoup_2fToDo
1804
1805 2005-11-17  Dan Winship  <danw@novell.com>
1806
1807         * libsoup/soup-message-io.c (io_cleanup): clear priv->io_data
1808         right away, to protect against this being re-entered mid-cleanup
1809         (when we unref the connection). #321208, based on a patch from
1810         Jedy Wang.
1811
1812 2005-11-16  Dan Winship  <danw@novell.com>
1813
1814         * libsoup/soup-xmlrpc-message.c
1815         (soup_xmlrpc_message_start_member): add the "name" element to the
1816         struct member. #321362, patch from Sebastian Bauer.
1817
1818 2005-11-10  Dan Winship  <danw@novell.com>
1819
1820         * configure.in: bump version to 2.2.90. This will not be
1821         officially released, but once these patches have gotten some
1822         testing they may be pulled up to the gnome-2-12 branch.
1823
1824         * libsoup/soup-connection.c:
1825         * libsoup/soup-server.c: 
1826         * libsoup/soup-session.c: 
1827         * libsoup/soup-socket.c: add an "async-context" property,
1828         which gets passed from server to socket, and session to connection
1829         to socket, allowing async usage outside the main thread. Based on
1830         patches from Armin Bauer and Jürg Billeter.
1831
1832         * libsoup/soup-misc.c (soup_add_io_watch, soup_add_idle,
1833         soup_add_timeout): utility routines to add watches, idles, and
1834         timeouts to non-default GMainContexts.
1835
1836         * libsoup/soup-message-io.c (io_write): set the read state
1837         appropriately after writing a "100 Continue" response
1838         (io_read): More 100-Continue stuff. I don't think this is quite
1839         right so it will probably change again later.
1840
1841 2005-11-01  Dan Winship  <danw@novell.com>
1842
1843         * docs/reference/libsoup-docs.sgml: tell it to generate an index
1844
1845         * docs/reference/tmpl/*.sgml: regen with newer gtk-doc
1846
1847 2005-11-01  Dan Winship  <danw@novell.com>
1848
1849         * libsoup/soup-connection.c (set_current_request,
1850         clear_current_request): Cast the argument to
1851         g_object_add/remove_weak_pointer to the wrong type, to make gcc
1852         4.1 happy, because C is stupid and "void **" means "a pointer to a
1853         void *", not "a pointer to any kind of pointer".
1854
1855         * libsoup/soup-xmlrpc-response.c
1856         (soup_xmlrpc_value_dump_internal): fix gccism. #320349, from
1857         Roland Illig.
1858
1859 2005-10-27  Dan Winship  <danw@novell.com>
1860
1861         * libsoup/soup-socket.c (soup_socket_client_new_async,
1862         soup_socket_client_new_sync): unref the SoupAddress passed to
1863         soup_socket_connect to avoid a leak. Based on a patch from Wang
1864         Xin.
1865         (socket_read_watch, read_from_network, socket_write_watch,
1866         soup_socket_write): request and handle G_IO_ERR and G_IO_HUP
1867         events when polling, since poll() will return them whether or not
1868         you asked for them, but glib will ignore them unless you did,
1869         which will result in CPU suckage if such an error occurs. #319305,
1870         patch from Jonathan Matthew.
1871
1872 2005-10-27  Dan Winship  <danw@novell.com>
1873
1874         bgo #316313 / bnc #116762, and probably also bgo #318252
1875
1876         * libsoup/soup-message-io.c (soup_message_io_stop): clear io->conn
1877         after releasing it, to make sure we can't accidentally release it
1878         twice.
1879
1880         * libsoup/soup-connection.c (clear_current_request): Call
1881         soup_message_io_stop() on the cleared request.
1882
1883         * libsoup/soup-connection-ntlm.c (ntlm_authorize_post): do a
1884         little dance here to make sure the session can't queue another
1885         message on the connection while we're in the process of requeuing
1886         the original one.
1887
1888 2005-08-30  Tor Lillqvist  <tml@novell.com>
1889
1890         * libsoup-zip.in: Include documentation in developer zipfile.
1891
1892 2005-08-22  Dan Winship  <danw@novell.com>
1893
1894         * libsoup/soup-soap-message.c (soup_soap_message_class_init): Call
1895         g_type_class_add_private.
1896
1897         * configure.in: Bump to 2.2.6.1
1898
1899         * NEWS: update
1900
1901 2005-08-22  Dan Winship  <danw@novell.com>
1902
1903         * configure.in: Bump to 2.2.6. Bump SOUP_AGE and SOUP_CURRENT for
1904         soup_server_get_socket() addition.
1905
1906         * NEWS: update
1907
1908 2005-08-22  Dan Winship  <danw@novell.com>
1909
1910         * libsoup/soup-connection.c (set_current_request,
1911         clear_current_request): Fix g_object_add/remove_weak_pointer usage
1912         to prevent a crash when canceling a request. From Tambet.
1913
1914 2005-08-16  Dan Winship  <danw@novell.com>
1915
1916         Fix a connection leak reported by Tambet.
1917
1918         * libsoup/soup-connection.c (send_request): rather than tracking
1919         the message progress via signals, call
1920         soup_message_send_request_internal() and have it call
1921         soup_connection_release() when it's done.
1922         (request_restarted, request_done): gone
1923         (clear_current_request): handle disconnecting (if necessary) and
1924         updating last_used time here.
1925         (soup_connection_release): Call clear_current_request().
1926         (dispose): Call clear_current_request()
1927
1928         * libsoup/soup-message-client-io.c
1929         (soup_message_send_request_internal): New. Takes a SoupConnection
1930         in addition to the other args, and passes that on to
1931         soup-message-io.
1932
1933         * libsoup/soup-message-io.c (SoupMessageIOData): add a
1934         SoupConnection field.
1935         (io_cleanup): if io->conn is set, unref it.
1936         (soup_message_io_stop): if io->conn is set, and we ended in a
1937         clean state, call soup_connection_release() on it.
1938         (soup_message_io_client): Add a SoupConnection arg, which gets
1939         reffed and stored in io->conn.
1940
1941         * TODO: misc updates
1942
1943 2005-08-15  Dan Winship  <danw@novell.com>
1944
1945         * libsoup/soup-connection.h (soup_connection_new):
1946         * libsoup/soup-server.h (soup_server_new):
1947         * libsoup/soup-session-async.h (soup_session_async_new_with_options): 
1948         * libsoup/soup-session-sync.h (soup_session_sync_new_with_options): 
1949         * libsoup/soup-socket.h (soup_socket_new): use G_GNUC_NULL_TERMINATED.
1950
1951         * libsoup/soup-types.h (G_GNUC_NULL_TERMINATED): steal the
1952         definition of this from glib 2.8 for use when compiling against
1953         glib 2.6.
1954
1955 2005-08-15  Tambet Ingo  <tambet@ximian.com>
1956
1957         * libsoup/soup-socket.c (update_fdflags, set_property): Fix compilation
1958         errors.
1959
1960         * libsoup/soup-server.c (soup_server_get_listener): ditto.
1961
1962 2005-08-12  Dan Winship  <danw@novell.com>
1963
1964         * libsoup/soup-server.c (soup_server_get_listener): new method to
1965         get the server's listening socket.
1966
1967         * libsoup/soup-socket.c: add a new "cloexec" property, to set
1968         FD_CLOEXEC on the socket. Update everything for that.
1969
1970 2005-08-05  Dan Winship  <danw@novell.com>
1971
1972         * libsoup/soup-socket.c (finalize): Free priv->read_buf. From
1973         Tambet.
1974         (soup_socket_connect): Make sure that get_iochannel() gets called
1975         if the connect succeeds right away, or the socket will fail on
1976         the first read or write. [#312540]
1977
1978 2005-08-01  Dan Winship  <danw@novell.com>
1979
1980         * configure.in: drop version back down to 2.2.5 and
1981         SOUP_API_VERSION back to 2.2; due to various snafus, there has
1982         never yet been an official release of the 2.4 API and the GNOME
1983         2.12 betas have been shipping with libsoup 2.2 tarballs (while
1984         jhbuild has been using 2.4, with evolution and related packages
1985         having configure hacks to build against either). As there never
1986         ended up being any API-incompatible changes in the 2.4 series, we
1987         can just merge it back into the 2.2 series and kill off 2.4.
1988
1989         * NEWS: Copy in the 2.2-series news from the gnome-2-10 branch,
1990         and add new NEWS
1991
1992         * libsoup-zip.in: s/2.2/@SOUP_API_VERSION@/
1993
1994         * libsoup/Makefile.am (libsoupincludedir, lib_LTLIBRARIES,
1995         libsoup_2_2_la_LDFLAGS, libsoup_2_2_la_LIBADD,
1996         libsoup_2_2_la_SOURCES): s/4/2/ in all the places automake won't
1997         let us use a variable.
1998
1999 2005-08-01  Dan Winship  <danw@novell.com>
2000
2001         * libsoup/soup-md5-utils.c (soup_md5_final_hex): Finalize a
2002         SoupMD5Context and write out the digest in hex digits.
2003
2004         * libsoup/soup-auth-digest.c (authenticate, compute_response):
2005         * libsoup/soup-server-auth.c (check_digest_passwd): Use that,
2006         rather than duplicating the code in both places here.
2007
2008         Patch from Wim Lewis.
2009         
2010 2005-07-15  Dan Winship  <danw@novell.com>
2011
2012         * libsoup/soup-session.c (redirect_handler): Allow relative URIs,
2013         since some servers are lame. Based on a patch from Jean-Yves
2014         Lefort. [#270688]
2015
2016         * tests/uri-parsing.c: add some more tests to make sure that
2017         things that should be %-escaped do get %-escaped
2018
2019 2005-07-06  Tor Lillqvist  <tml@novell.com>
2020
2021         * libsoup/soup-date.c (soup_gmtime): Mention in the doc comment
2022         that gmtime() is thread-safe on Windows.
2023         (soup_date_generate): Use soup_gmtime() instead of gmtime_r().
2024
2025 2005-06-14  Dan Winship  <danw@novell.com>
2026
2027         * configure.in: check for gmtime_r
2028
2029         * libsoup/soup-date.c: date/time-manipulation functions
2030
2031         * libsoup/soup-xmlrpc-message.c: 
2032         * libsoup/soup-xmlrpc-response.c: XMLRPC message classes, from
2033         Mariano Suarez-Alvarez, Fernando Herrera, and Jeff Bailey.
2034         [#300227]
2035
2036         * tests/date.c: soup-date test code
2037
2038         * tests/getbug.c: XMLRPC test code. (Should be switched to use
2039         bugzilla.gnome.org once bgo supports XMLRPC.)
2040
2041         * TODO: XMLRPC is implemented now (but shares the problem with
2042         SOAP that the API is not very good).
2043
2044 2005-06-14  Dan Winship  <danw@novell.com>
2045
2046         * libsoup/*.[ch]: add/fix gtk-doc comments, make functions match
2047         prototypes, etc
2048
2049         * docs/reference/*: update, fix, etc
2050
2051 2005-06-13  Tor Lillqvist  <tml@novell.com>
2052
2053         * configure.in: Check also for inet_ntop(). Pre-cache knowledge
2054         that we do have inet_pton() and inet_ntop() on Windows (because we
2055         implement them ourselves in soup-dns.c).
2056         
2057         * libsoup/soup-dns.c (inet_pton, inet_ntop): Fix the Win32
2058         implementations, they were completely bogus.
2059         (soup_dns_ntop): Make it compile if HAVE_INET_NTOP.
2060
2061 2005-06-08  Dan Winship  <danw@novell.com>
2062
2063         * libsoup/soup-connection-ntlm.c (ntlm_authorize_pre): Fix this to
2064         use just the domain name for the domain, not the whole
2065         DOMAIN\username. Based on a patch by Jeroen Hautekeete in #306877.
2066
2067 2005-05-26  Dan Winship  <danw@novell.com>
2068
2069         * libsoup/soup-session.c (cleanup_hosts): lock host_lock around
2070         this, since it can be called from set_property(). Possible fix for
2071         bnc #81641.
2072
2073 2005-05-05  Dan Winship  <danw@novell.com>
2074
2075         * docs/reference/Makefile.am (SCANGOBJ_OPTIONS): Use
2076         --type-init-func to force g_thread_init to be called. [#302674]
2077
2078 2005-04-18  Tor Lillqvist  <tml@novell.com>
2079
2080         * configure.in: Call AC_LIBTOOL_WIN32_DLL. Check for Win32, set
2081         Automake conditional OS_WIN32. Pre-cache information that we do
2082         have getaddrinfo(), getnameinfo(), and IPv6 on Win32. (The tests
2083         wouldn't notice as they don't include the necessary headers or
2084         link with -lws2_32. Easiest to just pre-cache it.)
2085
2086         * libsoup-zip.in: New file, to build zipfile-based distribution of
2087         libsoup for Win32. 
2088
2089         * Makefile.am (EXTRA_DIST)
2090         * configure.in (AC_OUTPUT): Add libsoup-zip(.in).
2091
2092         * libsoup/Makefile.am: Use -no-undefined on Win32. Link with
2093         WinSock library -lws2_32.
2094         
2095         * libsoup/soup-portability.h: New file. On Unix it includes the
2096         traditional BSD socket etc headers. On Win32 it includes
2097         winsock2.h and ws2tcpip.h.
2098
2099         * libsoup/*.c
2100         * libsoup/*.h: Correspondingly, don't include the BSD socket API
2101         headers directly.
2102
2103         * libsoup/soup-address.h
2104         * libsoup/soup-dns.h: Include soup-portability.h
2105
2106         * libsoup/soup-address.c (soup_address_class_init): This function
2107         should get called before libsoup uses the WinSock API, so this is
2108         a good place to call WSAStartup().
2109         
2110         * libsoup/soup-auth-digest.c (get_protection_space): Use
2111         g_strsplit() instead of the relatively unportable strtok_r().
2112
2113         * libsoup/soun-dns.c: Remove unused headers. Implement
2114         inet_pton() and inet_ntop() on Win32 using WSAStringToAddress()
2115         and WSAAddressToString().
2116
2117         * libsoup/soup-socket.c (SOUP_CLOSE_SOCKET, SOUP_IS_SOCKET_ERROR,
2118         SOUP_IS_INVALID_SOCKET, SOUP_IS_CONNECT_STATUS_INPROGRESS):
2119         Portability macros.
2120         (soup_socket_class_init): Call soup_address_get_type() to make
2121         sure WSAStartup() gets called (through soup_address_class_init()).
2122         (update_fdflags): Use ioctlsocket(FIONBIO) on Win32.
2123         (soup_socket_write): Conditionalize SIGPIPE use.
2124         
2125         * tests/get.c: mkdir() is different in Microsoft's C library.
2126
2127         * tests/simple-httpd.c: Rename TRY_AGAIN label to AGAIN to avoid
2128         some clash with winsock2.h (which includes windows.h). The Win32
2129         headers pollute the namespace wildly.
2130
2131 2005-04-15  Dan Winship  <danw@novell.com>
2132
2133         * libsoup/soup-dns.c (resolve_name): make this work with
2134         pre-EAI_OVERFLOW glibc [#300620]
2135
2136 2005-04-12  Dan Winship  <danw@novell.com>
2137
2138         * configure.in: Remove the various gethostbyname_r checks and just
2139         check for getnameinfo/getaddrinfo.
2140
2141         * libsoup/soup-dns.c: de-nastify. Make this use threads instead of
2142         forking. Change the API around a bunch in the process.
2143
2144         * libsoup/soup-address.c: Update for soup-dns changes
2145
2146         * tests/dns.c: take multiple hostnames on the command line and
2147         resolve them all at once (patch from tml)
2148
2149 2005-04-11  Dan Winship  <danw@novell.com>
2150
2151         * configure.in: require glib-2.0 >= 2.4.0
2152
2153         * libsoup/*.c: use G_DEFINE_TYPE and
2154         g_type_class_add_private/G_TYPE_INSTANCE_GET_PRIVATE
2155
2156         * libsoup/soup-types.h: kill SOUP_MAKE_TYPE and
2157         SOUP_MAKE_TYPE_WITH_IFACE
2158
2159         * tests/revserver.c: use GThread. (patch from tml)
2160
2161 2005-04-11  Dan Winship  <danw@novell.com>
2162
2163         * configure.in: bump version to 2.3.0. bump SOUP_API_VERSION to
2164         2.4
2165
2166         * libsoup.pc.in: rename from libsoup-2.2.pc.in
2167
2168         * Makefile.am (EXTRA_DIST, pkgconfig_DATA, install-data-local):
2169         install the .pc file by hand, renaming it to include the
2170         SOUP_API_VERSION
2171
2172         * libsoup/Makefile.am: s/2.2/2.4/
2173
2174 2005-03-09  Dan Winship  <danw@novell.com>
2175
2176         * libsoup/soup-gnutls.c (soup_gnutls_read): return G_IO_STATUS_EOF
2177         if gnutls returns 0. [#73352]
2178         (verify_certificate): put an #ifdef around
2179         GNUTLS_CERT_NOT_TRUSTED so it works with gnutls 1.2.x. [#57811]
2180
2181 2005-01-08  Not Zed  <NotZed@Ximian.com>
2182
2183         ** See ximian bug #70323.
2184
2185         * libsoup/soup-connection-ntlm.c: replace all unsigned long/long
2186         types with guint32, as the code needs 32 bit longs.
2187
2188 2004-10-20  Dan Winship  <danw@novell.com>
2189
2190         * libsoup/soup-gnutls.c: Commit the alleged changes from the 10-06
2191         commit, which somehow did not actually get committed then.
2192
2193         * libsoup/soup-connection.c (SoupConnectionPrivate): add a flag
2194         indicating whether or not the connection is connected.
2195         (tunnel_connect_finished): If successful, set connected. If the
2196         server returns a 3xx response, translate it to 407 (under the
2197         assumption that it's trying to redirect us to an HTML login page,
2198         as in bug 68531). Use soup_socket_start_proxy_ssl() rather than
2199         soup_socket_start_ssl().
2200         (socket_connect_result, soup_connection_connect_sync): If
2201         successful, set connected
2202         (soup_connection_disconnect): Don't emit "disconnected" if we
2203         aren't yet connected, or the message that was waiting for this
2204         connection may get stranded in the queue. (also part of 68531)
2205
2206         * libsoup/soup-socket.c (soup_socket_start_proxy_ssl): New, starts
2207         SSL and lets the caller pass the expected hostname. Fixes a
2208         problem where SSL certification validation would always fail if
2209         you used a proxy, because it was comparing the cert against the
2210         proxy's hostname. (68583)
2211
2212 2004-10-06  Dan Winship  <danw@novell.com>
2213
2214         * libsoup/soup-ssl.h (SoupSocketError): add
2215         SOUP_SSL_ERROR_CERTIFICATE.
2216
2217         * libsoup/soup-gnutls.c (do_handshake): Pass the GError to
2218         verify_certificate.
2219         (verify_certificate): Set the GError appropriately rather than
2220         spewing g_warnings.
2221
2222         * libsoup/soup-socket.c (read_from_network, soup_socket_write): If
2223         the GIOChannel operation returns an error, store it as GOBject
2224         data on the socket (as a hack so soup-message-io.c can access it
2225         without us needing to change SoupSocket's API).
2226
2227         * libsoup/soup-message-io.c (io_error): peek at the socket's
2228         "last_error" datum and set the message's status to SSL_FAILED
2229         (with the GError's message string) rather than IO_ERROR, if
2230         appropriate. For 64414.
2231
2232 2004-09-30  Dan Winship  <danw@novell.com>
2233
2234         * libsoup/soup-gnutls.c (soup_gnutls_init): Add this, with some
2235         extra initialization needed for libgcrypt 1.2 or higher. Fixes
2236         66342.
2237         (soup_ssl_get_client_credentials,
2238         soup_ssl_get_server_credentials): Call soup_gnutls_init().
2239
2240 2004-08-26  Dan Winship  <danw@novell.com>
2241
2242         * configure.in: Bump version to 2.2.0.
2243
2244         * AUTHORS: Update this to reflect the last 2 years.
2245
2246         * NEWS: Brief summary of 1.99.x -> 2.2 changes
2247
2248         * README, TODO: Updates
2249
2250 2004-08-26  Dan Winship  <danw@novell.com>
2251
2252         * libsoup/*: add/fix lots of gtk-doc comments
2253         
2254         * libsoup/soup-misc.c (soup_str_case_hash, soup_str_case_equal):
2255         Fix bug noticed while documenting. (We were using the
2256         locale-case-insensitive functions rather than the g_ascii_ ones.)
2257
2258         * libsoup/soup-message.h (SoupMessageFlags): remove the (never
2259         implemented) NO_PIPELINE and NO_COOKIE flags.
2260
2261         * docs/reference/tmpl/*.sgml: Regenerate, fill in some stuff.
2262         There are still problems here with gtk-doc not recognizing many of
2263         the objects in libsoup...
2264
2265 2004-08-13  JP Rosevear  <jpr@novell.com>
2266
2267         * configure.in: bump version, libtool number
2268
2269 2004-08-09  Dan Winship  <danw@novell.com>
2270
2271         * libsoup/soup-connection.c (soup_connection_connect_sync): Don't
2272         use conn after emitting the "connect_result" signal, since it
2273         might be destroyed by that. Based on a patch from hpj.
2274
2275 2004-08-02  Dan Winship  <danw@novell.com>
2276
2277         * libsoup/soup-uri.h: Add flag "broken_encoding" to SoupUri.
2278
2279         * libsoup/soup-uri.c: (soup_uri_to_string): if broken_encoding is
2280         set, don't re-encode the URL parts. Based on a patch by
2281         Alfred.Peng@Sun.COM.
2282
2283 2004-07-19  JP Rosevear  <jpr@novell.com>
2284
2285         * configure.in: bump version, libtool number
2286
2287 2004-07-15  Dan Winship  <danw@novell.com>
2288
2289         * libsoup/soup-session-sync.c (send_message): Simplify this. If
2290         the message comes back from soup_connection_send_request not
2291         FINISHED, get a new connection rather than reusing the old one.
2292         This fixes a race condition in which a connection could end up
2293         double-booked, and fixes the handling of messages that get
2294         redirected to another server.
2295
2296 2004-07-13  Dan Winship  <danw@novell.com>
2297
2298         * libsoup/soup-session.c (connect_result): If the connection
2299         attempt succeeded, reserve the connection before releasing
2300         host_lock. Otherwise, another thread might find it in the
2301         connection pool before the caller can queue a message on it.
2302         #60693
2303
2304         * libsoup/soup-session-async.c (got_connection): Call
2305         soup_connection_release(), since we don't have a specific message
2306         in mind for the connection, so we need it to be considered idle.
2307
2308         * libsoup/soup-connection.c (soup_connection_release): New
2309         function, to undo a soup_connection_reserve().
2310         (soup_connection_send_request, soup_connection_reserve,
2311         soup_connection_authenticate, soup_connection_reauthenticate):
2312         Document these
2313
2314 2004-07-12  Dan Winship  <danw@novell.com>
2315
2316         * libsoup/soup-session-sync.c (send_message): signal the
2317         "connections available" condition after the message finishes. Duh.
2318
2319         * libsoup-2.2.pc.in (Cflags, Libs): add XML_CFLAGS and XML_LIBS
2320
2321 2004-07-08  Dan Winship  <danw@novell.com>
2322
2323         * libsoup/soup-soap-response.c: Revert previous change for now; it
2324         breaks the build on distros with older libxmls.
2325
2326 2004-07-08  Dan Winship  <danw@novell.com>
2327
2328         * tests/dict.c: Basic SOAP test, using Aonaware's SOAP->DICT
2329         gateway
2330
2331 2004-07-07  Fernando Herrera  <fherrera@onirica.com>
2332
2333         * libsoup/soup-soap-response.c: (finalize), (init),
2334         (soup_soap_response_from_string): Use a parse context for the
2335         xml document, so we can safely use the option to ignore
2336         blank spaces and '\n'.
2337
2338 2004-07-06  Dan Winship  <danw@novell.com>
2339
2340         * libsoup/soup-uri.c (soup_uri_new_with_base): if the protocol is
2341         http or https, require a hostname. For #61049
2342
2343         * tests/uri-parsing.c (rel_tests, do_uri): Update for that
2344
2345 2004-06-03  JP Rosevear <jpr@novell.com>
2346
2347         * configure.in: bump version to 2.1.11, libtool number
2348
2349 2004-06-01  Dan Winship  <danw@novell.com>
2350
2351         * libsoup/soup-address.c: Redo the various IPv4/IPv6-abstracting
2352         macros to not use ?: expressions as lvalues, since that's
2353         apparently a GNU extension.
2354         (soup_address_resolve_async): Use a timeout rather than an idle
2355         handler to poll the dns result. (soup-dns really should be
2356         rewritten to not require polling, but this is easier for now.)
2357         #59240
2358
2359         * libsoup/soup-server.c (call_handler): Don't use GNU-only
2360         non-constant structure initialization
2361
2362         * tests/dns.c: Simple test of the dns code
2363
2364         * tests/Makefile.am (noinst_PROGRAMS): build it
2365
2366 2004-05-19  JP Rosevear  <jpr@novell.com>
2367
2368         * configure.in (SOUP_API_VERSION): bump version, libtool numbers
2369
2370 2004-05-18  Dan Winship  <danw@novell.com>
2371
2372         * libsoup/soup-ssl.h:
2373         * libsoup/soup-nossl.c: define some GError codes and stuff
2374
2375         * libsoup/soup-gnutls.c: add missing #include <gnutls/x509.h>
2376         (do_handshake): when returning G_IO_STATUS_AGAIN, set the GError
2377         to SOUP_SSL_ERROR_HANDSHAKE_NEEDS_READ or _NEEDS_WRITE
2378         appropriately.
2379
2380         * libsoup/soup-socket.c (soup_socket_write): Handle
2381         SOUP_SSL_ERROR_HANDSHAKE_NEEDS_READ, by setting an io watch for
2382         G_IO_IN instead of G_IO_OUT. Fixes the rcd-sucking-up-all-cpu bug
2383         (#58434)
2384         (read_from_network): Handle the reverse case (which would cause
2385         hanging rather than spinning, and might be the cause of some
2386         connector 1.5 slowness?)
2387
2388 2004-05-11  Dan Winship  <danw@novell.com>
2389
2390         * libsoup/soup-misc.c (soup_signal_connect_once): Do this less
2391         kludgefully, using the magic of GClosure, to fix x86_64 problems
2392         reported by snorp.
2393
2394 2004-05-04  Sivaiah Nallagatla <snallagatla@novell.com>
2395
2396         * libsoup/soup-soap-message.c (finalize) : free
2397         the elements of priv structure before freeing priv
2398
2399 2004-04-20  Dan Winship  <danw@ximian.com>
2400
2401         * libsoup/soup-connection-ntlm.c (ntlm_authorize_post): if
2402         re-sending the message, call soup_message_restarted()
2403         (send_request): Connect to "restarted" signal, and remove the 401
2404         handlers from there; doing it here didn't work because if the
2405         connection was closed, the message would be re-sent on a new
2406         connection, but would still have the handlers from the old
2407         connection attached to it, which would make authentication fail.
2408
2409         * libsoup/soup-message-handlers.c (soup_message_run_handlers):
2410         Copy the handler list before starting, to protect against handlers
2411         that modify the handler list.
2412
2413 2004-04-15  Dan Winship  <danw@ximian.com>
2414
2415         * libsoup/soup-connection.c (soup_connection_connect_sync):
2416         Connect to the socket's "disconnect" signal. (We were only doing
2417         this from the async version before, which meant that synchronous
2418         SoupConnections could outlive their sockets and start causing
2419         errors.) #57004
2420
2421         * libsoup/soup-connection-ntlm.c (send_request): Remove the old
2422         Authorization header before adding a new one.
2423
2424 2004-04-02  JP Rosevear  <jpr@ximian.com>
2425
2426         * configure.in: bump version, libtool number
2427
2428 2004-03-15  Dan Winship  <danw@ximian.com>
2429
2430         * libsoup/soup-soap-message.c (soup_soap_message_persist): Fix up
2431         types to kill a warning with -Wall -O2
2432
2433 2004-03-05  JP Rosevear <jpr@ximian.com>
2434
2435         * configure.in: bump version, libtool number
2436
2437 2004-03-02  Dan Winship  <danw@ximian.com>
2438
2439         * libsoup/soup-dns.c (check_hostent): Only loop on EINTR if
2440         bytes_read is -1, since the value of errno is irrelevant when
2441         bytes_read is 0. Probably #54960.
2442
2443 2004-03-01  Rodrigo Moya <rodrigo@ximian.com>
2444
2445         * libsoup/soup-soap-response.h: removed not-implemented function's
2446         prototype.
2447
2448 2004-02-27  Rodney Dawes  <dobey@ximian.com>
2449
2450         * configure.in:
2451         * libsoup/Makefile.am: Use a different variable for linking to the
2452         static version of gnutls, so we don't pull the .a files into the .pc
2453
2454         Fixes #53346
2455
2456 2004-02-20  Dan Winship  <danw@ximian.com>
2457
2458         * libsoup/soup-message-io.c (read_metadata, read_body_chunk,
2459         write_data): Pass gsize *, not guint *, to soup_socket_read/write,
2460         to make this work on 64-bit platforms. (Grr. C type checking
2461         sucks.) #54631
2462         
2463         * tests/revserver.c: Likewise
2464
2465 2004-02-18  Rodrigo Moya <rodrigo@ximian.com>
2466
2467         Fixes #54512
2468
2469         * libsoup/soup-soap-response.c (soup_soap_parameter_get_int_value):
2470         don't leak the value returned from xmlNodeGetContent().
2471         (soup_soap_parameter_get_string_value,
2472         soup_soap_parameter_get_property): return a g_strdup'ed
2473         string, not the value returned by xmlNodeGetContent, so that
2474         callers can use g_free, and not xmlFree.
2475
2476         * libsoup/soup-soap-response.h: made soup_parameter_get_property
2477         not return const.
2478
2479 2004-02-17  Dan Winship  <danw@ximian.com>
2480
2481         * libsoup/soup-soap-message.h (SOUP_IS_SOAP_MESSAGE_CLASS): Fix a
2482         typo. #54433, from Mariano Suarez-Alvarez.
2483
2484         * libsoup/soup-soap-response.h (SOUP_IS_SOAP_RESPONSE_CLASS):
2485         Likewise
2486
2487 2004-02-17  Rodney Dawes  <dobey@ximian.com>
2488
2489         * libsoup/soup-message.c (soup_message_new): HTTP connections require
2490         a hostname, and we also hash on the host for message queueing in the
2491         session, if the host is NULL we free the SoupUri and return NULL
2492
2493 2004-02-14  Dan Winship  <danw@ximian.com>
2494
2495         * configure.in: Use POSIX-compliant "test $foo = bar", rather than
2496         GNU-only "test $foo == bar". #54354, from Julio M. Merino Vidal.
2497
2498 2004-02-12  Joe Shaw  <joe@ximian.com>
2499
2500         * libsoup/soup-dns.c (check_hostent): Call read() in a do-while
2501         loop to prevent DNS errors from short reads.
2502
2503 2004-02-11  Joe Shaw  <joe@ximian.com>
2504
2505         * configure.in: Bumped version number to 2.1.7 and libtool
2506         current. 
2507
2508 2004-02-11  Dan Winship  <danw@ximian.com>
2509
2510         * libsoup/soup-connection.c (soup_connection_disconnect): Update
2511         Joe's comment here with a gory explanation of exactly what's going
2512         on. (It's not just an SSL bug either, it affects all connections.)
2513
2514 2004-02-10  Joe Shaw  <joe@ximian.com>
2515
2516         * libsoup/soup-connection.c (soup_connection_disconnect): Add a
2517         workaround for SSL connections which time-out but don't close the
2518         socket until we try sending data again later.
2519
2520         * libsoup/soup-socket.c (soup_socket_connect, soup_socket_listen):
2521         Don't free the sockaddr from soup_address_get_sockaddr(); we don't
2522         own it, the SoupAddress does.
2523
2524 2004-02-09  JP Rosevear  <jpr@ximian.com>
2525
2526         * configure.in: Bump libtool numbers
2527
2528 2004-02-05  Dan Winship  <danw@ximian.com>
2529
2530         * libsoup/soup-session.c (soup_session_add_filter): Ref the filter
2531         when adding it.
2532         (soup_session_remove_filter): And unref it here (we were already
2533         unreffing it in dispose().)
2534
2535 2004-02-05  Joe Shaw  <joe@ximian.com>
2536
2537         * libsoup/soup-dns.c (soup_dns_entry_unref): Don't try to free the
2538         hostent if it's NULL.
2539         (soup_dns_entry_check_lookup): If the entry is resolved, but the
2540         hostent is NULL, uncache it.
2541
2542 2004-02-04  Dan Winship  <danw@ximian.com>
2543
2544         * libsoup/soup-connection-ntlm.c (ntlm_authorize_pre): Always
2545         remove the WWW-Authenticate headers before returning, so the
2546         session won't fall back to Basic auth. Also, leave the connection
2547         in the "authenticating" state rather than setting it to
2548         "authenticated".
2549         (ntlm_authorize_post): Only requeue the message if it's in the
2550         "authenticating" state (and set it to "authenticated"). Fixes an
2551         "unepectedly disconnected" error if authentication fails.
2552
2553 2004-02-03  Dan Winship  <danw@ximian.com>
2554
2555         * libsoup/soup-message-io.c (io_cleanup): Call
2556         soup_message_io_stop so we don't get a callback on the io after
2557         it's been cleaned up.
2558
2559         * libsoup/soup-session.c (add_auth): Only remove the Authorization
2560         header if we have another one to add. (Otherwise it messes up
2561         SoupConnectionNTLM.)
2562
2563         * libsoup/soup-socket.c (read_from_buf): Use memmove rather than
2564         memcpy here, since the source and destination will overlap if
2565         *nread is small and read_buf->len is large. (Noticed by valgrind,
2566         #53625.)
2567
2568 2004-02-02  Joe Shaw  <joe@ximian.com>
2569
2570         * libsoup/soup-gnutls.c (soup_gnutls_close): Call gnutls_bye()
2571         with the GNUTLS_SHUT_WR flag (instead of RDWR) and check only for
2572         GNUTLS_E_INTERRUPTED.  GNUTLS_E_AGAIN will be returned by recv()
2573         when there are no messages on the wire on a non-blocking socket.
2574         This sends a SSL hangup message and then allows us to immediately
2575         close the socket.
2576
2577 2004-01-30  Rodrigo Moya <rodrigo@ximian.com>
2578
2579         * configure.in: bumped version number to 2.1.6.
2580
2581 2004-01-29  Rodrigo Moya <rodrigo@ximian.com>
2582
2583         * libsoup/soup-soap-response.[ch] (soup_soap_parameter_get_property):
2584         new function.
2585
2586 2004-01-29  Rodrigo Moya <rodrigo@ximian.com>
2587
2588         * libsoup/soup-soap-response.[ch]
2589         (soup_soap_parameter_get_string_value): removed 'const' from return
2590         type.
2591
2592 2004-01-29  Joe Shaw  <joe@ximian.com>
2593
2594         * libsoup/soup-gnutls.c (verify_certificate): Initialize the
2595         certificate before we try to use it.  Ahem.
2596
2597 2004-01-23  Joe Shaw  <joe@ximian.com>
2598
2599         * configure.in: Bump version to 2.1.5 and SOUP_RELEASE to 2
2600
2601 2004-01-21  Joe Shaw  <joe@ximian.com>
2602
2603         * configure.in: Require at least GnuTLS 1.0.0.
2604
2605         * libsoup/soup-gnutls.c: Fix the use of deprecated GnuTLS
2606         functions.
2607         (verify_certificate): Use gnutls_x509_crt_import() and
2608         gnutls_x509_crt_check_hostname() instead of
2609         gnutls_x509_check_certificates_hostname().
2610         (init_dh_params): Use gnutls_dh_params_generate2() instead of
2611         gnutls_dh_params_generate() and gnutls_dh_params_set().
2612
2613 2004-01-20  Joe Shaw  <joe@ximian.com>
2614
2615         * libsoup/soup-gnutls.c (soup_gnutls_close): gnutls_bye() doesn't
2616         close the socket itself, so we need to do it or else our
2617         connections stay in CLOSE_WAIT forever.
2618
2619 2004-01-16  Jason Leach  <leach@wam.umd.edu>
2620
2621         * libsoup/Makefile.am: builddir != srcdir fixes.
2622
2623 2004-01-14  Joe Shaw  <joe@ximian.com>
2624
2625         * libsoup/soup-gnutls.c (verify_certificate): Remove the
2626         check for GNUTLS_CERT_CORRUPTED, it's not in 1.0.x.
2627
2628 2004-01-12  JP Rosevear  <jpr@ximian.com>
2629
2630         * configure.in: bump version and libtool revision
2631
2632 2004-01-12  Dan Winship  <danw@ximian.com>
2633
2634         * tests/simple-httpd.c (main): Add a g_thread_init() so this works
2635         again.
2636
2637 2004-01-10  Larry Ewing  <lewing@ximian.com>
2638
2639         * libsoup-2.2.pc.in (Libs): use LIBGNUTLS_LIBS in the substitution
2640         string.
2641
2642 2004-01-09  Joe Shaw  <joe@ximian.com>
2643
2644         * acinclude.m4: Include the libgnutls.m4 file.
2645
2646         * configure.in: Remove manual checking for libgnutls-config and
2647         use the AM_PATH_LIBGNUTLS so we can pass in a minimum required
2648         version, which is 0.9.7 for now.
2649
2650         * libsoup/Makefile.am: Some changes for the above change.
2651
2652         * libsoup/soup-gnutls.c: Check for HAVE_SSL, not
2653         HAVE_GNUTLS_GNUTLS_H.
2654         (verify_certificate): Uncomment the SSL certificate hostname
2655         check.
2656
2657         * libsoup/soup-session.c (set_property): Be smart about flushing
2658         our SSL credentials only when the CA file is set to something
2659         different than it was before.
2660
2661 2004-01-09  Harish K <kharish@novell.com>
2662         * libsoup/soup-soap-response.c (soup_soap_response_from_string): 
2663         added code to ignore Header element, if present, while creating 
2664         response objects.  
2665         
2666 2004-01-05  Dan Winship  <danw@ximian.com>
2667
2668         * configure.in: Remove no-longer-relevant socklen_t check
2669
2670         * libsoup/soup-address.c: Reorder #includes for FreeBSD (From Joe
2671         Marcus Clarke, #52566)
2672
2673         * libsoup/soup-dns.c: Likewise
2674
2675 2003-12-29  JP Rosevear <jpr@ximian.com>
2676
2677         * configure.in: bump version and libtool numbers
2678
2679 2003-12-22  Dan Winship  <danw@ximian.com>
2680
2681         * README, TODO: Update these
2682
2683 2003-12-22  Dan Winship  <danw@ximian.com>
2684
2685         * libsoup/soup-socket.c: Lots of thread-safety stuff, primarly so
2686         you can disconnect a socket from one thread while doing I/O in
2687         another.
2688
2689         * libsoup/soup-message-io.c (soup_message_io_cancel): Split into
2690         soup_message_io_stop() and io_cleanup(), to separate out the "stop
2691         reading/writing" and "free data" phases to allow thread-safe
2692         synchronous cancellation.
2693         (soup_message_io_finished): call both soup_message_io_stop() and
2694         io_cleanup()
2695         (io_error): Only set SOUP_STATUS_IO_ERROR on the message if it
2696         doesn't already have a transport error status (eg, CANCELLED).
2697         (new_iostate): Call io_cleanup() if needed.
2698
2699         * libsoup/soup-status.h: add "SOUP_STATUS_NONE" for 0, to make it
2700         clearer that it's not a status.
2701
2702         * libsoup/soup-message.c (finalize, restarted, finished,
2703         soup_message_set_uri): s/soup_message_io_cancel/soup_message_io_stop/
2704         (soup_message_cleanup_response): s/0/SOUP_STATUS_NONE/
2705
2706         * libsoup/soup-connection.c (send_request): Remove
2707         soup_message_io_cancel call.
2708
2709         * libsoup/soup-session-sync.c (send_message): Connect to the
2710         connection's "disconnected" signal rather than using a weak ref,
2711         since that's what we really care about, and it's possible that the
2712         connection may have an extra ref on it somewhere that would keep
2713         it from being destroyed even if it was disconnected.
2714
2715 2003-12-20  Joe Shaw  <joe@ximian.com>
2716
2717         * libsoup/soup-session.c (lookup_auth): If const_path is NULL un
2718         the non-proxy case, then use the root ("/").
2719
2720 2003-12-19  Dan Winship  <danw@ximian.com>
2721
2722         * libsoup/soup-message-filter.c: New. An interface for objects
2723         that want to act on every message passing through a session.
2724         (Initially being used for authentication, but could also be used
2725         for cache handling, cookie management, etc.)
2726
2727         * libsoup/soup-connection.c (class_init, etc): Add a message
2728         filter property.
2729         (send_request): If the connection has a message filter set, run
2730         it on the message before sending it.
2731         (soup_connection_connect_async, etc): When setting up a tunnel, if
2732         we get back a 407 and the session tries to requeue the message,
2733         either re-send it, or return SOUP_STATUS_TRY_AGAIN (depending on
2734         whether or not the proxy closed the connection).
2735         (soup_connection_connect_sync): Likewise
2736         (send_request, request_done): Ref/unref the connection
2737
2738         * libsoup/soup-session.c (soup_session_get_type): Implement the
2739         SoupMessageFilter interface.
2740         (soup_session_get_connection): Use the session as the connection's
2741         message filter
2742         (soup_session_add_filter, soup_session_remove_filter): Add/remove
2743         filters from the session
2744         (setup_message): do auth handling, and call each of the session's
2745         filters' setup_message methods as well.
2746         (soup_session_send_message_via): No longer needed.
2747         (connect_result): Handle SOUP_STATUS_TRY_AGAIN.
2748
2749         * libsoup/soup-session-async.c (run_queue): Use
2750         soup_connection_send_request, since soup_session_send_message_via
2751         is gone now.
2752
2753         * libsoup/soup-session-sync.c (send_message): Likewise
2754
2755         * libsoup/soup-message.c (soup_message_is_keepalive): A successful
2756         response to a CONNECT is always keepalive, even if it's HTTP/1.0
2757         with no Connection header.
2758
2759         * libsoup/soup-status.h: add SOUP_STATUS_TRY_AGAIN
2760
2761         * libsoup/soup-types.h: Add SoupMessageFilter, and macros for
2762         gobject interface types.
2763
2764         * tests/get.c (main): Add a -p flag to specify a proxy
2765
2766         * tests/simple-proxy.c: Fix #includes
2767
2768 2003-12-18  Dan Winship  <danw@ximian.com>
2769
2770         * libsoup/soup-connection.c (soup_connection_disconnect): Actually
2771         disconnect the socket rather than just unreffing it, since the IO
2772         code may be holding an extra ref on it.
2773         (send_request): connect to the "restarted" signal too
2774         (request_restarted): Deal with "Connection: close"
2775
2776         * libsoup/soup-connection-ntlm.c (ntlm_authorize_pre): Make this
2777         not go into an infinite loop if the server only supports Basic.
2778
2779 2003-12-17  Rodrigo Moya <rodrigo@ximian.com>
2780
2781         * libsoup/Makefile.am: install soup-message-queue.h with the rest
2782         of the headers.
2783
2784 2003-12-17  Dan Winship  <danw@ximian.com>
2785
2786         * configure.in: Add gthread to glib check
2787
2788         * libsoup/soup-session.c: Make this an abstract class.
2789
2790         * libsoup/soup-session-async.c: A SoupSession class for
2791         asynchronous gmain-based operation; replaces the old SoupSession.
2792
2793         * libsoup/soup-session-sync.c: A SoupSession class for synchronous
2794         blocking operation for use with threaded apps.
2795
2796         * libsoup/soup-types.h, libsoup/soup.h: add the new session
2797         subclasses
2798
2799         * libsoup/soup-connection.c (soup_connection_connect_sync): Don't
2800         try to unref the socket if the socket creation fails.
2801         (soup_connection_reserve): New, to explicitly mark a connection as
2802         being in use without queueing a message on it.
2803
2804         * libsoup/soup-dns.c (check_hostent): Oof. Fix the logic of the
2805         "block" flag to not be reversed.
2806
2807         * libsoup/soup-message.c (finished): set status to FINISHED here.
2808         (soup_message_cancel): Gone; needs to be done at the session
2809         level.
2810
2811         * libsoup/soup-message-queue.c: Add a mutex and make all of the
2812         operations thread-safe.
2813
2814         * libsoup/soup-socket.c (disconnect_internal): Make this
2815         thread-safe.
2816         (soup_socket_connect): Make the sync case work correctly.
2817
2818         * libsoup/Makefile.am: add the SoupSession subclasses
2819
2820         * tests/Makefile.am: libsoup depends on libgthread now, so
2821         revserver doesn't need to explicitly.
2822
2823         * tests/get.c, tests/auth-test.c, tests/simple-proxy.c: Use
2824         soup_session_async_new().
2825
2826 2003-12-16  Rodrigo Moya <rodrigo@ximian.com>
2827
2828         * libsoup/soup-soap-response.[ch] (soup_soap_parameter_get_int_value):
2829         new function.
2830
2831 2003-12-16  Joe Shaw  <joe@ximian.com>
2832
2833         * libsoup/soup-connection.c (socket_connect_result,
2834         soup_connection_connect_sync): Only set up a tunnel if the
2835         destination protocol is HTTPS.
2836
2837         * libsoup/soup-message.c (class_init): Add a default handler for
2838         wrote_body.
2839         (wrote_body): Run the SOUP_HANDLER_POST_REQUEST handlers here.
2840         (soup_message_cancel): Don't set the status to
2841         SOUP_STATUS_CANCELLED and call soup_message_finished() if the
2842         status is already SOUP_MESSAGE_STATUS_FINISHED.
2843
2844         * libsoup/soup-session.c (set_property): Don't cancel the session
2845         if the proxy URI set as a property isn't different from the old
2846         one.
2847         (get_host_for_message): Refactor some code so that we can easily
2848         get the right SoupSessionHost for proxies as well as from the
2849         message.
2850         (authenticate_auth): Take a gboolean proxy parameter.  Check it to
2851         see which URI (message URI or proxy URI) to use for
2852         authentication.  Add a long comment about lack of clarity in RFC
2853         2617 with respect to proxies and protection spaces.
2854
2855 2003-12-15  Dan Winship  <danw@ximian.com>
2856
2857         * libsoup/soup-socket.h (soup_socket_read, soup_socket_read_until,
2858         soup_socket_write): s/guint/gsize/ to match the definitions in
2859         soup-socket.c. #52167.
2860
2861 2003-12-12  Rodrigo Moya <rodrigo@ximian.com>
2862
2863         * libsoup/soup-soap-message.c: removed debugging of the messages here.
2864
2865 2003-12-12  Rodrigo Moya <rodrigo@ximian.com>
2866
2867         * libsoup/soup-soap-message.c (soup_soap_message_start_envelope):
2868         added information for SOAP-ENV namespace.
2869
2870 2003-12-10  Dan Winship  <danw@ximian.com>
2871
2872         * libsoup/soup-message-client-io.c (parse_response_headers): if we
2873         receive an HTTP/1.0 response to an HTTP/1.1 request, downgrade the
2874         message's http_version so the keep-alive handling is correct.
2875         Fixes a problem noticed almost simultaneously by Rodrigo and Joe.
2876
2877         * libsoup/soup-message.c (soup_message_restarted, etc): Add a
2878         "restarted" signal as suggested by Joe.
2879
2880         * libsoup/soup-message-io.c (soup_message_io_finished): emit
2881         either "restarted" or "finished" as appropriate
2882
2883         * libsoup/soup-session.c (soup_session_queue_message): Connect to
2884         "restarted" and run the queue if a message gets restarted
2885
2886         * libsoup/soup-status.h: Remove a stray comma that gtk-doc doesn't
2887         like.
2888
2889 2003-12-10  Tambet Ingo  <tambet@ximian.com>
2890
2891         * configure.in: Use autoconfig to check for socklen_t ...
2892
2893         * libsoup/soup-address.c: ... and remove it from here ...
2894
2895         * libsoup/soup-dns.c: ... and here.
2896
2897 2003-12-09  Rodrigo Moya <rodrigo@ximian.com>
2898
2899         * libsoup/soup-soap-message.c (soup_soap_message_persist):
2900         (soup_soap_message_parse_response): print out request/response's
2901         contents, if in debug mode.
2902
2903 2003-12-07  JP Rosevear  <jpr@ximian.com>
2904
2905         * configure.in: Bump version
2906
2907 2003-11-28  Rodrigo Moya <rodrigo@ximian.com>
2908
2909         * libsoup/soup-soap-response.[ch]
2910         (soup_soap_parameter_get_first_child,
2911         soup_soap_parameter_get_first_child_by_name,
2912         soup_soap_parameter_get_next_child,
2913         soup_soap_parameter_get_next_child_by_name): new functions to
2914         manage SoupSoapParameter's children.
2915         (soup_soap_response_get_first_parameter): dont return a GList, but
2916         a SoupSoapParameter contained in the GList.
2917
2918 2003-11-26  Rodrigo Moya <rodrigo@ximian.com>
2919
2920         * libsoup/soup-soap-response.[ch]
2921         (soup_soap_parameter_get_string_value): new function.
2922
2923 2003-11-26  Rodrigo Moya <rodrigo@ximian.com>
2924
2925         * libsoup/soup-soap-response.[ch]: added SoupSoapParameter
2926         structure, to "hide" the usage of xmlNode's.
2927         (soup_soap_parameter_get_name): functions to manage SOAP
2928         response parameters.
2929         (soup_soap_response_get_first_parameter,
2930         soup_soap_response_get_first_parameter_by_name,
2931         soup_soap_response_get_next_parameter,
2932         soup_soap_response_get_next_parameter_by_name):
2933         new functions for an easy access to the response's parameters.
2934         (soup_soap_response_from_string): removed warnings.
2935
2936 2003-11-25  Rodrigo Moya <rodrigo@ximian.com>
2937
2938         * libsoup/soup-soap-response.c (soup_soap_response_set_method_name):
2939         fixed typo.
2940
2941 2003-11-25  Rodrigo Moya <rodrigo@ximian.com>
2942
2943         * libsoup/soup-soap-response.[ch] (soup_soap_response_get_method_name,
2944         soup_soap_response_set_method_name, soup_soap_message_get_parameters):
2945         new functions.
2946         (finalize): NULL out new private fields.
2947         (soup_soap_response_from_string): added validation code.
2948
2949 2003-11-23  Rodrigo Moya <rodrigo@ximian.com>
2950
2951         * libsoup/soup-soap-response.[ch]: new class for managing SOAP
2952         responses.
2953
2954         * libsoup/soup-soap-message.[ch] (soup_soap_message_parse_response):
2955         new function.
2956
2957         * libsoup/Makefile.am: added new files.
2958
2959 2003-11-18  Rodney Dawes  <dobey@ximian.com>
2960
2961         * gtk-doc.make: Add gtk-doc.make to cvs for systems without gtk-doc
2962
2963 2003-11-18  Rodney Dawes  <dobey@ximian.com>
2964
2965         * acinclude.m4: Add GTK_DOC_CHECK
2966
2967 2003-11-18  Dan Winship  <danw@ximian.com>
2968
2969         * configure.in: Replace old gtk-doc test with GTK_DOC_CHECK()
2970         (AC_OUTPUT): add docs/Makefile, docs/reference/Makefile
2971
2972         * autogen.sh (REQUIRED_AUTOMAKE_VERSION): 1.6, for gtk-doc.make
2973
2974         * Makefile.am: updates for gtk-doc
2975         (SUBDIRS): add back "docs"
2976
2977         * docs/Makefile.am (EXTRA_DIST): remove, since those old docs
2978         aren't around any more
2979
2980         * docs/reference/*: set up gtk-doc
2981
2982         * libsoup/Makefile.am (INCLUDES): Change G_LOG_DOMAIN to
2983         "libsoup". Remove unused defines.
2984
2985         * libsoup/soup-connection.c: Fix doc comments
2986         * libsoup/soup-message.c: Likewise
2987         * libsoup/soup-misc.c: Likewise
2988         * libsoup/soup-socket.c: Likewise
2989         * libsoup/soup-uri.c: Likewise
2990
2991         * libsoup/soup-address.h: Fixes to please gtk-doc
2992         * libsoup/soup-connection.h: Likewise
2993         * libsoup/soup-message.h: Likewise
2994         * libsoup/soup-message-private.h: Likewise
2995         * libsoup/soup-misc.h: Likewise
2996         * libsoup/soup-server-auth.h: Likewise
2997         * libsoup/soup-socket.h: Likewise
2998         * libsoup/soup-status.h: Likewise
2999
3000 2003-11-18  Dan Winship  <danw@ximian.com>
3001
3002         * configure.in: Fix up the SSL checks some. Remove some useless
3003         old header checks.
3004
3005         * libsoup/soup-misc.h: declare soup_ssl_supported.
3006
3007         * libsoup/soup-gnutls.c: add soup_ssl_supported declaration.
3008
3009         * libsoup/soup-nossl.c: Not an SSL implementation, built if
3010         HAVE_SSL is not defined.
3011
3012         * libsoup/Makefile.am (libsoup_2_2_la_SOURCES): add soup-nossl.c
3013
3014         * libsoup/soup-socket.c (soup_socket_start_ssl): Return success or
3015         failure.
3016         (listen_watch): Deal with soup_socket_start_ssl failing.
3017
3018         * libsoup/soup-connection.c (tunnel_connect_finished,
3019         socket_connect_result, soup_connection_connect_sync): Deal with
3020         the soup_socket_start_ssl failing.
3021
3022         * libsoup/soup-server.c (soup_server_new): Deal with
3023         soup_ssl_get_server_credentials failing
3024
3025 2003-11-18  Rodrigo Moya <rodrigo@ximian.com>
3026
3027         * libsoup/soup-soap-message.[ch] (soup_soap_message_start_fault,
3028         soup_soap_message_end_fault, soup_soap_message_start_fault_detail,
3029         soup_soap_message_end_fault_detail, soup_soap_message_start_header,
3030         soup_soap_message_end_header,
3031         soup_soap_message_start_header_element,
3032         soup_soap_message_end_header_element, soup_soap_message_write_int,
3033         soup_soap_message_write_double, soup_soap_message_write_base64,
3034         soup_soap_message_write_time, soup_soap_message_write_string,
3035         soup_soap_message_write_buffer, soup_soap_message_set_element_type,
3036         soup_soap_message_set_null, soup_soap_message_add_attribute,
3037         soup_soap_message_add_namespace,
3038         soup_soap_message_set_default_namespace,
3039         soup_soap_message_get_namespace_prefix,
3040         soup_soap_message_set_encoding_style, soup_soap_message_reset,
3041         soup_soap_message_persist): new functions from old SoupSerializer.
3042
3043 2003-11-17  Rodrigo Moya <rodrigo@ximian.com>
3044
3045         * libsoup/soup-soap-message.[ch] (soup_soap_message_new,
3046         soup_soap_message_new_from_uri): added a bunch of initialization
3047         parameters.
3048         (soup_soap_message_get_xml_doc, soup_soap_message_start_envelope,
3049         soup_soap_message_end_envelope, soup_soap_message_start_body,
3050         soup_soap_message_end_body, soup_soap_message_start_element,
3051         soup_soap_message_end_element):
3052         new functions.
3053
3054         * configure.in: depend on libxml-2.0 for the SOAP code.
3055
3056         * libsoup/Makefile.am: use XML CFLAGS and LIBS.
3057
3058 2003-11-17  Joe Shaw  <joe@ximian.com>
3059
3060         * configure.in: Add in the --enable-libgpg-error flag from the 2.0
3061         branch.
3062
3063         * acinclude.m4: Include the gpg-error macros.
3064
3065 2003-11-17  Rodrigo Moya <rodrigo@ximian.com>
3066
3067         * libsoup/soup-soap-message.[ch]: new class to make it easier to
3068         build SOAP messages.
3069
3070         * libsoup/Makefile.am: added new files.
3071
3072         * configure.in: increased version number.
3073
3074 2003-10-24  Joe Shaw  <joe@ximian.com>
3075
3076         * libsoup/soup-address.c (update_address_from_entry): Call
3077         soup_dns_entry_get_hostent() on the SoupAddress passed in, not the
3078         one in addr->priv->lookup.  Fixes a crash on synchronous DNS
3079         lookups.
3080
3081         * libsoup/soup-server.c (soup_server_new): We need to ref the
3082         address we're binding to, because soup_socket_get_local_address()
3083         doesn't ref for us.
3084
3085 2003-10-23  Dan Winship  <danw@ximian.com>
3086
3087         * libsoup/soup-socket.c (init): Initialize flags to default
3088         values.
3089
3090 2003-09-23  Dan Winship  <danw@ximian.com>
3091
3092         * libsoup/soup-gnutls.c (SoupGNUTLSCred): Remove refcounting, but
3093         note whether or not the CA file has been loaded.
3094         (SoupGNUTLSChannel): add a "hostname" field.
3095         (verify_certificate): Remove the comment about not being able to
3096         verify the hostname because of soup problems. Now it's because of
3097         GNUTLS problems instead.
3098         (soup_ssl_wrap_iochannel): Renamed from soup_ssl_get_iochannel,
3099         and takes a hostname and a creds argument now.
3100         (soup_ssl_get_client_credentials,
3101         soup_ssl_get_server_credentials): Return client/server credentials
3102         structures.
3103         (soup_ssl_free_client_credentials,
3104         soup_ssl_free_server_credentials): and free them.
3105
3106         * libsoup/soup-session.c (class_init, set_property, get_property):
3107         add ssl_ca_file property
3108         (get_host_for_message): when returning an SSL host for the first
3109         time, create a client credentials structure for the session.
3110         (run_queue): Pass the ssl creds to the new connection. Also fix an
3111         unrelated bug that caused infinite loops on "bad hostname".
3112
3113         * libsoup/soup-server.c: Use GObject properties, including
3114         ssl_cert_file and ssl_key_file properties.
3115         (soup_server_new): Remove "protocol" argument; if the cert file
3116         and key file properties were set, create a server credential
3117         structure from them and pass that to soup_socket_server_new.
3118
3119         * libsoup/soup-connection.c (SoupConnectionPrivate): Rename
3120         dest_uri to origin_uri to match RFC 2616 terminology. Add an
3121         "ssl_creds" field.
3122         (class_init, set_property, get_property): add SSL_CREDS property
3123         (soup_connection_connect_async, soup_connection_connect_sync):
3124         Pass ssl_creds to soup_socket_client_new calls.
3125
3126         * libsoup/soup-socket.c: Use GObject properties, including an
3127         ssl_creds property
3128         (soup_socket_set_flags): Gone (replaced with boolean properties)
3129         (soup_socket_new): Make this take a list of properties
3130         (listen_watch): copy ssl creds from listener to new socket
3131         (soup_socket_start_ssl): Pass remote hostname and socket creds
3132         structure to soup_ssl_wrap_iochannel.
3133         (soup_socket_client_new_async, soup_socket_client_new_sync,
3134         soup_socket_server_new): Replace the SSL boolean with an ssl_creds
3135         structure.
3136
3137         * libsoup/soup-misc.c (soup_set_ssl_ca_file,
3138         soup_set_ssl_cert_files, soup_get_ssl_ca_file,
3139         soup_get_ssl_cert_files): Gone. SSL state is now per-session or
3140         per-server.
3141
3142         * tests/get.c: add a "-c CAfile" argument, for loading a CA
3143         certificate file to validate https connections against
3144
3145         * tests/simple-httpd.c: Add "-c certfile" and "-k keyfile"
3146         arguments for loading an SSL server certificate. Only start an SSL
3147         server if those arguments were used.
3148
3149         * tests/test-cert.pem: 
3150         * tests/test-key.pem: SSL certificate for testing simple-httpd
3151
3152         * tests/revserver.c: Update for API changes
3153         * tests/simple-proxy.c: Likewise
3154
3155 2003-09-22  Dan Winship  <danw@ximian.com>
3156
3157         * libsoup/soup-message-io.c: Move RESPONSE_BLOCK_SIZE #define here
3158         from soup-private.h
3159
3160         * libsoup/soup-misc.c (soup_load_config, etc): Remove all this.
3161         (soup_set_security_policy, soup_get_security_policy): Remove,
3162         since the GNUTLS backend doesn't actually implement it.
3163         (soup_set_ssl_ca_dir, soup_get_ssl_ca_dir): Likewise
3164
3165         * libsoup/soup-misc.h: sync to soup-misc.c. Don't #include extra
3166         stuff.
3167
3168         * libsoup/soup-types.h (SOUP_MAKE_TYPE): Move this here from
3169         soup-private.h
3170
3171         * libsoup/soup-ssl.h: Merge soup_ssl_get_iochannel and
3172         soup_ssl_get_server_iochannel into a single function that takes a
3173         SoupSSLType.
3174
3175         * libsoup/soup-gnutls.c: Remove soup_get_ssl_ca_dir() reference.
3176         (soup_ssl_get_iochannel): Renamed from soup_gnutls_get_iochannel.
3177         (soup_gnutls_set_security_policy): Gone
3178
3179         * libsoup/soup-gnutls.h
3180         * libsoup/soup-ssl.c: Gone; soup-ssl.h is the #include file for
3181         soup-gnutls.c now
3182
3183         * libsoup/soup-socket.c: Move soup_sockaddr_max
3184         #define here from soup-private.h
3185         (soup_socket_start_ssl): Update for new soup_ssl_get_iochannel
3186         prototype.
3187
3188         * libsoup/soup-private.h: Gone
3189         
3190         * libsoup/soup-address.c: Fix #includes for soup-private.h and
3191         soup-misc.h changes
3192         * libsoup/soup-auth-digest.c: Likewise
3193         * libsoup/soup-auth.c: Likewise
3194         * libsoup/soup-connection-ntlm.c: Likewise
3195         * libsoup/soup-connection.c: Likewise
3196         * libsoup/soup-dns.c: Likewise
3197         * libsoup/soup-gnutls.c: Likewise
3198         * libsoup/soup-headers.c: Likewise
3199         * libsoup/soup-message-client-io.c: Likewise
3200         * libsoup/soup-message-handlers.c: Likewise
3201         * libsoup/soup-message-io.c: Likewise
3202         * libsoup/soup-message-server-io.c: Likewise
3203         * libsoup/soup-message.c: Likewise
3204         * libsoup/soup-server-message.c: Likewise
3205         * libsoup/soup-server.c: Likewise
3206         * libsoup/soup-session.c: Likewise
3207         * libsoup/soup-socket.c: Likewise
3208         * tests/auth-test.c: Likewise
3209
3210 2003-09-19  Dan Winship  <danw@ximian.com>
3211
3212         * libsoup/soup-address.c (update_address_from_entry): free the
3213         hostent.
3214
3215         * libsoup/soup-connection-ntlm.c (ntlm_authorize_pre): Don't leak
3216         the domain
3217
3218         * libsoup/soup-gnutls.c (soup_gnutls_get_iochannel): Add some more
3219         iochannel initialization. Not sure how this worked before...
3220
3221         * libsoup/soup-message.c (soup_message_cleanup_response): Renamed
3222         from soup_message_prepare (and a few things removed).
3223
3224         * libsoup/soup-message-client-io.c (soup_message_send_request):
3225         s/soup_message_prepare/soup_message_cleanup_response/
3226
3227         * libsoup/soup-message-io.c (io_read): Replace the final "\r\n"
3228         with "\0" on the headers before passing them to the parse
3229         function.
3230         (io_read): Call soup_message_cleanup_response after returning an
3231         informational response so the data doesn't leak.
3232
3233         * libsoup/soup-headers.c (soup_headers_parse): Update for
3234         soup-message-io.c:io_read change
3235
3236         * libsoup/soup-server.c (soup_server_new,
3237         soup_server_new_with_host): Don't leak the SoupAddress.
3238
3239         * libsoup/soup-session.c (class_init): Make PROP_PROXY_URI not
3240         CONSTRUCT_ONLY.
3241         (set_property): If the proxy uri changes, call
3242         soup_session_abort() and cleanup_hosts().
3243         (request_finished, final_finished): Fix a bug when requeuing
3244         messages.
3245
3246         * tests/libsoup.supp: valgrind suppression file for soup tests
3247
3248         * tests/Makefile.am (EXTRA_DIST): dist it.
3249         (noinst_PROGRAMS): move the former check_PROGRAMS to
3250         noinst_PROGRAMS instead.
3251
3252 2003-09-18  Dan Winship  <danw@ximian.com>
3253
3254         * libsoup/soup-message.c: Add wrote_informational and
3255         got_informational signals.
3256
3257         * libsoup/soup-message-client-io.c (get_request_headers): Set the
3258         EXPECT_CONTINUE flag on the message if that header is set.
3259
3260         * libsoup/soup-message-server-io.c (parse_request_headers):
3261         Likewise
3262
3263         * libsoup/soup-message-io.c (io_write): Set read_state to HEADERS
3264         when blocking on an expect-continue. Emit wrote_informational
3265         instead of wrote_headers in the 1xx case.
3266         (io_read): Set read_state to BLOCKING, not NOT_STARTED after
3267         reading a 100 Continue response. Emit got_informational instead of
3268         got_headers in the 1xx case.
3269
3270         * libsoup/soup-session.c (soup_session_send_message): Reorder
3271         things to deal with the fact that the message could finish right
3272         away if there is a connection available and the server is very
3273         close.
3274
3275         * libsoup/soup-status.h: Rename SOUP_STATUS_CLASS_TRANSPORT to
3276         SOUP_STATUS_CLASS_TRANSPORT_ERROR.
3277
3278 2003-09-17  Dan Winship  <danw@ximian.com>
3279
3280         * libsoup/soup-session.c (find_oldest_connection): Fix two bugs
3281         (one that pruned too little, one that pruned too much).
3282         (queue_message): When requeuing, don't run the queue;
3283         final_finished will take care of that later.
3284         (soup_session_abort): New, to cancel all pending requests.
3285
3286         * libsoup/soup-socket.c (soup_socket_connect, got_address): ref
3287         the socket while waiting for the address to resolve
3288
3289 2003-09-17  Dan Winship  <danw@ximian.com>
3290
3291         * libsoup/soup-connection.c (soup_connection_new): Replaces the
3292         three previous soup_connection_new* functions and uses gobject
3293         properties to set the destination and proxy uris.
3294         (class_init): set up two more signals, authenticate and
3295         reauthenticate.
3296         (soup_connection_send_request): virtualize
3297         (send_request): Default implementation
3298
3299         * libsoup/soup-connection-ntlm.c: New SoupConnection subclass that
3300         also handles NTLM authentication. Includes all of the NTLM code
3301         formerly in soup-auth-ntlm.c.
3302
3303         * libsoup/soup-auth-ntlm.[ch]: Gone.
3304
3305         * libsoup/soup-auth.c: Remove NTLM refs
3306
3307         * libsoup/soup-session.c (class_init): Add gobject properties for
3308         proxy, max_conns, use_ntlm. Change the "authenticate" and
3309         "reauthenticate" signal prototypes to not pass a SoupAuth (so they
3310         can be used for authenticating SoupConnectionNTLM as well, which
3311         doesn't use a SoupAuth).
3312         (soup_session_new): Renamed from soup_session_new_default.
3313         (soup_session_new_with_options): Replaces
3314         soup_session_new_with_proxy and soup_session_new_full. Takes
3315         gobject properties.
3316         (run_queue): Create a new connection of type SoupConnection or
3317         SoupConnectionNTLM depending on our "use_ntlm" property. Connect
3318         to its authenticate and reauthenticate signals.
3319         (connection_authenticate, connection_reauthenticate): proxy these
3320         signals.
3321
3322         * libsoup/soup-address.c (update_address_from_entry): Fix a
3323         crasher when failing to resolve the address.
3324
3325         * libsoup/soup-dns.c (check_hostent): Fix some "how was this
3326         working before" bugs.
3327
3328         * libsoup/soup-message-client-io.c (soup_message_send_request):
3329         call soup_message_prepare() to clean up the existing response
3330         state.
3331
3332         * libsoup/soup-message-io.c (io_error): Set the read_state to DONE
3333         when processing an OK EOF.
3334
3335         * libsoup/soup-status.h (SoupStatusClass): fix the numbering of
3336         these so that SOUP_STATUS_CLASS_SUCCESS is 2, etc.
3337
3338         * tests/auth-test.c (authenticate, reauthenticate): Update for new
3339         prototypes.
3340         (main): Use soup_session_new.
3341         * tests/get.c (main): Likewise.
3342         * tests/simple-proxy.c (main): Likewise.
3343
3344 2003-09-10  Dan Winship  <danw@ximian.com>
3345
3346         * libsoup/soup-session.c: Add "authenticate" and "reauthenticate"
3347         signals.
3348         (invalidate_auth): Remove the call to soup_auth_invalidate.
3349         (authenticate_auth): soup_auth_fn is gone. If the URI doesn't
3350         contain authentication, then emit "authenticate" or
3351         "reauthenticate" (depending on whether or not this is the first
3352         time we've asked for a password for this auth).
3353         (update_auth_internal): If the server rejects our
3354         username/password, don't bail out immediately. Try doing a
3355         "reauthenticate" first.
3356
3357         * libsoup/soup-misc.c (soup_set_authorize_callback): Gone
3358
3359         * libsoup/soup-auth.c (soup_auth_new_from_header_list): Remove the
3360         "pref" arg.
3361         (soup_auth_invalidate): Remove this; it doesn't actually do
3362         anything useful for us.
3363
3364         * libsoup/soup-auth-basic.c (invalidate): Remove
3365         * libsoup/soup-auth-digest.c: (invalidate): Remove
3366         * libsoup/soup-auth-ntlm.c: (invalidate): Remove
3367
3368         * libsoup/soup-uri.c: Remove all references to "authmech".
3369         (soup_uri_set_auth): Remove this too.
3370
3371         * tests/auth-test.c: Update to use the "authenticate" and
3372         "reauthenticate" signals instead of encoding usernames and
3373         passwords in the URIs. Add a few more test cases.
3374
3375 2003-09-10  Dan Winship  <danw@ximian.com>
3376
3377         * libsoup/soup-message-private.h (SoupMessagePrivate): Remove the
3378         "status" field from here, since it's mostly used by SoupSession,
3379         which shouldn't need access to SoupMessagePrivate.
3380
3381         * libsoup/soup-message.h (SoupMessage): Move it here.
3382         (SoupCallbackFn): Remove this alias for SoupMessageCallbackFn.
3383         (soup_message_set_uri): also moved from soup-message-private.h
3384
3385         * libsoup/soup-message.c: s/msg->priv->status/msg->status/.
3386
3387         * libsoup/soup-message-handlers.c:
3388         s/SoupCallbackFn/SoupMessageCallbackFn/ everywhere.
3389
3390         * libsoup/soup-message-io.c (soup_message_io_client,
3391         soup_message_io_server, soup_message_io_unpause): Don't set up an
3392         idle handler, just jump right in to reading/writing; if this is a
3393         synchronous socket, then the caller wants to block, and if it's
3394         not, then we'll quickly get an EAGAIN anyway.
3395
3396         * libsoup/soup-session.c: (queue_message): Likewise.
3397         (*) Update for SoupMessageStatus move and remove
3398         soup-message-private.h include.
3399
3400         * libsoup/soup-server-message.c: Remove soup-message-private.h
3401         include.
3402
3403         * libsoup/soup-server.c: Likewise.
3404
3405         * libsoup/soup-connection.c (soup_connection_is_connected,
3406         soup_connection_is_new): Remove these, since they weren't being
3407         used.
3408
3409         * libsoup/soup-md5-utils.c: Moved from md5-utils.c and renamed, to
3410         avoid namespace pollution.
3411
3412         * libsoup/soup-auth-digest.c: Update for that.
3413         * libsoup/soup-server-auth.c: Likewise
3414
3415         * tests/auth-test.c: Remove soup-message-private.h include
3416
3417 2003-09-09  Dan Winship  <danw@ximian.com>
3418
3419         Beginnings of improved synchronous API support
3420
3421         * libsoup/soup-dns.c: Simplify this by making it not automatically
3422         return the result: force the caller to poll. (This isn't really a
3423         performance issue: the results should come back quickly anyway.)
3424         Also, make the cache thread-safe.
3425         (soup_dns_entry_from_name): Was soup_gethostbyname
3426         (soup_dns_entry_from_addr): Was soup_gethostbyaddr
3427         (soup_dns_entry_check_lookup): Used to poll to see if DNS is done
3428         (soup_dns_entry_get_hostent): Gets the hostent from an entry (and
3429         blocks if it's not resolved yet).
3430
3431         * libsoup/soup-address.c: Update for soup-dns changes.
3432         (soup_address_new): Don't automatically start resolving the
3433         hostname now, since we don't know if the caller is going to want
3434         it resolved synchronously or asynchronously.
3435         (soup_address_resolve_async): Renamed from soup_address_resolve.
3436         (soup_address_resolve_sync): New routine to do blocking
3437         synchronous DNS.
3438
3439         * libsoup/soup-socket.c (soup_socket_connect): Now returns a
3440         status value directly when connecting synchronously.
3441         (soup_socket_client_new_async, soup_socket_client_new_sync):
3442         Separate async/sync client socket functions.
3443         (soup_socket_get_iochannel): Made static since it was not used
3444         outside soup-socket.
3445
3446         * libsoup/soup-connection.c (soup_connection_new,
3447         soup_connection_new_proxy, soup_connection_new_tunnel): Just set
3448         up the data, don't actually start connecting.
3449         (soup_connection_connect_async, soup_connection_connect_sync): New
3450         async and sync SoupConnection connecting routines.
3451         (soup_connection_get_socket): Remove this since it wasn't being
3452         used.
3453
3454         * libsoup/soup-session.c (final_finished): Run the queue since a
3455         connection is now freed up.
3456         (run_queue): Update for soup_connection_new* changes.
3457
3458         * libsoup/soup-misc.c (soup_substring_index): Remove, since it
3459         wasn't being used any more.
3460
3461         * libsoup/soup-private.h: Remove some prototypes for functions
3462         that no longer exist.
3463
3464         * libsoup/soup-uri.c (soup_uri_copy_root): New utility function
3465         (copies the protocol, host, and port of a SoupUri).
3466
3467         * tests/auth-test.c:
3468         * tests/get.c:
3469         * tests/simple-proxy.c: belatedly update for soup-session change
3470
3471         * tests/revserver.c: Handle each new connection in its own thread,
3472         using synchronous SoupSocket calls.
3473
3474 2003-09-05  Dan Winship  <danw@ximian.com>
3475
3476         * libsoup/soup-session.c: Move a bunch of logic here from
3477         soup-context. Now the session keeps track of hosts (instead of
3478         having a global soup_hosts hash) and their connections.
3479         (soup_session_new_with_proxy, soup_session_new_full): New session
3480         constructors to specify a proxy or a proxy and connection limits
3481         (send_request): Add Authorization and Proxy-Authorization headers
3482         before sending off the request.
3483         (soup_session_queue_message, et al): Improve the way this works.
3484         There's no need to use timeouts to wait for connections to become
3485         free; we *know* when they become free.
3486
3487         * libsoup/soup-private.h: Remove SoupHost and some other
3488         no-longer-used stuff.
3489
3490         * libsoup/soup-misc.c (soup_set_proxy, soup_get_proxy,
3491         soup_set_connection_limit, soup_set_connection_limit): Gone. These
3492         are all per-session now.
3493
3494         * libsoup/soup-message.c: Remove all SoupContext references
3495         (mostly replaced with SoupUri references)
3496         (cleanup_message): priv->connect_tag and priv->connection are gone
3497         now, so this was just soup_message_io_cancel(). So remove
3498         cleanup_message and replace it with that everywhere.
3499         (soup_message_disconnect): Gone.
3500         (soup_message_set_uri): Replaces soup_message_set_context.
3501         (soup_message_set_connection, soup_message_get_connection): Gone
3502
3503         * libsoup/soup-message-server-io.c (parse_request_headers):
3504         s/soup_message_set_context/soup_message_set_uri/
3505
3506         * libsoup/soup-message-private.h (SoupMessagePrivate): Remove
3507         connect_tag, context, and connection.
3508
3509         * libsoup/soup-message-client-io.c (encode_http_auth): Gone.
3510
3511         * libsoup/soup-context.c: Gone
3512
3513         * tests/auth-test.c (identify_auth): update for session/context
3514         changes
3515
3516 2003-09-03  Dan Winship  <danw@ximian.com>
3517
3518         * libsoup/soup-status.h: Renamed from soup-error.h, with types
3519         and defines renamed accordingly.
3520
3521         * libsoup/soup-message.h (SoupMessage): Rename errorcode to
3522         status_code and errorphrase to reason_phrase. Remove errorclass.
3523         (SOUP_MESSAGE_IS_ERROR): Remove this. You can't classify redirects
3524         as being either "errors" or "not errors", so its semantics are
3525         guaranteed to be wrong sometimes.
3526
3527         * libsoup/soup-message.c (soup_message_set_status,
3528         soup_message_set_status_full): Renamed
3529
3530         * libsoup/soup-message-handlers.c
3531         (soup_message_add_status_code_handler,
3532         soup_message_add_status_class_handler): Rename.
3533
3534         * libsoup/soup-session.c (soup_session_send_message): Make this
3535         return a status code rather than a status class.
3536
3537         * libsoup/soup-message-private.h (SoupMessagePrivate): Remove some
3538         unrelated unused fields (retries, callback, user_data).
3539
3540         * ...: Updates
3541
3542 2003-09-02  Dan Winship  <danw@ximian.com>
3543
3544         * libsoup/soup-session.c: First draft at the new object to
3545         maintain formerly-global state. (Not yet complete; still need to
3546         get rid of SoupContext).
3547
3548         * libsoup/soup-message-queue.c: Data structure used by SoupSession
3549
3550         * libsoup/soup-queue.c: Gone. Mostly moved into soup-session, but
3551         some bits went into soup-connection.
3552
3553         * libsoup/soup-connection.c (soup_connection_send_request): New,
3554         to send a request on a connection. The connection updates its
3555         internal state and then hands off to soup_message_send_request.
3556         (request_done): Callback set up by soup_connection_send_request.
3557         Marks the connection as no-longer-in-use, and disconnects it if
3558         the message says to.
3559         (soup_connection_set_in_use, soup_connection_mark_old): No longer
3560         needed; the connection takes care of this itself now.
3561         (soup_connection_new_proxy): New, to create a new connection that
3562         is explicitly marked as being through an HTTP proxy.
3563         (soup_connection_new_tunnel): New, to create a new HTTPS
3564         connection through a proxy. (Includes the code to send the
3565         CONNECT.)
3566
3567         * libsoup/soup-context.c (try_existing_connections): Don't need to
3568         call soup_connection_set_in_use.
3569         (try_create_connection): Use soup_connection_new,
3570         soup_connection_new_proxy, or soup_connection_new_tunnel as
3571         appropriate.
3572
3573         * libsoup/soup-message.c (soup_message_prepare): Replaces
3574         queue_message.
3575         (soup_message_queue, soup_message_requeue, soup_message_prepare):
3576         Gone. This must be done via a SoupSession now.
3577         (soup_message_set_connection): don't need to mark in_use/not
3578         in_use. Also, msg->priv->socket is gone now.
3579         (soup_message_get_socket): Gone.
3580
3581         * libsoup/soup-message-handlers.c (soup_message_run_handlers):
3582         Remove references to global handlers.
3583         (redirect_handler, authorize_handler): Moved to soup-session.c.
3584
3585         * libsoup/soup-misc.c (soup_shutdown): Gone; just unref the
3586         session to shut down now.
3587
3588         * libsoup/soup.h: add soup-session.h
3589
3590         * libsoup/Makefile.am: updates
3591
3592         * tests/auth-test.c, tests/get.c, tests/simple-proxy.c: Use
3593         SoupSession.
3594
3595 2003-08-29  Dan Winship  <danw@ximian.com>
3596
3597         * libsoup/soup-message-io.c: Major rewrite. There is now only a
3598         single IO state object (instead of one for reading and one for
3599         writing), and the IO code handles switching back and forth between
3600         reading and writing as appropriate (including handling the extra
3601         switches needed for "Expect: 100-continue").
3602         (soup_message_io_client, soup_message_io_server): The new entry
3603         points.
3604         (soup_message_io_cancel): If the caller cancels the IO when we
3605         were expecting to read more data, disconnect the socket.
3606
3607         * libsoup/soup-message.h (SoupMessageFlags): add
3608         SOUP_MESSAGE_EXPECT_CONTINUE, to indicate that the IO code should
3609         do the special expect-continue handling.
3610
3611         * libsoup/soup-message.c: Move all the signal stuff here. Remove
3612         the "done_reading" and "done_writing" signals and replace them
3613         with a single "finished" signal. (A single signal. Say that 10
3614         times fast!)
3615         (soup_message_got_headers, etc): Functions to emit signals.
3616         (got_headers, got_chunk, got_body): Default signal methods that
3617         call soup_message_run_handlers.
3618         (finished): Default signal method that replaces
3619         soup_message_issue_callback.
3620         ([various]): s/soup_message_issue_callback/soup_message_finished/
3621         (soup_message_requeue): There's no soup_message_set_read_callbacks
3622         any more, so if the caller requeues while it's still reading, just
3623         cancel the read.
3624         (soup_message_add_chunk, soup_message_add_final_chunk,
3625         soup_message_pop_chunk): Moved here from soup-server-message,
3626         although we don't actually quite support using chunked encoding
3627         for requests yet.
3628
3629         * libsoup/soup-server-message.c (soup_server_message_new): No
3630         longer takes a socket argument.
3631         (soup_server_message_add_chunk, soup_server_message_get_chunk):
3632         Moved into SoupMessage.
3633
3634         * libsoup/soup-message-handlers.c (global_handlers): Make these
3635         POST_BODY rather than PRE_BODY, so they won't mess up the IO
3636         channel when the requeue the message.
3637         (soup_message_run_handlers): Don't need to issue the message
3638         callback from here any more.
3639         (authorize_handler): Just leave the error as 401 or 407 (see
3640         soup-error.h change)
3641
3642         * libsoup/soup-message-client-io.c (soup_message_send_request):
3643         Replaces soup_message_write_request and
3644         soup_message_read_response.
3645
3646         * libsoup/soup-message-server-io.c: Parallel to
3647         soup-message-client-io.c, this defines the server-side header
3648         handling.
3649         (soup_message_read_request): Its entry point.
3650
3651         * libsoup/soup-server.c: Lots of code moved into
3652         soup-message-server-io.c. Update for other changes.
3653
3654         * libsoup/soup-queue.c: Update for changes
3655
3656         * libsoup/soup-socket.c (read_from_network, soup_socket_write):
3657         Don't call soup_socket_disconnect() on an error, just return
3658         SOUP_SOCKET_ERROR. Otherwise soup_socket_disconnect() could emit
3659         signals that will mess up the caller of the read/write function.
3660
3661         * libsoup/soup-connection.c (soup_connection_disconnect): When
3662         disconnecting the socket, disconnect from its signals first to
3663         prevent bad reentrancy.
3664
3665         * libsoup/soup-error.h: Kill off SOUP_ERROR_CANT_AUTHENTICATE and
3666         SOUP_ERROR_CANT_AUTHENTICATE_PROXY, since they don't really say
3667         anything that SOUP_ERROR_UNATHORIZED and
3668         SOUP_ERROR_PROXY_UNAUTHORIZED don't say. (And now, all of the
3669         "transport" errors actually are transport-related.)
3670
3671         * tests/auth-test.c (main): s/CANT_AUTHENTICATE/UNAUTHORIZED/
3672
3673         * tests/simple-proxy.c: Complicate this a bunch. In particular,
3674         use SOUP_MESSAGE_OVERWRITE_CHUNKS and the GOT_CHUNK signal, and
3675         pass the data back to the client in chunked format.
3676
3677 2003-08-27  Dan Winship  <danw@ximian.com>
3678
3679         * libsoup/soup-types.h: New header with typedefs, to avoid
3680         #include loops among other headers.
3681
3682         * libsoup/Makefile.am (libsoupinclude_HEADERS): add it
3683
3684         * libsoup/*.[ch], tests/*.c: Update for soup-types.h
3685         
3686 2003-08-26  Dan Winship  <danw@ximian.com>
3687
3688         * libsoup/soup-message-client-io.c (soup_message_write_request,
3689         soup_message_read_response): Higher-than-soup-message-io-level
3690         functions to do client-side IO. (Code that used to be in
3691         soup-queue.c)
3692         (get_request_header_cb): Fix a bug in the generation of the Host:
3693         header; need to include the port number if it's not the default.
3694
3695         * libsoup/soup-message-io.c (soup_message_write,
3696         soup_message_write_simple): Take separate user_datas for the get_*
3697         callbacks and the done callbacks.
3698
3699         * libsoup/soup-queue.c: Update to use soup_message_write_request
3700         and soup_message_read_response.
3701
3702         * libsoup/soup-connection.c (soup_connection_new): Change the
3703         prototype to take a SoupUri and a callback.
3704
3705         * libsoup/soup-context.c (try_create_connection,
3706         soup_context_connect_cb): Update for soup_connection_new change.
3707
3708         * libsoup/soup-server.c (read_done_cb, issue_bad_request): Update
3709         for soup_message_write changes
3710
3711         * libsoup/soup-uri.c (soup_uri_uses_default_port): new utility
3712         function
3713
3714 2003-08-26  Dan Winship  <danw@ximian.com>
3715
3716         * libsoup/soup-message-private.h: Define SoupMessage signal stuff
3717         (READ_HEADERS, READ_CHUNK, READ_BODY, READ_ERROR, WROTE_HEADERS,
3718         WROTE_CHUNK, WROTE_BODY, WRITE_ERROR).
3719
3720         * libsoup/soup-message.c (class_init): set up signals
3721         (requeue_read_finished): Update for changes.
3722
3723         * libsoup/soup-message-io.c (soup_message_read): Split out
3724         parse_headers_cb from read_headers_cb. Also add a SoupDataBuffer *
3725         arg to say where to store the message body. Set up
3726         read_headers_cb, read_chunk_cb, read_body_cb, and error_cb as
3727         signal handlers.
3728         (do_read): Call r->parse_headers_cb, then emit READ_HEADERS
3729         (read_body_chunk): emit READ_CHUNK.
3730         (issue_final_callback): Set r->body. emit READ_BODY.
3731         (failed_read): emit READ_ERROR.
3732         (soup_message_read_set_callbacks): Disconnect old signal handlers,
3733         connect new ones.
3734         (soup_message_read_cancel): Disconnect signal handlers.
3735         (soup_message_write, soup_message_write_simple): Set up
3736         wrote_body_cb and error_cb as signal handlers.
3737         (do_write): emit WROTE_HEADERS and WROTE_CHUNK, even though
3738         nothing currently ever listens for them. emit WROTE_BODY when
3739         done.
3740         (failed_write): emit WRITE_ERROR
3741
3742         * libsoup/soup-queue.c (soup_queue_parse_headers_cb,
3743         soup_queue_read_headers_cb): Split this into two unequal chunks.
3744         (read_header_cb only runs the pre-body handlers).
3745         (soup_queue_read_chunk_cb, soup_queue_read_done_cb): Update
3746         prototypes.
3747         (soup_queue_write_done_cb): Update call to soup_message_read
3748
3749         * libsoup/soup-server.c (parse_headers_cb): Renamed from
3750         read_headers_cb
3751         (read_done_cb): Update prototype
3752         (start_request): Update soup_message_read call.
3753
3754 2003-08-25  Dan Winship  <danw@ximian.com>
3755
3756         * libsoup/soup-message-io.c (soup_message_read,
3757         soup_message_write, soup_message_write_simple): Add a "user_data"
3758         arg, pass it to the callbacks.
3759
3760         * libsoup/soup-message.c (soup_message_requeue,
3761         requeue_read_finished, requeue_read_error): Update for that
3762
3763         * libsoup/soup-queue.c: Likewise
3764
3765         * libsoup/soup-server.c: Likewise
3766
3767 2003-08-25  Dan Winship  <danw@ximian.com>
3768
3769         * libsoup/soup-message.c (soup_message_new): Take a uri string
3770         instead of a context. Also, swap the args (so the method comes
3771         before the URI, just like in the protocol).
3772         (soup_message_new_from_uri): Like soup_messgae_new, but takes a
3773         SoupUri instead of a string
3774         (soup_message_set_request, soup_message_set_response): Replace
3775         soup_message_new_full.
3776         (cleanup_message): Was soup_message_cleanup, but is static now.
3777         (queue_message): Do the pre-queuing message cleanup here instead
3778         of in soup_queue_message.
3779         (soup_message_queue): Set the callback and user_data, then call
3780         queue_message.
3781         (requeue_read_error, requeue_read_finished, soup_message_requeue):
3782         Use queue_message
3783         (soup_message_get_uri): Replaces soup_message_get_context.
3784
3785         * libsoup/soup-message.h (SoupMessage): Remove msg->context. (It's
3786         part of SoupMessagePrivate now)
3787
3788         * libsoup/soup-context.c: #include soup-message-private
3789         (soup_context_from_uri): constify the uri arg.
3790
3791         * libsoup/soup-queue.c: Various context/uri fixes
3792         (proxy_https_connect): Use soup_message_new_from_uri.
3793         (soup_queue_message): Drastically simplified since most of the
3794         work is in soup-messsage.c:queue_message() now
3795
3796         * libsoup/soup-auth-digest.c (compute_response,
3797         get_authorization): Use soup_message_get_uri.
3798
3799         * libsoup/soup-server-auth.c (parse_digest): Likewise
3800
3801         * libsoup/soup-server.c (call_handler): Likewise
3802
3803         * tests/simple-httpd.c (server_callback): Likewise.
3804
3805         * tests/simple-proxy.c (server_callback): Likewise
3806
3807         * tests/get.c (got_url): Likewise.
3808         (get_url): Update soup_message_new usage.
3809
3810         * tests/auth-test.c: #include soup-message-private. Update for
3811         context changes and soup_message_new change.
3812
3813 2003-08-22  Dan Winship  <danw@ximian.com>
3814
3815         * libsoup/soup-message-private.h: New file containing
3816         SoupMessagePrivate and some other soup-message-internal
3817         types/functions. Also includes the new, expanded SoupMessageStatus
3818         enum.
3819
3820         * libsoup/soup-message-io.c: Replaces what used to be in
3821         soup-transfer, but now all the interfaces take SoupMessages
3822         instead of SoupReader/SoupWriter and deal with maintaining
3823         msg->priv->{read,write}_state themselves. Fixes up all the
3824         refcounting madness.
3825
3826         * libsoup/soup-message-handlers.c: Move the handler code here,
3827         mostly unchanged. (But rename SoupHandlerType to SoupHandlerPhase
3828         to make the distinction from SoupHandlerKind clearer.)
3829
3830         * libsoup/soup-message.c: Update for soup-message-io and new
3831         SoupMessageStatus values. Remove handler code.
3832         (soup_message_cleanup): Remove the hack to try to preserve the
3833         connection if the message gets cleaned up before it finishes
3834         reading. soup_message_requeue handles this in the requeuing case,
3835         and there's no especially compelling reason to bother doing it in
3836         any other case. (And the soup-message-io api doesn't support
3837         having a read operation that's not connected to any message.)
3838
3839         * libsoup/soup-private.h: remove SoupMessagePrivate
3840
3841         * libsoup/soup-queue.c: Update for soup-message-io and new
3842         SoupMessageStatus values.
3843
3844         * libsoup/soup-server-message.c: Likewise
3845
3846         * libsoup/soup-server.c: Likewise
3847
3848         * libsoup/soup-transfer.c: Gone (yay)
3849
3850         * libsoup/Makefile.am (libsoup_2_2_la_SOURCES): update
3851
3852 2003-08-20  Dan Winship  <danw@ximian.com>
3853
3854         * libsoup/soup-message.c: Make this a GObject. (Note that since
3855         SoupMessage was not refcounted before, it's not really refcounted
3856         now either. TBF)
3857         (soup_message_free): Gone, replaced by g_object_unref
3858         (soup_message_copy, soup_message_foreach_remove_header): Remove
3859         these, since neither was currently functional.
3860         (soup_message_is_keepalive): New utility function to look at
3861         HTTP version and request/response headers to decide if a message
3862         indicates the connection should be kept alive.
3863         (soup_message_set_connection, soup_message_get_connection): New
3864         (soup_message_get_socket): New
3865
3866         * libsoup/soup-server-message.c: Make this a subclass of
3867         SoupMessage.
3868         (soup_server_message_new): Now takes a SoupServer and SoupSocket
3869         (soup_server_message_get_server): New
3870         (soup_server_message_set_encoding,
3871         soup_server_message_get_encoding): Get/set whether the message
3872         should be sent with content-length or chunked encoding
3873         (soup_server_message_is_started, soup_server_message_is_finished):
3874         Private member accessors.
3875         (soup_server_message_add_chunk): Renamed from add_data
3876         (soup_server_message_get_chunk): Pops a chunk from the list.
3877         (soup_server_message_get_source): Gone
3878
3879         * libsoup/soup-server.c: Update for SoupServerMessage changes.
3880         (error_cb, write_done_cb): All the cleanup stuff that used to be
3881         here happens automatically by unreffing the message now.
3882         (get_response_header): Remove some erroneous leftover CGI stuff
3883         (issue_bad_request): add "Connection: close" to the response.
3884         (read_headers_cb): clean this up a bit. Reject HTTP/1.1 messages
3885         with no Host header as per RFC 2616.
3886
3887         * libsoup/soup-connection.c (soup_connection_start_ssl): Gone
3888         (soup_connection_set_in_use): Let the caller set the connection to
3889         "not in use" even after the socket has been disconnected.
3890
3891         * libsoup/soup-context.c: Use soup_message_get_connection
3892
3893         * libsoup/soup-headers.c (soup_headers_parse_request): Remove the
3894         check on request length, since it was rejecting
3895         "GET / HTTP/1.0\r\n\r\n", which is a valid complete request.
3896
3897         * libsoup/soup-queue.c: Use soup_message_get_connection and
3898         soup_message_get_socket.
3899         (soup_queue_read_done_cb): Use soup_message_is_keepalive
3900         (proxy_https_connect_cb): Use soup_socket_start_ssl rather than
3901         soup_connection_start_ssl
3902
3903         * libsoup/soup-socket.c (finalize): disconnect the GIOChannel
3904         handlers if the socket hasn't been disconnected yet.
3905
3906         * libsoup/soup-transfer.c (soup_reader_read_body_chunk,
3907         reader_read): Fix these so that reader_read will exit properly if
3908         the read is cancelled.
3909
3910         * tests/auth-test.c (main): s/soup_message_free/g_object_unref/
3911
3912         * tests/simple-httpd.c (server_callback): set the message to
3913         content-length encoding.
3914         * tests/simple-proxy.c (server_callback): Likewise
3915
3916 2003-08-19  Dan Winship  <danw@ximian.com>
3917
3918         * libsoup/soup-socket.c (soup_socket_read,
3919         soup_socket_read_until, soup_socket_write): New API for doing
3920         socket IO. Works both synchronously and asynchronously, and
3921         buffers data to prevent the "100 Continue" problem.
3922         (soup_socket_set_flag): Replaces formerly-private
3923         soup_set_sockopts. (primarily to let the caller turn off
3924         SOUP_SOCKET_FLAG_NONBLOCKING).
3925
3926         * libsoup/soup-transfer.c (soup_transfer_read,
3927         soup_transfer_write, soup_transfer_write_simple): Take a
3928         SoupSocket instead of a GIOChannel. Use the new socket IO api.
3929         Changed the prototypes of some of the callbacks to be less
3930         hackish.
3931
3932         * libsoup/soup-connection.c (soup_connection_get_socket): Replaces
3933         soup_connection_get_iochannel.
3934
3935         * libsoup/soup-message.c: Fix up for soup-transfer changes
3936
3937         * libsoup/soup-queue.c: Likewise
3938
3939         * libsoup/soup-server.c: Likewise
3940
3941         * tests/revserver.c: A slightly more complicated replacement for
3942         timeserver. (Does both reads and writes)
3943
3944 2003-08-19  Dan Winship  <danw@ximian.com>
3945
3946         * libsoup/soup-socks.[ch]: Remove this. RC doesn't let you
3947         configure it, and no one has complained, and it looks like the
3948         SOCKS5 auth code doesn't actually work anyway...
3949
3950         * libsoup/soup-queue.c (proxy_connect): Remove SOCKS code.
3951
3952         * libsoup/soup-uri.h: Remove SOUP_PROTOCOL_SOCKS4 and
3953         SOUP_PROTOCOL_SOCKS5
3954
3955         * libsoup/soup-misc.c: Remove a references to SOCKS in a comment
3956
3957         * libsoup/Makefile.am (libsoup_2_2_la_SOURCES): remove
3958         soup-socks.[ch]
3959
3960 2003-08-19  Dan Winship  <danw@ximian.com>
3961
3962         * libsoup/soup-server.c: Make this a GObject. Remove
3963         SoupServerMessage code (to soup-server-message.c). Remove CGI
3964         server code (for now?)
3965         (soup_server_add_handler, soup_server_remove_handler): Rename
3966         (from register/unregister) to make it clearer what they do.
3967
3968         * libsoup/soup-server-message.c: Moved out of soup-server.c
3969
3970         * libsoup/soup-private.h: Remove SoupServer def
3971
3972         * libsoup/Makefile.am (libsoupinclude_HEADERS,
3973         libsoup_2_2_la_SOURCES): add soup-server-message.[ch]
3974
3975         * tests/simple-httpd.c: 
3976         * tests/simple-proxy.c: Update for SoupServer changes
3977
3978 2003-08-18  Dan Winship  <danw@ximian.com>
3979
3980         * libsoup/soup-address.c (SoupAddressPrivate): Make this more like
3981         a struct sockaddr again (like it used to be). In particular, add
3982         back the "port" field. Add a bunch of macros to try (and fail) to
3983         simplify some of the code.
3984         (soup_address_new): Now returns a SoupAddress directly rather than
3985         a random handle, and the caller can just use g_object_unref to
3986         cancel the lookup. Also, the callback now uses a
3987         SoupKnownErrorCode rather than a special-purpose address-lookup
3988         error code.
3989         (soup_address_new_cancel): No longer needed.
3990         (soup_address_new_sync): Removed
3991         (soup_address_new_any): Replaces soup_address_ipv4_any and
3992         soup_address_ipv6_any.
3993         (soup_address_get_name, etc): Gone. Use soup_address_resolve()
3994         now.
3995         (soup_address_get_physical): Renamed from
3996         soup_address_get_canonical_name.
3997         (soup_address_get_sockaddr): Replaces soup_address_make_sockaddr()
3998
3999         * libsoup/soup-socket.c: Update for SoupAddress changes and make
4000         similar changes here.
4001         (soup_socket_new): Just creates a generic SoupSocket now.
4002         (soup_socket_connect): Client setup
4003         (soup_socket_listen): Server setup. Now also sets up an iochannel
4004         listening for connects and emits a "new_connection" signal as they
4005         come in.
4006         (soup_socket_start_ssl): Turns on SSL.
4007         (soup_socket_client_new, soup_socket_server_new): Utility
4008         functions that wrap the above.
4009         (soup_socket_new_cancel, soup_socket_new_sync): Gone
4010         (soup_socket_server_accept, soup_socket_server_try_accept): No
4011         longer needed.
4012         (soup_socket_get_iochannel): No longer adds a ref when returning
4013         the iochannel. Also, we set it to "close_on_unref" so that if a
4014         caller adds a ref to it, the connection will actually remain open
4015         even after the SoupSocket is destroyed.
4016         (soup_socket_get_local_address, soup_socket_get_remote_address):
4017         Let the caller get both of these.
4018
4019         * libsoup/soup-connection.c: Don't keep a private copy of the
4020         socket's iochannel.
4021         (soup_connection_new): Don't need to set socket options here.
4022         SoupSocket does it.
4023         (soup_connection_start_ssl): Just call soup_socket_start_ssl.
4024         (soup_connection_get_iochannel): Just return the socket's
4025         iochannel (and don't ref it)
4026
4027         * libsoup/soup-error.c: add SOUP_ERROR_CANT_RESOLVE and
4028         SOUP_ERROR_CANT_RESOLVE_PROXY
4029
4030         * libsoup/soup-dns.c (soup_ntop): Make the address arg const.
4031         Remove the "FIXME add a CANT_RESOLVE error" and return
4032         SOUP_ERROR_CANT_RESOLVE instead.
4033
4034         * libsoup/soup-server.c: Update for socket/address changes. Don't
4035         poke into SoupSocket's private fields.
4036         (soup_server_run_async): Just connect to the socket's
4037         "new_connection" signal.
4038
4039         * libsoup/soup-context.c (try_create_connection,
4040         soup_context_connect_cb): Update for socket changes. Replace
4041         SOUP_CONNECT_ERROR codes with plain SOUP_ERROR codes.
4042
4043         * libsoup/soup-misc.c (soup_signal_connect_once): Utility function
4044         to connect to a signal handler and connect another function to
4045         clean up the first signal handler after its first invocation.
4046         (Lets us use signals to replace one-off callbacks.)
4047
4048         * libsoup/soup-private.h: Remove SoupSocketPrivate since it is
4049         actually private now.
4050         (struct _SoupServer): Remove accept_tag.
4051
4052         * libsoup/soup-queue.c (soup_queue_read_done_cb, start_request):
4053         Don't unref the iochannel.
4054         (soup_queue_connect_cb): Takes a SoupKnownErrorCode now.
4055
4056         * libsoup/soup-socks.c: Update for socket/address changes
4057
4058         * tests/simple-httpd.c (main):
4059         s/SOUP_SERVER_ANY_PORT/SOUP_ADDRESS_ANY_PORT/
4060         * tests/simple-proxy.c (main): Likewise
4061
4062         * tests/timeserver.c: Update for SoupSocket's "new_connection"
4063         signal, and for SoupAddress changes.
4064
4065 2003-08-14  Dan Winship  <danw@ximian.com>
4066
4067         * libsoup/soup-connection.c: New, split out from soup-context and
4068         made into a GObject.
4069         (soup_connection_disconnect): Disconnects the connection and emits
4070         a signal. (Replaces the old "keep_alive" flag.)
4071         (soup_connection_is_connected): Checks if the connection is still
4072         connected
4073         (connection_died): Just disconnect, rather than freeing the
4074         connection. This way if anyone else is still referencing it they
4075         won't end up with an invalid pointer.
4076
4077         * libsoup/soup-context.c: Make this a GObject, remove all the
4078         SoupConnection code. Add an "ntlm_auths" field to SoupHost so that
4079         SoupContext can keep track of connection auth stuff there without
4080         SoupConnection needing to care. Various other updates.
4081
4082         * libsoup/soup-private.h: Remove SoupContext and SoupConnection
4083         definitions.
4084
4085         * libsoup/*.c, tests/get.c: Update for context/connection changes
4086
4087         * libsoup/soup-socks.c (soup_connect_socks_proxy): Change the
4088         definition to deal with the fact that there's no
4089         soup_connection_get_context any more.
4090
4091         * libsoup/soup-queue.c (soup_queue_read_headers_cb): Don't deal
4092         with connection persistence here.
4093         (soup_queue_read_done_cb): Do it here instead. Disconnect the
4094         connection when appropriate.
4095         (proxy_connect, proxy_https_connect, proxy_https_connect_cb):
4096         Reference-count the connection properly. (I think.)
4097
4098         * libsoup/soup-marshal.list: New, for SoupConnection's
4099         "disconnected" signal.
4100
4101         * libsoup/Makefile.am: add rules to build soup-marshal.[ch]
4102
4103         * configure.in: Use AM_PATH_GLIB_2 rather than pkg-config, so that
4104         GLIB_GENMARSHAL gets set too.
4105
4106 2003-08-14  Dan Winship  <danw@ximian.com>
4107
4108         * libsoup/soup-error.c: Fix a spelling mistake.
4109
4110         * libsoup/*.c: Fix use of @/%/#/() in gtk-doc comments
4111
4112 2003-08-12  Dan Winship  <danw@ximian.com>
4113
4114         * libsoup/soup-auth.c: Make this an abstract GObject. Tweak some
4115         of the interfaces around a little bit.
4116
4117         * libsoup/soup-auth-basic.c: subclass for Basic auth
4118
4119         * libsoup/soup-auth-digest.c: subclass for Digest auth
4120
4121         * libsoup/soup-auth-ntlm.c: subclass for NTLM auth. Move all of
4122         the code from soup-ntlm.c here, and make it private.
4123
4124         * libsoup/soup-ntlm.c: gone
4125
4126         * libsoup/soup-misc.h: Remove the definition of SoupAuthType from
4127         here, and change the signature of SoupAuthorizeFn.
4128
4129         * libsoup/soup-context.c: Use g_object_unref to free auths, use
4130         methods instead of directly access private fields.
4131
4132         * libsoup/soup-queue.c: Likewise
4133
4134         * libsoup/soup-server-auth.c (soup_server_auth_free): Remove all
4135         NTLM references. We have no plans to implement server-side NTLM
4136         auth.
4137
4138         * tests/auth-test.c (identify_auth): Update for auth api changes
4139
4140 2003-08-12  Dan Winship  <danw@ximian.com>
4141
4142         * configure.in (GLIB): add gobject-2.0 to the PKG_CHECK_MODULES
4143         call
4144
4145         * libsoup/soup-address.c: Make this a GObject.
4146         (soup_address_ref, soup_address_unref): Gone.
4147         (soup_address_copy): Gone. Wasn't being used anyway.
4148
4149         * libsoup/soup-dns.c: Move all of the DNS code and caching stuff
4150         here from soup-address.c, so that soup-address doesn't need to
4151         worry about trying to cache zero-ref addresses.
4152
4153         * libsoup/soup-socket.c: Make this a GObject. Use "guint"
4154         consistently for port numbers.
4155         (soup_socket_ref, soup_socket_unref): Gone.
4156
4157         * libsoup/soup-private.h: Change the SoupSocket definition to be
4158         SoupSocketPrivate. (Still need to keep this here since soup-server
4159         pokes around in its internals.)
4160         (SOUP_MAKE_TYPE): Copied from gal's E_MAKE_TYPE.
4161
4162         * libsoup/soup-server.c (read_done_cb, write_done_cb): Unref the
4163         reader/writer rather than leaking them.
4164
4165         * libsoup/*: Use GObject methods for socket/address refcounting
4166         
4167         * tests/auth-test.c (main)
4168         * tests/timeserver.c (main): Call g_type_init.
4169
4170         * tests/get.c (main): Call g_type_init.
4171         (get_url, got_url): Fix some bugs that could make -r mode get into
4172         infinite loops downloading the same files over and over. Plug some
4173         memory leaks to make this more useful for valgrinding libsoup.
4174
4175         * tests/simple-httpd.c (main): Call g_type_init. Set up a signal
4176         handler for SIGINT so we can exit cleanly, since valgrind won't
4177         give a leak report if you don't. Plug a few memory leaks.
4178
4179         * tests/simple-proxy.c (main): Likewise 
4180
4181 2003-08-12  Dan Winship  <danw@ximian.com>
4182
4183         Pull over some new test programs from the soup-refactoring branch,
4184         along with the SoupUri changes they depend on.
4185
4186         * tests/simple-httpd.c: A really simple HTTP server, to test the
4187         server code.
4188
4189         * tests/simple-proxy.c: An even simpler HTTP proxy
4190
4191         * tests/get.c: Add "-r" flag to recursively get files (thereby
4192         testing multiple-connections-at-once code). Also good for setting
4193         up a tree to use with simple-httpd.
4194
4195         * tests/timeserver.c (main): Fix a bug. (s/ipv6/ipv4/ in the
4196         normal case)
4197
4198         * tests/uri-parsing.c: Regression test for the new soup-uri.c
4199
4200         * libsoup/soup-uri.c: Rewrite/update to conform to RFC 2396, and
4201         pull in some optimizations from camel-url. Also, make SoupProtocol
4202         a GQuark so we can still compare them with ==, but we can also
4203         recognize any protocol.
4204         (soup_uri_new_with_base): New, to merge base and relative URIs
4205         (soup_uri_to_string): Update this. Change the "show_password" flag
4206         (which we always passed FALSE for) to "just_path", for places that
4207         want the path+query without the protocol, host, etc.
4208
4209         * libsoup/soup-queue.c (soup_get_request_header): Just use
4210         soup_uri_to_string to generate the request URI.
4211
4212         * libsoup/soup-auth.c (compute_response, digest_auth_func): Use
4213         "soup_uri_to_path (uri, TRUE)" rather than trying to reassemble
4214         the URI by hand badly.
4215         * libsoup/soup-server-auth.c (parse_digest): Likewise
4216
4217         * libsoup/soup-socks.c (soup_connect_socks_proxy): Change a
4218         switch() to an series of if()s since SOUP_PROTOCOL_* aren't
4219         constants any more.
4220
4221         * libsoup/soup-context.c (soup_context_uri_hash,
4222         soup_context_uri_equal): s/querystring/query/
4223
4224 2003-08-12  Dan Winship  <danw@ximian.com>
4225
4226         * configure.in: Bump API version to 2.2 and package version to
4227         2.1.0. Remove NSS and OpenSSL checks and proxy-related config. Use
4228         libgnutls-config to find GNUTLS.
4229
4230         * libsoup-2.2.pc.in: Update, and rename from soup-2.0.pc
4231
4232         * Makefile.am: Update for pc file rename
4233
4234         * libsoup/Makefile.am: s/2.0/2.2/ everywhere. Remove NSS, OpenSSL,
4235         and libsoup-ssl-proxy stuff.
4236
4237         * libsoup/soup-ssl-proxy.c
4238         * libsoup/soup-nss.[ch]
4239         * libsoup/soup-openssl.[ch]: gone
4240
4241         * libsoup/soup-ssl.c: remove NSS and OpenSSL bits
4242
4243         * tests/Makefile.am (get_LDADD, timeserver_LDADD,
4244         auth_test_LDADD): Update libsoup version
4245
4246 2003-08-07  Dan Winship  <danw@ximian.com>
4247
4248         * libsoup/soup-auth.c (soup_auth_lookup, soup_auth_set_context,
4249         soup_auth_invalidate): These are all really SoupContext functions,
4250         so move them to soup-context.c (and rename them appropriately).
4251         (soup_auth_get_protection_space): New method to get the
4252         "protection space" of an auth (paths where it is valid).
4253         (soup_auth_invalidate): New method to try to un-authenticate an
4254         auth (so we can keep the domain info cached even if the auth info
4255         is wrong).
4256         (basic_pspace_func): Basic protection space is all directories
4257         below the current one.
4258         (basic_invalidate_func): Clear the encoded username/password
4259         (digest_pspace_func): Digest protection space is either the whole
4260         server, or "what the domain parameter says" (though we don't deal
4261         with cross-host domains).
4262         (digest_invalidate_func): Return FALSE; bad digest auth info isn't
4263         cacheable.
4264         (digest_parse_func, digest_free): Set/free domain parameter
4265         (ntlm_pspace): NTLM protection space is always the whole server.
4266         (ntlm_invalidate): Clear the auth state.
4267         (soup_auth_new_ntlm): Make this non-static
4268         (SoupAuth): Replace the quad-state "status" field with an
4269         "authenticated" boolean.
4270         
4271         * libsoup/soup-private.h (SoupHost): Replace the "valid_auths"
4272         hash with separate "auth_realms" (path->realm) and "auths"
4273         (realm->auth) hashes. Also add a "use_ntlm" flag.
4274
4275         * libsoup/soup-context.c (soup_context_unref): Update SoupHost
4276         freeing code.
4277         (connection_free): Don't the connection's auth, just free it.
4278         (soup_context_lookup_auth): Formerly soup_auth_lookup, but now
4279         does two-stage lookup (path->realm then realm->auth) and also
4280         deals with NTLM hacks.
4281         (soup_context_update_auth): Mostly formerly soup_auth_set_context,
4282         but also large parts of authorize_handler. Updates the auth hashes
4283         based on information from a 401 or 407 response. Does a better job
4284         than authorize_handler did of not throwing away good information.
4285         (soup_context_preauthenticate): New; fakes up auth info so that
4286         requests will end up using authentication without the server
4287         needing to return an error first.
4288         (soup_context_authenticate_auth): Moved out of authorize_handler
4289         so it can be used at request-sending time too, if we know that we
4290         need it. (That way we can avoid requeuing the request if it isn't
4291         going to be able to be authenticated.)
4292         (soup_context_invalidate_auth): Sort of like the old
4293         soup_auth_invalidate, but only destroys the auth data, while still
4294         remembering the path->realm mapping.
4295
4296         * libsoup/soup-message.c (authorize_handler): Mostly moved into
4297         soup_context_update_auth.
4298         (maybe_validate_auth): Remove this; it was only useful because of
4299         bugs elsewhere in the auth handling.
4300         
4301         * libsoup/soup-queue.c (soup_encode_http_auth): Update for
4302         soup_context_lookup_auth. If the returned auth isn't
4303         authenticated, call soup_context_authenticate_auth() on it.
4304
4305         * tests/auth-test.c: New (from soup-refactoring branch). Tests
4306         that the Basic/Digest auth code does the right thing. (TODO: find
4307         a good way to add NTLM tests too.)
4308
4309         * tests/Makefile.am (check_PROGRAMS): add auth-test
4310
4311 2003-07-29  Dan Winship  <danw@ximian.com>
4312
4313         * configure.in: 1.99.25 ("Potato and Leek Soup")
4314
4315         * libsoup/soup-message.c (requeue_read_finished,
4316         release_connection): Free the passed-in body data. Otherwise the
4317         response body ends up getting leaked on most 3xx and 4xx
4318         responses.
4319         (soup_message_cleanup): Remove a piece of code that didn't
4320         actually do anything and its associated confused comment.
4321
4322         * libsoup/soup-auth.c (ntlm_free): plug an occasional NTLM auth leak
4323
4324         * libsoup/soup-context.c (connection_free): plug a non-occasional
4325         NTLM auth leak.
4326
4327 2003-06-26  Joe Shaw  <joe@ximian.com>
4328
4329         * configure.in: Version 1.99.24
4330
4331 2003-06-24  Dan Winship  <danw@ximian.com>
4332
4333         * configure.in: Check pkgconfig for openssl, since 0.9.7 (a) uses
4334         it, and (b) depends on lots of new things sometimes (like on RH9).
4335
4336         * libsoup/soup-openssl.c: 
4337         * libsoup/soup-ssl-proxy.c: Change #ifdef HAVE_OPENSSL_SSL_H to
4338         just #ifdef HAVE_OPENSSL since the header check doesn't get run in
4339         the pkgconfig case
4340
4341 2003-06-19  Dan Winship  <danw@ximian.com>
4342
4343         * libsoup/soup-queue.c (soup_queue_read_done_cb): unref the
4344         old read_tag before changing/clearing it.
4345         (soup_queue_write_done_cb): Likewise with the write_tag.
4346
4347         * libsoup/soup-transfer.c (issue_final_callback): ref the reader
4348         around the stop+callback.
4349         (soup_transfer_write_cb): Likewise.
4350
4351 2003-06-12  Dan Winship  <danw@ximian.com>
4352
4353         * libsoup/soup-transfer.c (SoupReader, SoupWriter): add a
4354         ref_count field.
4355         (soup_transfer_read, create_writer): Set initial ref_count to 2
4356         (one for soup-transfer, one for the caller).
4357         (soup_transfer_read_ref, soup_transfer_read_unref): ref/unref a
4358         reader
4359         (soup_transfer_read_stop): Clears the GIOChannel callbacks and
4360         drops soup-transfer's ref.
4361         (soup_transfer_read_cancel): Now just a stop+unref
4362         (soup_transfer_write_ref, soup_transfer_write_unref,
4363         soup_transfer_write_stop, soup_transfer_write_cancel): Similarly.
4364
4365         * libsoup/soup-message.c (soup_message_cleanup): when setting up
4366         the "finish reading" callbacks, unref the reader so it will be
4367         destroyed once it's done reading.
4368         (soup_message_requeue): Likewise.
4369
4370         * libsoup/soup-queue.c (soup_queue_read_headers_cb): Update for
4371         prototype change (no longer returns a SoupTransferDone).
4372         (soup_queue_read_chunk_cb): Likewise.
4373
4374         * libsoup/soup-server.c (read_headers_cb): Likewise
4375
4376 2003-06-11  Dan Winship  <danw@ximian.com>
4377
4378         * libsoup/soup-transfer.c: Change all functions to take a
4379         SoupReader * or SoupWriter * instead of a guint.
4380
4381         * libsoup/soup-private.h (SoupMessagePrivate): make read_tag and
4382         write_tag pointers instead of guints.
4383
4384 2003-06-02  Chris Toshok  <toshok@ximian.com>
4385
4386         * libsoup/soup-ssl.c: remove #include for soup-nss.h
4387
4388 2003-06-02  Chris Toshok  <toshok@ximian.com>
4389
4390         * libsoup/Makefile.am (INCLUDES): remove NSS_CFLAGS.
4391         (libsoup_2_0_la_LIBADD): remove NSS_LIBS.
4392         (libsoup_2_0_la_SOURCES): remove soup-nss.[ch]
4393
4394 2003-06-02  Chris Toshok  <toshok@ximian.com>
4395
4396         * configure.in: Bump version to 1.99.23.
4397
4398 2003-05-30  Chris Toshok  <toshok@ximian.com>
4399
4400         * libsoup/soup-queue.c (soup_queue_error_cb): always force a
4401         reconnect when there's an error with ssl connection.  This fixes
4402         #43387, but it runs the risk of sending requests multiple times to
4403         the exchange server, and it results in lots of shorter lived
4404         connections and more forking (in the ssl proxy case), depending on
4405         the length of the operation.
4406
4407 2003-05-21  Dan Winship  <danw@ximian.com>
4408
4409         * configure.in: 1.99.22 (codename: French Onion Soup)
4410
4411 2003-05-20  Dan Winship  <danw@ximian.com>
4412
4413         * libsoup/soup-message.c (soup_message_requeue): Clear the
4414         write_tag as well so we don't double-cancel it. #43395.
4415
4416         * libsoup/soup-queue.c (soup_queue_error_cb): The connection might
4417         be destroyed by the end of the func, so we have to call
4418         soup_connection_set_used at the beginning.
4419
4420         * libsoup/soup-openssl.c (soup_openssl_read, soup_openssl_write):
4421         Call g_set_error() so that we don't SEGV immediately after
4422         returning G_IO_STATUS_ERROR.
4423
4424 2003-05-08  Joe Shaw  <joe@ximian.com>
4425
4426         * configure.in: Bump version to 1.99.21
4427
4428         * libsoup/soup-queue.c (proxy_connect): If the proxy HTTPS
4429         tunnelling fails, the other message which shares our same
4430         connection will free it first, so set ours to NULL.
4431
4432 2003-05-08  Dan Winship  <danw@ximian.com>
4433
4434         * libsoup/soup-auth.c (ntlm_auth): If the auth status is PENDING,
4435         return an NTLM request string. Otherwise return the "response"
4436         field (which should include the NTLM authenticate message)
4437         (ntlm_init): Don't bother setting "response" to the NTLM request
4438         string. Just leave it NULL in that case.
4439
4440         * libsoup/soup-message.c (authorize_handler): Never try to reuse
4441         an NTLM auth returned from soup_auth_lookup. Only set the auth on
4442         the connection when it's SOUP_AUTH_STATUS_SUCCESSFUL. Otherwise,
4443         call soup_auth_set_context() on it just like for non-NTLM auth.
4444         The net effect of all of this is that now we record when a context
4445         needs NTLM auth just like with non-NTLM auth, so that that info
4446         gets preserved across connections.
4447         (soup_message_requeue): No longer need the hackery here to
4448         preserve the connection auth state.
4449
4450 2003-05-07  Dan Winship  <danw@ximian.com>
4451
4452         * libsoup/soup-context.c (soup_connection_set_in_use): New, to
4453         toggle the connection's in_use flag, and set up the death watch
4454         when it's not in use.
4455         (connection_death): This is only hooked up when the connection is
4456         not in use now, so don't need to check that. Should fix the
4457         infinite connection_death loop.
4458         (soup_connection_is_new): Keep a distinct "new" flag rather than
4459         defining "new" as "has been released at least once".
4460         (soup_connection_set_used): Mark a connection no-longer new.
4461         (soup_context_connect_cb): Mark the connection as new. Don't set
4462         up the death watch since it's in_use.
4463         (try_existing_connections): Use soup_connection_set_in_use.
4464         (soup_connection_release): Likewise
4465
4466         * libsoup/soup-message.c (requeue_read_finished): Call
4467         soup_connection_set_used so that the connection isn't still
4468         considered new when we send the message the second time.
4469
4470         * libsoup/soup-queue.c (soup_queue_error_cb): Call
4471         soup_connection_set_used (assuming we don't close the connection)
4472         (soup_queue_read_done_cb): Likewise.
4473
4474         * libsoup/soup-transfer.c (soup_transfer_read_cb): If we read
4475         nothing, call soup_transfer_read_error_cb rather than just
4476         cancelling, or else it will get cancelled again later.
4477
4478 2003-05-07  Dan Winship  <danw@ximian.com>
4479
4480         * soup-2.0.pc.in (Libs): Don't put @OPENSSL_LIBS@ here; the
4481         library doesn't depend on them, only the proxy does. #42473
4482
4483 2003-05-06  Dan Winship  <danw@ximian.com>
4484
4485         * src/libsoup/soup-message.c (global_handlers): Change the
4486         redirect handler to be a RESPONSE_ERROR_CLASS_HANDLER for
4487         SOUP_ERROR_CLASS_REDIRECT rather than a RESPONSE_HEADER_HANDLER
4488         for "Location" to get around the non-64-bit-clean union
4489         initialization pointed out by Jeremy Katz <katzj@redhat.com>.
4490         (redirect_handler): Update for that.
4491
4492 2003-04-28  Dan Winship  <danw@ximian.com>
4493
4494         * configure.in: 1.99.20
4495
4496         * libsoup/soup-transfer.c (soup_transfer_read_error_cb): Make sure
4497         we always call UNIGNORE_CANCEL. Might fix #41971
4498
4499 2003-04-25  Dan Winship  <danw@ximian.com>
4500
4501         * libsoup/soup-queue.c (soup_queue_error_cb): if an old connection
4502         suddenly gets an io error while reading or writing, assume it's a
4503         timeout or something, close the connection, and requeue the
4504         message.
4505
4506 2003-04-23  Dan Winship  <danw@ximian.com>
4507
4508         * libsoup/soup-message.c (soup_message_cleanup): Don't set up the
4509         soup-transfer callbacks to keep reading off the connection unless
4510         we're actually going to keep the connection around afterward.
4511         Otherwise we can just close it.
4512
4513         * libsoup/soup-transfer.c: Re-kludge the awful IGNORE_CANCEL
4514         thingy so that it's possible to cancel a read from inside a
4515         callback so that the above change actually works instead of just
4516         crashing.
4517
4518 2003-04-20  Rodney Dawes  <dobey@ximian.com>
4519
4520         * configure.in: Up version to 1.99.18
4521         * libsoup/Makefile.am: Line separator after GNUTLS_CFLAGS
4522         
4523 2003-04-11  Dan Winship  <danw@ximian.com>
4524
4525         * libsoup/soup-context.c (soup_connection_purge_idle): New
4526         function to close all idle connections. (Needed for #41117 or else
4527         there's no way to force-discard NTLM authentication.)
4528
4529         * libsoup/soup-queue.c (soup_queue_shutdown): Use it
4530
4531 2003-04-10  Joe Shaw  <joe@ximian.com>
4532
4533         * libsoup/soup-queue.c (proxy_https_connect):
4534         proxy_https_connect_cb() might not get called if connecting to the
4535         proxy fails, and it causes us to double-free the connection.
4536         Always set the message's connection to NULL before freeing it.
4537
4538 2003-04-09  Dan Winship  <danw@ximian.com>
4539
4540         * configure.in: 1.99.17
4541
4542 2003-04-07  Dan Winship  <danw@ximian.com>
4543
4544         * libsoup/soup-context.c (connection_death): Revert Joe's changes.
4545         We can't release the connection there because there may be
4546         SoupMessages still pointing to it. (Needs to be revisited.)
4547
4548 2003-04-03  JP Rosevear  <jpr@ximian.com>
4549
4550         * libsoup/soup-ssl.c (soup_ssl_hup_waitpid): guard against EINTR
4551         error during waitpid
4552
4553         * libsoup/soup-address.c: ditto
4554
4555 2003-04-02  Joe Shaw  <joe@ximian.com>
4556
4557         * libsoup/soup-context.c (connection_death): Only drop the
4558         connection if we get an error condition on the channel.  Fixes a
4559         double-free.
4560
4561 2003-04-02  Joe Shaw  <joe@ximian.com>
4562
4563         * libsoup/soup-context.c (connection_death): Just call
4564         soup_connection_release() from here and return whether the
4565         connection is in use.
4566
4567 2003-03-31  Ian Peters  <itp@ximian.com>
4568
4569         * libsoup/soup-gnutls.c (soup_gnutls_close): loop on gnutls_bye in
4570         case of EAGAIN or EINTR, since shutting down an SSL connection
4571         requires more than just closing a socket.
4572
4573 2003-03-28  Dan Winship  <danw@ximian.com>
4574
4575         * libsoup/soup-message.c (soup_message_set_context): If the new
4576         context points to a different server from the old context, call
4577         soup_message_cleanup. Otherwise it tries to reuse the old
4578         connection...
4579
4580 2003-03-25  Joe Shaw  <joe@ximian.com>
4581
4582         * configure.in: Bump up to 1.99.16
4583
4584 2003-03-24  Joe Shaw  <joe@ximian.com>
4585
4586         * soup-error.[ch]: Add SOUP_ERROR_SSL_FAILED which gives a
4587         slightly better error message on various SSL failures than the
4588         previous message.
4589
4590         * soup-queue.c (soup_queue_error_cb): Throw the
4591         SOUP_ERROR_SSL_FAILED error when we fail an SSL handshake.
4592
4593 2003-03-21  Joe Shaw  <joe@ximian.com>
4594
4595         * soup-server.c: Use non-deprecated g_main_loop_* calls
4596         throughout.
4597         (soup_server_unref): Don't unref the main loop if it's NULL.
4598         Fixes a glib warning.
4599
4600 2003-03-18  Dan Winship  <danw@ximian.com>
4601
4602         * configure.in: comment out NSS checks. The NSS code doesn't work
4603         and there are no current plans to fix it.
4604
4605         * README (Features): Mention GnuTLS, remove NSS and the rest of
4606         the "Planned Features" section.
4607
4608         * MAINTAINERS: remove Alex
4609
4610         * libsoup/soup-openssl.c (soup_openssl_get_iochannel): Bump the
4611         timeout to 10 seconds (and get rid of the 3 tries) so we don't
4612         fail to connect just because the server is slow/far away.
4613
4614 2003-03-17  Joe Shaw  <joe@ximian.com>
4615
4616         * configure.in: Bump up to 1.99.15.
4617
4618 2003-03-12  Ian Peters  <itp@ximian.com>
4619
4620         * libsoup/soup-gnutls.c: because creating client credentials is
4621         expensive, keep the same one around as long as possible, only
4622         recreating it if the ssl_ca_file changes.  Wrap
4623         gnutls_certificate_credentials in a refcounted struct to avoid
4624         freeing it while another established connection may potentially
4625         need it (say, to rehandshake).
4626
4627 2003-03-11  Frank Belew  <frb@ximian.com>
4628
4629         * soup-2.0.pc.in: add ssl libs to defaults, since ssl doesn't 
4630         use pkgconfig
4631
4632 2003-03-10  Joe Shaw  <joe@ximian.com>
4633
4634         * configure.in: Bump up to 1.99.14.
4635
4636         * configure.in, libsoup/Makefile.am, libsoup/soup.gnutls.[ch],
4637         libsoup/soup-ssl.c: Add support for GnuTLS.  Patch from Ian
4638         Peters.
4639
4640 2003-03-07  Joe Shaw  <joe@ximian.com>
4641
4642         * configure.in: Bump up to 1.99.13.
4643
4644         * libsoup/soup-context.c (soup_context_connect_cb): Add G_IO_IN to
4645         the list of conditions to watch.  If the remote end hangs up the
4646         connection, we'll get a successful read of 0 bytes, not a HUP.
4647         The connection will have to be released by the point we check for
4648         it in connection_death().
4649
4650         * libsoup/soup-queue.c (soup_queue_error_cb): Get rid of some
4651         (apparently) errant resetting of the read and write tags.  I think
4652         this might have been causing some reentrancy and crashes.
4653
4654         * libsoup/soup-socket.c (soup_socket_get_iochannel): Set the IO
4655         channel to NULL encoding and not buffered.
4656
4657         * libsoup/soup-transfer.c (soup_transfer_read_cb): Remove some
4658         incorrect comments.
4659
4660 2003-02-28  Joe Shaw  <joe@ximian.com>
4661
4662         * configure.in: Bump up to 1.99.12.
4663
4664         * libsoup/soup-transfer.c (soup_transfer_read_cb): We can get a
4665         header_len of 0 and a total_read of 0 in the case of a SIGPIPE; in
4666         this case we probably don't want to call the error callback, we
4667         just want to act like our transfer was cancelled.
4668
4669 2003-02-27  Joe Shaw  <joe@ximian.com>
4670
4671         Try to apply some order to the iochannel refcounting...
4672
4673         * configure.in: Bump up to 1.99.11.
4674
4675         * libsoup/soup-context.c (soup_connection_get_iochannel): The
4676         connections needs to own a reference to the iochannel!  If we're
4677         using HTTPS, release the ref we get from soup_socket_get_iochannel
4678         and replace it with the ref we get from soup_ssl_get_iochannel().
4679         Then, always ref the channel that we return (ugh, but that's the
4680         soup way).
4681         (connection_free): Release the connection's ref to the iochannel.
4682
4683         * libsoup/soup-ssl.c (soup_ssl_get_iochannel_real): Ref the
4684         iochannel. The reference we pass back will be owned by the
4685         connection.
4686         (soup_ssl_hup_waitpid): Release our ref.
4687
4688 2003-02-27  Joe Shaw  <joe@ximian.com>
4689
4690         * configure.in: Bump up to 1.99.10.
4691
4692         * libsoup/soup-ssl.c (soup_ssl_get_iochannel_real): Ref the
4693         iochannel, return to the status quo.  Sigh.
4694
4695 2003-02-26  Joe Shaw  <joe@ximian.com>
4696
4697         * configure.in: Bump up to 1.99.9.
4698
4699         * libsoup/soup-ssl.c (soup_ssl_hup_waitpid): Comment out the unref,
4700         it's causing problems with HTTPS and proxies; the iochannel
4701         refcounting is waaaaaay horked.
4702
4703 2003-02-26  Frank Belew  <frb@ximian.com>
4704
4705         * libsoup/Makefile.am: added workaround to link ssl-proxy statically
4706
4707 2003-02-11  Joe Shaw  <joe@ximian.com>
4708
4709         * configure.in: Bump up to 1.99.8 for snaps.
4710
4711         * libsoup/soup-address.c (soup_gethostbyname): Fix this for Solaris.
4712         It returns the address to the resulting hostent or NULL on failure,
4713         unlike Linux which returns an error code.
4714
4715 2003-02-11  Joe Shaw  <joe@ximian.com>
4716
4717         * configure.in: Bump up to 1.99.7 for snaps.
4718
4719         * libsoup/soup-openssl.c (soup_openssl_get_iochannel): Print out
4720         the error string from OpenSSL if we can't establish a connection.
4721
4722 2003-02-04  Joe Shaw  <joe@ximian.com>
4723
4724         * configure.in: Bump up to 1.99.6 for snaps.
4725
4726         * libsoup/soup-server.c (destroy_message): We already assigned
4727         chan, so don't reassign it, and unref it in all cases.
4728         (issue_bad_request): Always unref after a call to
4729         soup_socket_get_iochannel(), because it refs it.
4730         (conn_accept): Fix some funky GIOChannel reffing here.
4731
4732         * libsoup/soup-ssl.c (soup_ssl_get_iochannel_real): Don't call
4733         g_io_channel_ref() on the socket.  This is the exact opposite of
4734         what we want to do.  Create a temporary structure containing the
4735         parent pid and the old socket and unref the socket when our
4736         callback is called.  This should fix GIOChannels being leaked on
4737         SSL connections.
4738
4739         * libsoup/soup-ssl-proxy.c: Always close the GIOChannels after the
4740         main loop quits.
4741
4742 2003-01-22  Joe Shaw  <joe@ximian.com>
4743
4744         * configure.in: Bump up to 1.99.5 for the snaps.
4745
4746         * libsoup/soup-address.c (soup_address_new): If we found the
4747         address in our hash, we need to return NULL or else Soup will
4748         think we're doing an async lookup and do some cancellation on
4749         us.  Besides, we were returning the wrong type anyway and it
4750         was crashing things.
4751
4752 2003-01-17  Joe Shaw  <joe@ximian.com>
4753
4754         * libsoup/soup-ssl-proxy.c (soup_ssl_proxy_readwrite): It's not
4755         uncommon for us to get a G_IO_ERROR_AGAIN when trying to write
4756         out, so keep trying until we succeed.
4757
4758 2003-01-10  Joe Shaw  <joe@ximian.com>
4759
4760         * libsoup/soup-openssl.c (verify_cb): Load some X509 and SSL error
4761         strings and print out the error when the cert can't verify.
4762
4763 2003-01-09  Dan Winship  <danw@ximian.com>
4764
4765         * libsoup/soup-address.c (soup_gethostbyname): Fix a memcpy
4766         overrun noticed by valgrind
4767
4768 2002-12-20  Joe Shaw  <joe@ximian.com>
4769
4770         * libsoup/soup-server.c (soup_server_new_with_host): Added.
4771         Starts a server only on the interface specified, instead of all
4772         network interfaces.
4773
4774 2002-12-16  Jeremy Katz  <katzj@redhat.com>
4775
4776         * configure.in: use $libdir instead of /usr/lib when looking for
4777         libraries
4778
4779 2002-12-11  Joe Shaw  <joe@ximian.com>
4780
4781         * libsoup/soup-queue.c (proxy_https_connect_cb): I am an idiot.
4782         Don't set a variable to NULL and then immediately try to
4783         dereference it.
4784
4785 2002-12-09  Joe Shaw  <joe@ximian.com>
4786
4787         * libsoup/soup-openssl.c (soup_openssl_get_iochannel): Put a
4788         timeout on the select()s when we get SSL_ERROR_WANT_READ/WRITE so
4789         we don't hang forever if we don't get more data.
4790
4791         * libsoup/soup-ssl-proxy.c (main): Don't set our fds to blocking
4792         or else we'll hang forever in SSL_connect() if the other side
4793         hangs up.
4794
4795         * libsoup/soup-queue.c (proxy_https_connect_cb): We never want to
4796         release the connection on message free, even if the connection was
4797         unsuccessful.
4798
4799 2002-12-03  Joe Shaw  <joe@ximian.com>
4800
4801         * libsoup/soup-ssl.c (soup_ssl_get_iochannel_real): Call
4802         g_io_channel_set_close_on_unref() on the second half of the socket
4803         pair so we don't leak file descriptors.
4804
4805 2002-12-03  Frank Belew  <frb@ximian.com>
4806
4807         * libsoup/soup-address.c: add signal.h to the list of headers to 
4808         pick up SIGKILL
4809         
4810 2002-11-25  Joe Shaw  <joe@ximian.com>
4811
4812         * Makefile.am: Build the tests directory again
4813
4814 2002-11-21  Rodney Dawes  <dobey@ximian.com>
4815
4816         * configure.in: Don't require autoconf 2.5x, needs to work with 2.13
4817         
4818 2002-11-20  Michael Meeks  <michael@ximian.com>
4819
4820         * configure.in: require autoconf 2.52 not 2.53.
4821
4822 2002-11-18  Dan Winship  <danw@ximian.com>
4823
4824         * libsoup/soup-address.c (soup_address_hash): Don't use s6_addr32
4825         since it's apparently non-portable. Use s6_addr instead.
4826         (soup_gethostbyaddr): fix a sometimes-uninitialized variable.
4827
4828         * libsoup/soup-error.c: Fix spelling of
4829         SOUP_ERROR_MOVED_PERMANENTLY and its description.
4830
4831         * libsoup/soup-message.c (soup_message_get_request_header, etc):
4832         Remove long-deprecated API.
4833
4834         * libsoup/soup-socket.c (soup_socket_connect): remove unused
4835         variable.
4836
4837         * libsoup/soup-openssl.c (soup_openssl_read): Use gsize.
4838         * libsoup/soup-server.c (cgi_read): Likewise
4839         * libsoup/soup-socks.c (soup_socks_write, soup_socks_read):
4840         Likewise.
4841         * libsoup/soup-ssl-proxy.c (soup_ssl_proxy_readwrite): Likewise.
4842         * libsoup/soup-transfer.c (soup_transfer_read_cb,
4843         soup_transfer_write_cb): Likewise.
4844
4845         * tests/timeserver.c: Add "-6" to listen on the IPv6 local address
4846         instead of IPv4. (Tested on OS X.)
4847
4848 2002-11-15  Dan Winship  <danw@ximian.com>
4849
4850         * libsoup/*: Change old Helix Code refs to Ximian (and update
4851         copyright dates).
4852
4853 2002-11-15  Frank Belew  <frb@ximian.com>
4854
4855         * tests/Makefile.am: uncomment lines to make timeserver build 
4856         correctly
4857         
4858 2002-11-14  Joe Shaw  <joe@ximian.com>
4859
4860         * libsoup/soup-address.c (soup_address_new): When we get an
4861         address from the hash, call our address lookup callback or else
4862         the connection will hang.
4863
4864 2002-11-13  Dan Winship  <danw@ximian.com>
4865
4866         * tests/timeserver.c: Oops, commit this.
4867
4868         * tests/Makefile.am (noinst_PROGRAMS): reenable timeserver.
4869
4870 2002-11-13  Joe Shaw  <joe@ximian.com>
4871
4872         * libsoup/Makefile.am: Replace the BINDIR define with LIBEXECDIR.
4873         (install-exec-hook): Install libsoup-ssl-proxy into libexecdir
4874         instead of bindir.
4875
4876         * libsoup/soup-openssl.c (soup_openssl_close): Call SSL_shutdown()
4877         to properly shut down the SSL connection before closing the
4878         socket.
4879
4880         * libsoup/soup-ssl-proxy.c (soup_ssl_proxy_readwrite): Close the
4881         iochannels before quitting the main loop.
4882
4883         * tests/Makefile.am: disable building timeserver, the source file
4884         wasn't added.
4885
4886 2002-11-12  Dan Winship  <danw@ximian.com>
4887
4888         * configure.in: Check for IPv6 support in networking headers.
4889
4890         * libsoup/soup-address.c: Make the internal structure of
4891         SoupAddress entirely private, and make SoupAddress be more like a
4892         hostent and less like a sockaddr. (Ie, make it not have a port
4893         associated with it.) Document undocumented functions. Add
4894         completely-untested support for IPv6.
4895         (soup_address_new_from_sockaddr): New, to parse a sockaddr into a
4896         SoupAddress and a port.
4897         (soup_address_ipv4_any, soup_address_ipv6_any): Return static
4898         addresses corresponding to the IPv6 and IPv6 "any" addresses.
4899         (soup_address_get_canonical_name): Use inet_ntop/inet_ntoa.
4900         (soup_address_make_sockaddr): Now constructs a new sockaddr, which
4901         may be a sockaddr_in or sockaddr_in6.
4902         (soup_address_gethostname, soup_address_gethostaddr): Remove
4903         these. They aren't reliable, especially on multihomed hosts.
4904         (soup_gethostbyname, soup_gethostbyaddr): support IPv6
4905         (soup_address_new): Keep pending lookups in a separate hash table
4906         from completed lookups. Fix a bug when canceling a lookup when
4907         there was more one outstanding request for it.
4908         (soup_address_lookup_in_cache): Removed.
4909
4910         * libsoup/soup-socket.c: Add a port field to SoupSocket (since
4911         it's not in SoupAddress any more).
4912         (soup_socket_connect): Simplify this. Don't use
4913         soup_address_lookup_in_cache, just call soup_address_new, since we
4914         already know the code can deal with the callback being invoked
4915         immediately.
4916         (soup_socket_new_sync, soup_socket_new): Take a port argument.
4917         (soup_socket_server_new): Take a SoupAddress to use as the local
4918         address to bind to. This lets the caller choose between the IPv4
4919         and IPv6 "any" addresses, and also lets you bind to a single
4920         interface of a multi-homed machine.
4921         (soup_socket_server_accept, soup_socket_server_try_accept): Merge
4922         the common code.
4923
4924         * libsoup/soup-server.c (soup_server_new): Pass
4925         soup_address_ipv4_any() to soup_socket_server_new().
4926
4927         * libsoup/soup-socks.c (soup_connect_socks_proxy,
4928         soup_socks_write): Fix up for the API changes, but it won't work
4929         with IPv6 yet.
4930
4931         * tests/timeserver.c: Another really simple test, for the server
4932         socket code.
4933
4934         * tests/Makefile.am: build timeserver
4935
4936 2002-11-11  Dan Winship  <danw@ximian.com>
4937
4938         * libsoup/soup-address.c: Move the SoupAddress code from
4939         soup-socket.c and soup-socket-unix.c to here.
4940
4941         * libsoup/soup-socket.c: Move the remaining code from
4942         soup-socket-unix.c here.
4943
4944         * libsoup/soup-socket-unix.c: Gone
4945
4946         * tests/get.c: really really trivial test program
4947
4948         * configure.in (AC_OUTPUT):
4949         * Makefile.am (SUBDIRS): add tests/
4950
4951 2002-11-05  Dan Winship  <danw@ximian.com>
4952
4953         * Split libsoup out of soup. ChangeLog.old contains the original
4954         soup ChangeLog.
4955
4956         * Makefile.am, etc: Fix things up to work with the new directory
4957         layout. Disable docs until we fix them.
4958
4959         * autogen.sh: Use gnome-autogen.sh
4960
4961         * configure.in: Require autoconf 2.53. Remove stuff that was only
4962         needed for httpd or wsdl code. Remove glib1 support. Bump version
4963         to 2.0.
4964
4965         * libsoup/Makefile.am: Rename library to libsoup-2.0, put includes
4966         in ${includedir}/soup-2.0
4967         
4968         * libsoup/*: Merge soup-0-7 back onto the trunk. Remove
4969         SOAP-specific stuff, Windows support, and other things that
4970         weren't being maintained.
4971
4972         * soup-config.in, soupConf.sh: Kill these. We only support
4973         pkg-config now.