(no commit message)
[oweals/gnunet.git] / TODO
diff --git a/TODO b/TODO
index 492d5b5ff8d7209518c010b0ed820706e0d2f63d..4b115c4bb12b543f0da446fdcf4057afbc3d0f1c 100644 (file)
--- a/TODO
+++ b/TODO
-Implementable right now (but not necessarily important), with caveats
-(unavailable components that will limit what can be implemented right
-away), in order in which they will likely be done:
-* TESTING-TESTBED [Nate]
-* SETUP
-* DV [Nate]
-* TBENCH
-* TRACEKIT
-* FRAGMENTATION [Ji Lu]
-* HTTP transport
-* MySQL / Postgres plugins (datastore, datacache)
-* UPNP [Milan]
-* ARM [Safey]
-
-Urgent items (before announcing ng.gnunet.org):
-* TRANSPORT:
-  - main service not implemented [Nate]
-  - testcases crash & burn (no surprise)
-* CORE:
-  - outbound message monitoring not supported [Christian]
-  - test currently fails spectacularly [segv of transport service]
-    => need transport to work first!
-  - request connect not working [Christian, need transport first]
-* TOPOLOGY:
-  - needs testing [need transport first]
-* HOSTLIST:
-  - needs testing [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
-      also want to do pushing sometimes?)
-    + need to bound queueing of replies for other peers    
-  - test multi-peer search/download
-* new webpage
-  - run peer => have a 0.9.x hostlist
-  - improve basic documentation (configure, dependencies, what works, etc.)
-  - write minimal welcome/introduction to 0.9.x-development/webpage/status
-=> Deploy(able) development network
-
-
-0.9.0pre0:
-* UTIL:
-  - load: need way to determine network load (up/down)
-  - trust: need *fast* way to check/update trust in peers
-           (async peerinfo would not be right)
-  - OS: existing waitpid call is not nice (not integratable with scheduler! fix this!)
-    => should 'scheduler' support SIGCHILD explicitly? Always?
-* STATISTICS:
-  - synchronous/asynchronous API (& implementation) is not nice;
-    => provide notification-based API
-  - does not seem to work with timeouts (especially if service is not running)
-* ARM:
-  - need to get rid of synchronous API for service starts (cause all kinds of problems)
-    [=> eliminate for need to tell ARM about service starts most of the time!] [Safey]
-* HELLO:
-  - need function to test "equivalency" of HELLOs; use in topology!
-* Module features to implement:
-  - advanced FS API parts
-    + namespaces: fundamental namespace API
-    + search: SBlocks, KSBlocks, probes, notify FS-service of known results
-    + collection
-    + location URIs (publish, search, download)
-    + persistence support (publish, unindex, search, download)
-    + indexing: index-failure-cleanup
-    + download: management/bounding of parallel downloads (for recursive dl.)
-    + datastore reservation (publishing)
-    + gnunet-publish (URI args)
-    + gnunet-download (directory)
-    + gnunet-search (options, incl. namespace search)
-    + gnunet-download (many options)
-    + gnunet-directory (man page, options)
-    + gnunet-pseudonym (all of it)
-    + gnunet-service-fs (remove failing on-demand blocks, many other nitpicks/features/optimizations)
-    + datastore: do active migration support here?
-  - implement adv. FS testcases 
-    + getopt API
-    + insert: sblocks, loc uris
-    + download: loc uris
-    + search: sblocks, skblocks, loc uris
-    + namespaces
-    + collection
-  - implement FS performance tests (needs TESTING)
+0.9.0pre4:
+* GNUNET-GTK: [CG]
+  - provide context menus to allow aborts of downloads/uploads
+  - provide way to handle errors (search, download, publish errors)
+* FS [CG]
+  - implement multi-peer FS performance tests + gauger them!
     + insert
     + download
     + search
-    + unindex
-  - non-anonymous FS service (needs DHT)
-    + basic DHT integration
-    + CS-DHT-functions (DHT-put of LOC)
-    + P2P-functions (DHT-get)
-  - setup (RC-pre0)
-    + default generation
-    + need to settle basic design; do we want to keep guile?
-  - testing (RC-pre0)
-    + modify configuration to allow controlling connections for non-local starts
-    + testbed creation with topology (needs working F2F topology) [Nate]
-    + testbed with churn [Nate]
-    + implement library for distributed testing [Nate]
-    + implement testcases for distributed testing [Nate]
-    + test basic peer re-configure [Nate]
-    + test topology creation [Nate]
-    + test churn generation [Nate]
-
-0.9.0pre1:
-* Module features to implement:
-  - tbench (RC-pre1)
-    + good to have for DV evaluation!
-  - DV (RC-pre1)
-    + write DV API 
-    + implement DV service [Nate & CG]
-    + implement DV library [Nate]
-    + implement DV transport plugin [Nate & CG]
-    + implement testcases [Nate]
-    + implement performance tests [Nate]
-* GUIs to implement:
-  - gtk (RC-pre1)
-    + how to integrate scheduler with GTK event loop!
-
-0.9.0pre2:
-* Module features to implement:
-  - tracekit (RC-pre2)
-    + good to have for DV/DHT evaluation!
-  - DHT (RC-pre2)
-    + implement DHT service (needs DV, DATACACHE)
-    + implement DHT library
-    + implement testcases
-    + implement performance tests
-* GUIs to implement:
-  - fuse (RC-pre2)
-* Plugins to implement:
-  - UDP backend (RC-pre2)
-    + Fragmentation library 
-    + actual plugin
-  - HTTP backend (RC-pre2)
-
-0.9.0pre3:
-* GUIs to implement:
-  - qt (RC-pre3)
-    + see discussions @ FISL about integration with event loop!
-* Determine RC bugs and fix those!
+* transport:
+  - CONNECT: actually consider switching session...
 
 0.9.0:
-* Documentation
-  - update man pages
-  - update webpage documentation
 * new webpage:
-  - expand bibliography
-  - convert documentation pages to books
-  - update books (especially for developers)
-  - create good Drupal theme for GNUnet
-  - make a NICE download page and figure out how to 
-    enable developers to publish TGZs nicely
-  - port "contact" page
-  - add content type for "todo" items?
-  - DNS activation
-* Plugins to implement:
-  - MySQL database backends
-    + datacache
-    + datastore
-  - Postgres database backends
-    + datacache
-    + datastore
-  - vpn
-* Determine RC bugs and fix those!
-
+  - write chapter on DHT/block [Nate] 
+  - make a NICE download page 
+* big code review
+* Determine RC bugs and fix those (release should have no known real bugs)
 
-0.9.x:
-* Plugins to implement:
-  - SMTP transport backend
-  - HTTPS transport backend
-    + improved HTTPS support in MHD
-    + actual plugin
-* Remove KBlocks in gnunet-unindex (see discussion with Kenneth Almquist on gnunet-devs in 9/2009)
-* Allow checking of presence of search results and/or content via command-line tools
-  (add options to gnunet-search / gnunet-download to limit search to local peer)
+0.9.1:
+* TRANSPORT: [MW]
+  - 'TransmitFunction' requires plugins to have "unbounded" queue (or at least 
+    queue of size > 2), might be better to have at MOST one message pending
+    per plugin/target and only send the next one after the continuation was
+    called (or use 'notify_transmit_ready-style API?)
+  - WLAN transport backend [DB]
+  - need to periodically probe latency/transport cost changes & possibly switch transport 
+    (working ATS)
+* DV: 
+  - proper bandwidth allocation
+  - performance tests
+* PEERINFO:    
+  - merge multiple HELLOs of the same peer in the transmission queue
+    (theoretically reduces overhead; bounds message queue size)
+  - merge multiple iteration requests over "all" peers in the queue
+    (theoretically reduces overhead; bounds messgae queue size)
 * STATISTICS:
   - should use BIO instead of mmap
-* PEERINFO:
+* FS: [CG]
+  - Remove KBlocks in gnunet-unindex (see discussion with Kenneth Almquist on gnunet-devs in 9/2009)
+  - use different queue prioritization for probe-downloads vs. normal downloads
+  - re-implement gnunet-auto-share
+  - implement 'GNUNET_FS_file_information_create_from_directory', avoiding
+    code duplication with gnunet-gtk's similar code (!)
+* GNUNET-GTK: [CG]
+  - add tool bar
+  - do meaningful update to status line (starting up, peer running, #connections, shutdown, ...)
+  - add progress dialog for 'add_dir_at_iter' scan (can take a while...)
+  - NS list in search dialog should use colors to offset our own namespaces from the others
+  - right-clicking on NS list in search dialog should open menu that allows 
+    * viewing full meta data 
+    * deletion of namespace info
+  - implement unindex operation (use dialog with all indexed files for selection)
+  - finish publish dialog details:
+    + normalize keywords (edit subdialog)
+  - implement download by URI dialog; figure out where to display those downloads!
+  - add combo box to select desired mime type for search
+* ARM: [CG]
+  - better tracking of which config changes actually need to cause process restarts by ARM.
+  - handle gnunet-arm -k in combination with auto-start magic (what is the right thing here?)
+  - discover dependencies between services
+
+0.9.2:
+* PEERINFO: [NN]
   - expire 'ancient' HELLOs (those without valid addresses AND that 
     we have not 'used' (for their public keys) in a while; need a way
     to track actual 'use')
   - make sue we also trigger notifications whenever HELLOs expire
+* WLAN:
+  - nice signal strength adjustment [MW]
+  - energy cost in ATS [MW]
+* BLOCKS:
+  - testcase would be nice
+* STATISTICS:
+  - implement statistics GUI (=> start from gnunet-gtk by button!)
+* PEERINFO: [NN]
+  - move peerinfo to new GUI (=> start from gnunet-gtk by button!)
+  - extend peer dialog with green-yellow-red connectivity status lights
+  - extend peer dialog with country flags and names
+
+0.9.3:
+* SMTP transport backend:
+  - sending (SMTP/SMTPS)
+  - receiving (IMAP/IMAPS/POP?)
+  - rate limiting
+  - improved batching
+  - resource limit integration with ATS
+* VPN 
+  - "DNS" .gnunet [MW]
+* MESH:
+  - optimized routes (beyond DHT/DV)