drop
[oweals/gnunet.git] / TODO
diff --git a/TODO b/TODO
index ab1d9617237b597414b7928f901ca3be532c5fc1..992f61f8070563cd1cfa7feb0e574371776b548a 100644 (file)
--- a/TODO
+++ b/TODO
@@ -12,36 +12,40 @@ away), in order in which they will likely be done:
 * UPNP [Milan]
 
 Urgent items (before announcing ng.gnunet.org):
-* topology
-  - valgrind crash (in topology test case):
-==31107== Invalid read of size 8                                                                                                             
-==31107==    at 0x401DA1: free_peer (gnunet-daemon-topology.c:480)                                                                           
-==31107==    by 0x4030A2: cleaning_task (gnunet-daemon-topology.c:1212)                                                                      
-==31107==    by 0x545DCBD: run_ready (scheduler.c:482)                                                                                       
-==31107==    by 0x545E0CD: GNUNET_SCHEDULER_run (scheduler.c:609)                                                                            
-==31107==    by 0x545B00F: GNUNET_PROGRAM_run (program.c:223)                                                                                
-==31107==    by 0x403477: main (gnunet-daemon-topology.c:1346)                                                                               
-==31107==  Address 0x737e828 is 8 bytes inside a block of size 144 free'd                                                                    
-==31107==    at 0x4C21DBC: free (vg_replace_malloc.c:325)                                                                                    
-==31107==    by 0x544240B: GNUNET_xfree_ (common_allocation.c:144)                                                                           
-==31107==    by 0x401E13: free_peer (gnunet-daemon-topology.c:487)                                                                           
-==31107==    by 0x4030A2: cleaning_task (gnunet-daemon-topology.c:1212)                                                                      
-==31107==    by 0x545DCBD: run_ready (scheduler.c:482)                                                                                       
-==31107==    by 0x545E0CD: GNUNET_SCHEDULER_run (scheduler.c:609)                                                                            
-==31107==    by 0x545B00F: GNUNET_PROGRAM_run (program.c:223)                                                                                
-==31107==    by 0x403477: main (gnunet-daemon-topology.c:1346)                                                                               
-==31107==                                                                                                                                    
-  - considers peers 'connected' well before they actually are
-    (since core notifies about it too early?);
-  - (forced) disconnect does not work (also CORE API issue)
-  - needs testing (not sure the current testcase does much...)
-* hostlist
+* UTIL:
+  - provide higher-level convenience API for servers/services that
+    need to send a stream of notifications to clients; instead
+    of having each service queue messages and "send when ready", 
+    simply have a way to add a client to the notification set
+    and to 'notify client' or 'notify all clients'
+    (useful for peerinfo (new hellos), transport (our hello; blacklist), 
+     core (misc monitoring features), statistics (change notifications)
+     and likely others)
+  - server/service API change for ARM inetd'ing
+    (listen as well as support for start with multiple, already
+     bound & listening sockets!)
+* TRANSPORT:
+  - main service not implemented [Nate]
+  - blacklist not implemented [Christian]
+  - testcases crash & burn (no surprise)
+* CORE:
+  - request disconnect not implemented [Christian]
+  - various notification options not implemented [Christian]
+  - test currently fails spectacularly [segv of transport service]
+    => need transport to work first!
+  - request connect not working [Christian, need transport first]
+* PEERINFO:
+  - make sue we also trigger notifications whenever HELLOs expire
+* TOPOLOGY:
+  - needs testing [need transport first]
+* TESTING:
+  - check that 'GNUNET_TRANSPORT_get_hello' is associated with
+    a cancel request wherever appropriate (other testcases
+    in particular!) [Christian]
+* HOSTLIST:
   - test fails (looks like it works, but that's because of a bad
     connectivity notification; somehow core is unable to send
-    messages successfully via transport)
-* CORE:
-  - core notifies about connects "too early" (when we have not yet
-    succeeded with the full key exchange) [see also: BUGS]
+    messages successfully via transport) [need transport first]
 * FS (basic anonymous FS only)
   - implement FS service (P2P operations)
     + how to send queries (soliciting is not there in core; do we
@@ -69,6 +73,8 @@ Urgent items (before announcing ng.gnunet.org):
     [=> eliminate for need to tell ARM about service starts most of the time!]
 * HELLO:
   - need function to test "equivalency" of HELLOs; use in topology!
+* CORE:
+  - outbound message monitoring not supported
 * Module features to implement:
   - advanced FS API parts
     + namespaces: fundamental namespace API