]> granicus.if.org Git - apache/blob - STATUS
replace ssl_ds_array usage with apr_array_header_t
[apache] / STATUS
1 APACHE 2.0 STATUS:                                              -*-text-*-
2 Last modified at [$Date: 2002/03/12 14:41:29 $]
3
4 Release:
5
6     2.0.34  : in development
7     2.0.33  : tagged March 6, 2002.
8     2.0.32  : released Feburary 16, 2002.
9     2.0.31  : rolled Feburary 1, 2002.  not released.
10     2.0.30  : tagged January 8, 2002.  not rolled.
11     2.0.29  : tagged November 27, 2001.  not rolled.
12     2.0.28  : released November 13, 2001
13     2.0.27  : rolled November 6, 2001
14     2.0.26  : tagged October 16, 2001.  not rolled.
15     2.0.25  : rolled August 29, 2001
16     2.0.24  : rolled August 18, 2001
17     2.0.23  : rolled August 9, 2001
18     2.0.22  : rolled July 29, 2001
19     2.0.21  : rolled July 20, 2001
20     2.0.20  : rolled July 8, 2001
21     2.0.19  : rolled June 27, 2001
22     2.0.18  : rolled May 18, 2001
23     2.0.17  : rolled April 17, 2001
24     2.0.16  : rolled April 4, 2001
25     2.0.15  : rolled March 21, 2001
26     2.0.14  : rolled March 7, 2001
27     2.0a9   : released December 12, 2000
28     2.0a8   : released November 20, 2000
29     2.0a7   : released October 8, 2000
30     2.0a6   : released August 18, 2000
31     2.0a5   : released August 4, 2000
32     2.0a4   : released June 7, 2000
33     2.0a3   : released April 28, 2000
34     2.0a2   : released March 31, 2000
35     2.0a1   : released March 10, 2000
36
37 Please consult the following STATUS files for information
38 on related projects:
39
40     * srclib/apr/STATUS
41     * srclib/apr-util/STATUS
42     * docs/STATUS
43
44
45 CURRENT RELEASE NOTES:
46
47     * 34 status: Let's get all API changes and showstoppers in this one.
48                  Please.
49
50 FINAL RELEASE SHOWSTOPPERS:
51
52     * If any request gets to the core handler, without a flag that this 
53       r->filename was tested by dir/file_walk, we need to 500 at the very 
54       end of the ap_process_request_internal() processing.  This provides
55       authors of older modules better compatibility, while still improving
56       the security and robustness of 2.0. 
57         Status: still need to decide where this goes, OtherBill comments...
58         Message-ID: <065701c14526$495203b0$96c0b0d0@roweclan.net>
59         we need to look at halting this in the 'default handler' case,
60         and that implies pushing the 'handler election' into the request
61         internal processing phase from the run request phase.
62         Jim asks: would a stopgap be something bogus like adding another
63         flag to request_rec ala eos_sent and before we OK, if not set
64         force 500?
65         Jeff says: reviewing the original message and the one
66         follow-up (also from OtherBill) it looks like OtherBill had a
67         good handle on the problem, though I wonder why not just put a
68         simple check in default_handler to see if dir/file_walk has
69         been done (a footprint left by dir/file_walk doesn't have to
70         be in request_rec; a better place is core_request_config)
71
72     * We need to find out the right place to add the AddOutputFilterByType
73       directive.  mod_mime?  No.  core with fixups?  That's what it is now.
74       ap_pass_brigade() hook?  As a filter that runs at HTTP_HEADER stage?
75       This needs to be resolved before the next public release.
76         Message-ID: <018701c1b99c$f0f24310$0a01230a@KOJ>
77         
78     * API changes planned for 2.0 that should happen before the
79       GA release:
80           * Free lists for bucket allocation
81           * Pool allocator change
82
83     * We do not properly substitute the prefix-variables in the configuration
84       scripts or generated-configs.  (i.e. if sysconfdir is etc,
85       httpd-std.conf points to conf.)
86         Aaron says: This is not a showstopper, these problems have existed
87                     for as long as I can remember. It would be nice to fix
88                     them but they are not new.
89
90     * Address popular PRs
91         * Win32 doesn't install as service correctly [9863, 9914, 9961]
92         * Don't be stupid and cd to a blank directory when doing installs
93           [PR 9993]
94
95 CURRENT VOTES:
96
97     * Should we always build binaries statically unless otherwise
98       indicated?
99         Message-ID: <20020129210006.B23512@Lithium.MeepZor.Com>
100
101       +1:  Ken
102       -1:  Justin, Ian
103         
104     * If the parent process dies, should the remaining child processes
105       "gracefully" self-terminate. Or maybe we should make it a runtime
106       option, or have a concept of 2 parent processes (one being a 
107       "hot spare").
108       See: Message-ID: <3C58232C.FE91F19F@Golux.Com>
109
110       Self-destruct: Ken, Martin
111       Not self-destruct: BrianP, Ian, Cliff, BillS
112       Make it runtime configurable: Aaron, Jim, Justin
113       Have 2 parents: +1: Jim
114                       -1: Justin
115                       +0: Martin (while standing by, could it do
116                                   something useful?)
117
118     * Make the worker MPM the default MPM for threaded Unix boxes.
119       +1:   Justin, Ian, Cliff
120       -0:   Aaron (premature decision, needs more discussion), Lars
121
122 RELEASE NON-SHOWSTOPPERS BUT WOULD BE REAL NICE TO WRAP THESE UP:
123
124     * mod_negotiation may be broken on Win32 with large .var
125       files.  Some Win32 savant needs to evaluate the Win32 
126       portion of the patch posted to dev@apr.apache.org in this
127       message: <m3sn761ra6.fsf@rdu88-250-166.nc.rr.com>
128
129     * Convert all instances of the old apr_lock_t type to the new
130       types.
131         Status: Aaron has converted all but the perchild MPM to
132                 use the new lock API. Since perchild has been put
133                 on the back burner, this is no longer a showstopper.
134                 Aaron will patch perchild as soon as it becomes
135                 buildable again.
136
137     * With AP_MODE_EXHAUSTIVE in the core, it is finally clear to me
138       how the Perchild MPM should be re-written.  It hasn't worked
139       correctly since filters were added because it wasn't possible to
140       get the content that had already been written and the socket at
141       the same time.  This mode lets us do that, so the MPM can be
142       fixed.
143
144     * htpasswd blindly processes the file you give it, and does no
145       sanity checking before totally corrupting whatever file it was
146       you thought you had. It should check the input file and bail
147       if it finds non-comment lines that do not contain exactly 1
148       ':' character.
149         Message-ID: <20020217150457.A31632@clove.org>
150
151     * Can a static httpd be built reliably?
152         Message-ID: <20020207142751.T31582@clove.org>
153
154     * [Ken] Test suite failures:
155       o worker is also failing some of the 'cgi' subtests
156       (see <URL:http://Source-Zone.Org/Apache/regression/>):
157         Justin says: "Worker should be fine and passes httpd-test here.
158                       If you can provide evidence that it can be reproduced
159                       outside of httpd-test, then it's a showstopper.  I
160                       think it's a perl or a httpd-test problem."
161         Not a showstopper: Justin
162
163     * Usage of APR_BRIGADE_NORMALIZE in core_input_filter should be
164       removed if possible.
165         Message-ID: <Pine.LNX.4.33.0201202232430.318-100000@deepthought.cs.virginia.edu>
166         
167     * There is a bug in how we sort some hooks, at least the pre-config
168       hook.  The first time we call the hooks, they are in the correct 
169       order, but the second time, we don't sort them correctly.  Currently,
170       the modules/http/config.m4 file has been renamed to 
171       modules/http/config2.m4 to work around this problem, it should moved
172       back when this is fixed.    rbb
173         Justin says: "Is this really a showstopper?  This has been here
174                       forever.  What's wrong?  Does this have to do with
175                       autoconf or m4?"
176         Not a showstopper: Justin, BrianP, trawick, gregames
177
178     * The Add...Filter and Set...Filter directives do not allow the
179       administrator to order filters, beyond the order of filename (mime)
180       extensions.  It isn't clear if Set...Filter(s) should be inserted 
181       before or after the Add...Filter(s) which are ordered by sequence of
182       filename extensions.  At minimum, some sort of +-[0-10] syntax seems
183       like the quickest fix for a 2.0 gold release.
184         Justin says: "Could we delay this for a point release or 2.1?"
185         Not a showstopper: justin, wrowe, trawick, stoddard, Jim, Ian, Aaron,
186                            gregames
187
188     * Get perchild to work on platforms other than Linux. This
189       will require a portable mechanism to pass data and file/socket
190       descriptors between vhost child groups. An API was proposed
191       on dev@apr:
192         Message-ID: <20020111115006.K1529@clove.org>
193
194     * CGI single-byte reads
195       BrianP suggests that this is caused by the ap_scan_script_header_err()
196       routine, which will do single-byte reads until it finds the end
197       of the header, at which point it constructs a pipe-bucket (buffered)
198       to read from.
199       Proposed solution in:
200         Message-ID: <3C36ADAF.60601@cnet.com>
201
202     * Try to get libtool inter-library dependency code working on AIX.
203         Message-ID: <cm3n10lx555.fsf@rdu163-40-092.nc.rr.com>
204
205       Justin says: If we get it working on AIX, we can enable this
206                    on all platforms and clean up our build system
207                    somewhat.
208       Jeff says:   I thought I tested a patch for you sometime in
209                    January that you were going to commit within a few
210                    days.
211
212     * Handling of %2f in URIs.  Currently both 1.3 and 2.0
213       completely disallow %2f in the request URI path (see
214       ap_unescape_url() in util.c).  It's permitted and passed
215       through in the query string, however.  Roy says the
216       original reason for disallowing it, from five years ago,
217       was to protect CGI scripts that applied PATH_INFO to
218       a filesystem location and which might be tricked by
219       ..%2f..%2f(...).  We *should* allow path-info of the
220       form 'http://foo.com/index.cgi/path/to/path%2finfo'.
221       Since we've revamped a lot of our processing of path
222       segments, it would be nice to allow this, or at least
223       allow it conditionally with a directive.
224
225     * FreeBSD, threads, and worker MPM.  All seems to work fine 
226       if you only have one worker process with many threads.  Add 
227       a second worker process and the accept lock seems to be
228       lost.  This might be an APR issue with how it deals with
229       the child_init hook (i.e. the fcntl lock needs to be resynced).
230       More examination and analysis is required.
231         Status: This has also been reported on Cygwin.  
232         Message-ID: <3C2CC514.8EF3BED1@wapme-systems.de> (cygnus)
233
234       Justin says: So, FreeBSD-CURRENT and Cywin have the same 
235                    problem.  Yum.  If another platform has this
236                    with worker, this becomes a showstopper.
237       Aaron says: I spent some time disecting this and have come to
238               the conclusion that it is not a problem in the worker MPM
239               (or at least, it is not isolated to a problem in worker).
240               I'll list some of the problems I'm seeing in case someone
241               else wants to pick up where I've left off:
242                - Delivery of just about any signal to one of the child
243                  processes will send it into an infinite loop as well.
244                - Even though the parent is spinning out of control,
245                  at first the child or children will appear to work
246                  properly. At times it is possible to get it into a state,
247                  however, where a request will hang until another concurrent
248                  request "kicks" the first, at which point the second will
249                  hang. My theory is that this has to do with the
250                  pthread_cond_*() implementation in FreeBSD, but it's still
251                  possible that it is in APR.
252       
253       Justin adds: Oh, FreeBSD threads are implemented entirely with 
254                    select()/poll()/longjmp().  Welcome to the nightmare.
255                    So, that means a ktrace output also has the thread 
256                    scheduling internals in it (since it is all the same to 
257                    the kernel).  Which makes it hard to distinguish between 
258                    our select() calls and their select() calls.  
259                    *bangs head on wall repeatedly*  But, some of the libc_r 
260                    files have a DBG_MSG #define.  This is moderately helpful
261                    when used with -DNO_DETACH.  The kernel scheduler isn't 
262                    waking up the threads on a select().  Yum.  And, I bet 
263                    those decrementing select calls have to do with the 
264                    scheduler.  Time to brush up on our OS fundamentals.
265
266     * There is increasing demand from module writers for an API
267       that will allow them to control the server Ã  la apachectl.
268       Reasons include sole-function servers that need to die if
269       an external dependency (e.g., a database) fails, et cetera.
270       Perhaps something in the (ever more abused) scoreboard?
271         rbb: I don't believe the scoreboard is the correct mechanism
272              for this.  We already have a pipe that goes between parent
273              and child for graceful shutdown events, along with an API that
274              can be used to send a message down that pipe.  In threaded MPMs,
275              it is easy enough to make that one pipe be used for graceful
276              and graceless events, and it is also easy to open that pipe
277              to both parent and child for writing.  Then we just need to
278              figure out how to do graceless on non-threaded MPMs.
279
280     * Allow the DocumentRoot directive within <Location > scopes?  This
281       allows the beloved (crusty) Alias /foo/ /somepath/foo/ followed
282       by a <Directory /somepath/foo> to become simply 
283       <Location /foo/> DocumentRoot /somefile/foo (IMHO a bit more legible
284       and in-your-face.)  DocumentRoot unset would be accepted [and would
285       not permit content to be served, only virtual resources such as
286       server-info or server-status.
287         This proposed change would _not_ depricate Alias.
288
289     * Win32: Rotatelogs sometimes is not terminated when Apache
290       goes down hard.  FirstBill was looking at possibly tracking the 
291       child's-child processes in the parent process.
292         OtherBill asks, wasn't this fixed? 
293         stoddard: Not fixed. Shared scoreboard might offer a good
294         way for the parent to keep track of 'other child' processes
295         and whack them if the child goes down.
296
297     * Win32: Add a simple hold console open patch (wait for close or
298         the ESC key, with a nice message) if the server died a bad 
299         death (non-zero exit code) in console mode.
300         Resolution: bring forward same ugly hacks from 1.3.13-.20
301
302     * Port of mod_ssl to Apache 2.0:
303
304       The current porting state is summarized in modules/ssl/README. The
305       remaining work includes:
306       (1) stablizing/optimizing the SSL filter logic
307       (2) Enabling the various SSL caching mechanisms (shmcb, shmht)
308       (3) Enabling SSL extentions
309       (4) Trying to seperate the https filter logic from mod_ssl -
310           This is to facilitate other modules that wish to use the https
311           filter or the mod_ssl logic or both as required.
312         Justin: mod_ssl filter logic is redone, so that should be fine.
313                 Madhu has submitted a patch for SSL caching - however, I
314                 am -0 on that patch as I *think* we could implement the
315                 shared memory another way that is much cleaner (i.e.
316                 treat shmem directly as a dbm via APR routines).  Justin 
317                 also thinks that the https filter logic may be sufficiently
318                 decoupled now, but isn't really sure.
319
320     * Performance & Debug: Eliminate most (and perhaps all) of the 
321       malloc/free calls in the bucket brigade code.  Need some 
322       light weight memory management functions that allow freeing 
323       memory (putting it back into a memory pool) when it is no 
324       longer needed. Enabling simple debugging features like guard
325       bands, double free detection, etc. would be cool but certainly
326       not a hard requirement.
327
328           Status: Cliff started to implement this using SMS as has
329                   been discussed at length for months, but since
330                   SMS is not being used anywhere else in the server,
331                   several people expressed the opinion that we should
332                   get rid of it entirely, meaning that the buckets
333                   need their own memory management (free list) functions.
334                   Cliff will implement that this weekend so we at least
335                   have something to look at/compare with.
336
337     * Eliminate unnecessary creation of pipes in mod_cgid
338         Status: Ken asks, didn't Jeff fix this when he fixed the queue
339                 overrun?
340
341     * Combine log_child and piped_log_spawn. Clean up http_log.c.
342       Common logging API.
343
344     * Document mod_file_cache.
345
346     * Platforms that do not support fork (primarily Win32 and AS/400)
347       Architect start-up code that avoids initializing all the modules 
348       in the parent process on platforms that do not support fork.
349
350     * Win32: Migrate the MPM over to use APR thread/process calls. This
351       would eliminate some code in the Win32 branch that essentially
352       duplicates what is in APR.
353
354     * There are still a number of places in the code where we are
355       losing error status (i.e. throwing away the error returned by a
356       system call and replacing it with a generic error code)
357
358     * Mass vhosting version of suEXEC.
359
360     * All DBMs suffer from confusion in support/dbmmanage (perl script) since 
361       the dbmmanage employs the first-matched dbm format.  This is not
362       necessarily the library that Apache was built with.  Aught to
363       rewrite dbmmanage upon installation to bin/ with the proper library 
364       for predictable mod_auth_dbm administration.
365         Questions; htdbm exists, time to kill dbmmanage, or does it remain
366                    useful as a perl dbm management example?  If we keep it,
367                    do we address the issue above?
368
369     * Integrate mod_dav.
370         Some additional items remaining:
371         - case_preserved_filename stuff
372             (use the new canonical name stuff?)
373         - find a new home for ap_text(_header)
374         - is it possible to remove the DAV: namespace stuff from util_xml?
375
376     * ap_core_translate() and its use by mod_mmap_static and mod_file_cache
377       are a bit wonky.  The function should probably be exposed as a utility 
378       function (such as ap_translate_url2fs() or ap_validate_fs_url() or 
379       something).  Another approach would be a new hook phase after
380       "translate" which would allow the module to munge what the
381       translation has decided to do.
382         Status: Greg +1 (volunteers), Ryan +1
383
384     * Explore use of a post-config hook for the code in http_main.c which
385       calls ap_fixup_virutal_hosts(), ap_fini_vhost_config(), and
386       ap_sort_hooks()  [to reduce the logic in main()]
387
388     * read the config tree just once, and process N times (as necessary)
389
390     * (possibly) use UUIDs in mod_unique_id and/or mod_usertrack
391
392     * (possibly) port the bug fix for PR 6942 (segv when LoadModule is put
393       into a VirtualHost container) to 2.0.
394
395     * shift stuff to mod_core.h
396
397     * callers of ap_run_create_request() should check the return value
398       for failure (Doug volunteers)
399
400     * Win32: Get Apache working on Windows 95/98. The following work
401         (at least) needs to be done:
402         - Document warning that OSR2 is required (for Crypt functions, in
403         rand.c, at least.)  This could be resolved with an SSL library, or
404         randomization in APR itself.
405         - Bring the Win9xConHook.dll from 1.3 into 2.0 (no sense till it
406         actually works) and add in a splash of Win9x service code.
407
408     * In order to use a DSO version of mod_ssl we have to link with
409       -lssl and -lcrypto. A workaround is in place right now where the
410       entire EXTRA_LIBS macro is being appended to the objects list, but
411       this is a hack. We should either revamp the APACHE_CHECK_SSL_TOOLKIT
412       autoconf function or come up with some other autoconf checks to
413       search for libssl and libcrypto and properly add them to mod_ssl's
414       link flags.
415
416     * Fix the worker MPM to use POD to kill child processes instead
417       of ap_os_killpg, regardless of how they should die. (Ryan Bloom)
418
419     * mod_cache: handle cache_control: no_cache "field_name" to enable 
420       cacheing the response w/o header "field_name"
421       See RFC2616 section 14.9.1
422
423 PRs that have been suspended forever waiting for someone to
424 put them into 'the next release':
425
426     * PR#76: general
427       missing call to "setlocale();"
428         Status: 
429
430     * PR#78: mod_include
431       Additional status for XBitHack directive
432         Status: 
433
434     * PR#362: mod_proxy
435       Mod_proxy doesn't allow change of error pages
436         Status: 
437
438     * PR#370: mod_env
439       Modified PATH environemnt variable is not passed, instead
440       system's is used
441         Status: 
442
443     * PR#440: mod_proxy
444       Proxy doesn't deliver documents if not connected
445         Status: 
446
447     * PR#534: mod_proxy
448       proxy converts ~name to %7Ename when name starts with a dot (.)
449         Status: 
450
451     * PR#537: mod_access
452       mod_access syntax allows hosts that should be restricted
453         Status: 
454
455     * PR#557: mod_auth-any
456       ~UserHome directories are not honored in absolute pathname
457       requests (.htaccess)
458         Status: 
459
460     * PR#612: mod_proxy
461       Proxy FTP Authentication Fails
462         Status: 
463
464     * PR#623: mod_include
465       A smarter "Last Modified" value for SSI documents (see PR number 600)
466         Status: 
467
468     * PR#628: config
469       Request of "Options SymLinksIfGroupMatch"
470         Status: 
471
472     * PR#700: mod_proxy
473       Proxy doesn't do links right for OpenVMS files through ftp:
474         Status: 
475
476     * PR#759: mod_imap
477       imap should read <MAP><AREA>*</MAP> too!
478         Status: 
479
480     * PR#793: general
481       RLimitCPU and RLimitMEM don't apply to all children like they should
482         Status: 
483
484     * PR#921: suexec
485       Uses cwd before filling it in, doesn't use syslog
486         Status: 
487
488     * PR#922: config
489       it is useful to allow specifiction that root-owned symlinks
490       should always be followed
491         Status: 
492
493     * PR#980: mod_proxy
494       Controlling Access to Remote Proxies would be nice...
495         Status: 
496
497     * PR#994: mod_proxy
498       Adding authentication "on the fly" through the proxy module
499         Status: 
500
501     * PR#1004: apache-api
502       request_config field in request_rec is moderately bogus
503         Status: 
504
505     * PR#1028: other
506       DoS attacks involving memory consumption
507         Status: 
508
509     * PR#1050: mod_log-any
510       Logging of virtual server to error_log as well
511         Status: 
512
513     * PR#1085: mod_proxy
514       ProxyRemote make a dead cycle.
515         Status: 
516
517     * PR#1117: mod_auth-any
518       Using NIS passwd.byname dbm files with AuthDBMUserFile
519         Status: 
520
521     * PR#1120: suexec
522       suexec does not parse arguments to #exec cmd
523         Status: 
524
525     * PR#1145: mod_include
526       Allow for Last-Modified: without resorting to XBitHack
527         Status: 
528
529     * PR#1158: apache-api
530       improvements to child spawning API
531         Status: 
532
533     * PR#1166: mod_proxy
534       ``nph-'' not honored (no buffering) for ProxyRemote mapping
535         Status: 
536
537     * PR#1176: mod_cgi
538       Apache cannot handle continuation line in headers
539         Status: 
540
541     * PR#1191: general
542       setlogin() is not called, causing problems with e.g. identd
543         Status: 
544
545     * PR#1204: general
546       regerror() exists, use it
547         Status: 
548
549     * PR#1233: apache-api
550       there is no way to keep per-connection per-module state
551         Status: 
552
553     * PR#1263: mod_autoexec
554       Add frame-safe anchor attribute to mod_autoindex links
555         Status: 
556
557     * PR#1268: suexec
558       CGI scripts running as Apache user: security (suexec etc.)
559         Status: 
560
561     * PR#1285: suexec
562       Error messages could be easier to spot in cgi.log file for suexec.c
563         Status: 
564
565     * PR#1287: mod_access
566       add allow,deny/deny,allow warning to mod_access
567         Status: 
568
569     * PR#1290: mod_proxy
570       Need to know "hit-rate" on proxy cache
571         Status: 
572
573     * PR#1358: mod_log-any
574       Selective url-encode of log fields (or maybe a pseudo
575       log_rewrite module?)
576         Status: 
577
578     * PR#1383: mod_headers
579       I make mod_headers to modify request headers as well as
580       response ones.
581         Status: 
582
583     * PR#1532: mod_proxy
584       Proxy transfer logging
585         Status: 
586
587     * PR#1547: mod_proxy
588       No HTTP_X_FORWARDED_FOR set...
589         Status: 
590
591     * PR#1567: mod_proxy
592       ProxyRemote proxy requests fail authentication by firewall
593         Status: 
594
595     * PR#1582: mod_rewrite
596       mod_rewrite forms REQUEST_URI different than mod_cgi does
597         Status: 
598
599     * PR#1677: mod_headers
600       mod_headers should allow mod_log_config-style formats in
601       header values
602         Status: 
603
604     * PR#1702: mod_proxy
605       mod_proxy to support persistent conns?
606         Status: 
607
608     * PR#1803: mod_include
609       patches to mod_include to allow for file tests
610         Status: 
611
612     * PR#1809: mod_auth-any
613       Suggestion for improving authentication modules and core source
614       code, problem with 401 and ErrorDocument
615         Status: 
616
617     * PR#1878: mod_proxy
618       listing of proxy cache content
619         Status: 
620
621     * PR#1905: suexec
622       Allow modules to set user:group for execution.
623         Status: 
624
625     * PR#2024: apache-api
626       adding auth_why to conn_rec
627         Status: 
628
629     * PR#2073: mod_log-any
630       pipelined connections are not logged correctly
631         Status: 
632
633     * PR#2074: mod_rewrite
634       mod_rewrite doesn't pass Proxy Throughput on internal subrequests
635         Status: 
636
637     * PR#2113: config
638       HTTP Server Rebuild Line Needs Changing for the better
639         Status: 
640
641     * PR#2138: mod_status
642       mod_status always displays 256 possible connection slots
643         Status: 
644
645     * PR#2221: documentation
646       Make online documentation search link back to my installation
647         Status: 
648
649     * PR#2284: general
650       Can not POST to ErrorDocument - Apache/1.3b6
651         Status: 
652
653     * PR#2314: mod_proxy
654       patterns in ProxyRemote
655         Status: 
656
657     * PR#2343: mod_status
658       Status module averages are for entire uptime
659         Status: 
660
661     * PR#2360: suexec
662       suexec for general access of user content?
663         Status: 
664
665     * PR#2396: general
666       Proposal for TimeZone directive
667         Status: 
668
669     * PR#2415: mod_info
670       /server-info doesn't check for the virtual host to list the info
671         Status: 
672
673     * PR#2421: config
674       problem specifying ndbm library for build ?with autoconfigure
675         Status: 
676
677     * PR#2431: general
678       A small addition to rotatelogs.c to improve program functionality.
679         Status: 
680
681     * PR#2446: config
682       AllowOverride FileInfo is too coarse
683         Status: 
684
685     * PR#2460: mod_cgi
686       TimeOut applies to output of CGI scripts
687         Status: 
688
689     * PR#2512: mod_access
690       &lt;IfDenied&gt; directive wanted
691         Status: 
692
693     * PR#2573: suexec
694       CGI's for general use still have to be run as another user
695       with suExec
696         Status: 
697
698     * PR#2648: general
699       Cache file names in Proxy module
700         Status: 
701
702     * PR#2760: config
703       [PATCH] User/Group for <Directory> and <Location> i.e. not only
704       in global and <Virtual>.
705         Status: 
706
707     * PR#2763: general
708       mailto tags and bundling bug report script
709         Status: 
710
711     * PR#2785: os-aix
712       Support for System Resource Controller
713         Status: 
714
715     * PR#2793: protocol
716       When will Apache support P3P? Any Plans?
717         Status: 
718
719     * PR#2873: config
720       Feedback/Comment on APACI
721         Status: 
722
723     * PR#2889: general
724       Inclusion of RPM spec file in CVS/distributions
725         Status: 
726
727     * PR#2906: general
728       Propose that Apache recommend $UNIQUE_ID for all "session id"
729       algorithms
730         Status: 
731
732     * PR#2907: config
733       suggestion: power up your Include directive :)
734         Status: 
735
736     * PR#3018: general
737       cannot limit some HTTP methods
738         Status: 
739
740     * PR#3143: apache-api
741       No module specific data hook for per-connection data
742         Status: 
743
744     * PR#3191: mod_negotiation
745       no way to set global quality-of-source (qs) coneg values
746       with multiviews
747         Status: 
748
749     * PR#3568: mod_proxy
750       Accessing URL through proxy server corrupts data.
751         Status: 
752
753     * PR#3605: mod_proxy
754       Some anonymous FTP URLs ask for authentication
755         Status: 
756
757     * PR#3677: general
758       New ErrorDocumentMatch directive
759         Status: 
760
761     * PR#4241: config
762       Need to be able to override shebang line to make CGI scripts
763       more portable.
764         Status: 
765
766     * PR#4244: config
767       "Files" and "FilesMatch" regexp does not recognize bang as
768       negation operator
769         Status: 
770
771     * PR#4448: mod_log-any
772       Please allow CGI env variables (QUERY_STRING, ...) to be logged
773       with %{}e
774         Status: 
775
776     * PR#4459: mod_include
777       Suggestion for better handling of Last-modified headers
778         Status: 
779
780     * PR#4490: mod_cgi
781       mod_cgi prevents handling of OPTIONS requests
782         Status: 
783
784     * PR#5713: os-windows
785       [PATCH] install as win32 service with domain account
786         Status: Cannot accept password-as-arg, we should prompt the
787                 user when -k install/-k config with a user argument.
788
789     * PR#5993: general
790       AllowOverride should have a 'CheckNone' and 'AllowNone' argument
791       instead of only 'None'
792         Status: 
793
794 Other bugs that need fixing:
795
796     * MaxRequestsPerChild measures connections, not requests.
797         Until someone has a better way, we'll probably just rename it
798         "MaxConnectionsPerChild".
799     
800     * Regex containers don't work in an intutive way
801         Status: No one has come up with an efficient way to fix this
802         behavior. Dean has suggested getting rid of regex containers
803         completely.
804         OtherBill suggests: We at least seem to agree on eliminating
805                             the <Container ~ foo> forms, and using only
806                             <ContainerMatch foo> semantics.
807
808     * SIGSEGV on Linux (glibc 2.1.2) isn't caught properly by a
809       sigwaiting thread. We need to work around this, perhaps unless
810       there is hope soon for a fixed glibc.
811
812     * orig_ct in the byterange/multipart handling may not be
813       needed. Apache 1.3 just never stashed "multipart" into
814       r->content_type. We should probably follow suit since the
815       byterange stuff doesn't want the rest of the code to see the
816       multipart content-type; the other code should still think it is
817       dealing with the <orig_ct> stuff.
818         Status: Greg volunteers to investigate (esp. since he was most 
819                 likely the one to break it :-)
820
821 Other features that need writing:
822
823     * Finish infrastructure in core for async MPMs
824         Status: post 2.0
825
826     * TODO in source -- just do an egrep on "TODO" and see what's there
827
828 Available Patches:
829
830    * Jon Travis's <jtravis@covalent.net> patch to deal with thread-safe
831      issues with inet_ntoa.  See message <20001201163220.A12827@covalent.net>
832         Status:  This is being set aside until the IPv6 work is finished
833                  so that we know exactly what is required.
834
835    * Martin Sojka <msojka@gmx.de>'s patch to add error reporting for failed 
836      htpasswd actions due to a full /tmp volume (other programs may have
837      similar problems?)
838         PR: 6475
839         Status:
840
841    * Mike Abbott's <mja@trudge.engr.sgi.com> patches to improve
842      performance
843        Status: These were written for 1.3, and are awaiting a port to
844        2.0
845  
846    * Jim Winstead's <jimw@trainedmonkey.com> patch to add CookieDomain and 
847      other small mod_usertrack features
848
849    * Dan Rench's <drench@xnet.com> patch to add allow the errmsg and timefmt 
850      of SSI's to be modified in the config file.  Patch is available in 
851      PR6193
852
853 Open issues:
854
855    * Which MPMs will be included with Apache 2.0?