update status
[oweals/gnunet.git] / TODO
1 Implementable right now (but not necessarily important), with caveats
2 (unavailable components that will limit what can be implemented right
3 away), in order in which they will likely be done:
4 * TESTING-TESTBED [Nate]
5 * SETUP
6 * DV [Nate]
7 * TBENCH
8 * TRACEKIT
9 * FRAGMENTATION [Ji Lu]
10 * HTTP transport
11 * MySQL / Postgres plugins (datastore, datacache) [Radhika]
12 * UPNP [Milan]
13
14 Urgent items (before announcing ng.gnunet.org):
15 * TEST:
16   - topology
17   - hostlist
18 * CORE:
19   - soliciting traffic for clients that registered for it is not implemented
20     (in the service, client API supports GNUNET_MESSAGE_TYPE_CORE_SOLICIT_TRAFFIC
21      but never receives any such messages); how to avoid busy-waiting here
22      is a good question (solicit => nothing, when to solicit again???)
23 * FS (basic anonymous FS only)
24   - implement FS service (P2P operations)
25     + how to send queries (soliciting is not there in core; do we
26       also want to do pushing sometimes?)
27     + need to bound queueing of replies for other peers    
28   - test multi-peer search/download
29 * new webpage
30   - prevent?
31   - migrate Mantis!?
32   - run peer => have a 0.9.x hostlist
33   - improve basic documentation (configure, dependencies, what works, etc.)
34   - write minimal welcome/introduction to 0.9.x-development/webpage/status
35 => Deploy(able) development network
36
37
38 0.9.0pre0:
39 * UTIL:
40   - heap: "remove_node" can hardly be O(1) given the API, but it should be [Radhika]
41   - load: need way to determine network load (up/down)
42   - trust: need *fast* way to check/update trust in peers
43            (async peerinfo would not be right)
44 * Module features to implement:
45   - advanced FS API parts
46     + namespaces: fundamental namespace API
47     + search: SBlocks, KSBlocks, probes, notify FS-service of known results
48     + collection
49     + location URIs (publish, search, download)
50     + persistence support (publish, unindex, search, download)
51     + indexing: index-failure-cleanup
52     + download: management/bounding of parallel downloads (for recursive dl.)
53     + datastore reservation (publishing)
54     + gnunet-publish (URI args)
55     + gnunet-download (directory)
56     + gnunet-search (options, incl. namespace search)
57     + gnunet-download (many options)
58     + gnunet-directory (man page, options)
59     + gnunet-pseudonym (all of it)
60     + gnunet-service-fs (remove failing on-demand blocks, many other nitpicks/features/optimizations)
61     + datastore: do active migration support here?
62   - implement adv. FS testcases 
63     + getopt API
64     + insert: sblocks, loc uris
65     + download: loc uris
66     + search: sblocks, skblocks, loc uris
67     + namespaces
68     + collection
69   - implement FS performance tests (needs TESTING)
70     + insert
71     + download
72     + search
73     + unindex
74   - non-anonymous FS service (needs DHT)
75     + basic DHT integration
76     + CS-DHT-functions (DHT-put of LOC)
77     + P2P-functions (DHT-get)
78   - setup (RC-pre0)
79     + default generation
80     + need to settle basic design; do we want to keep guile?
81   - testing (RC-pre0)
82     + modify configuration to allow controlling connections for non-local starts
83     + testbed creation with topology (needs working F2F topology) [Nate]
84     + testbed with churn [Nate]
85     + implement library for distributed testing [Nate]
86     + implement testcases for distributed testing [Nate]
87     + test basic peer re-configure [Nate]
88     + test topology creation [Nate]
89     + test churn generation [Nate]
90
91 0.9.0pre1:
92 * Module features to implement:
93   - tbench (RC-pre1)
94     + good to have for DV evaluation!
95   - DV (RC-pre1)
96     + write DV API 
97     + implement DV service [Nate & CG]
98     + implement DV library [Nate]
99     + implement DV transport plugin [Nate & CG]
100     + implement testcases [Nate]
101     + implement performance tests [Nate]
102 * GUIs to implement:
103   - gtk (RC-pre1)
104     + how to integrate scheduler with GTK event loop!
105
106 0.9.0pre2:
107 * Module features to implement:
108   - tracekit (RC-pre2)
109     + good to have for DV/DHT evaluation!
110   - DHT (RC-pre2)
111     + implement DHT service (needs DV, DATACACHE)
112     + implement DHT library
113     + implement testcases
114     + implement performance tests
115 * GUIs to implement:
116   - fuse (RC-pre2)
117 * Plugins to implement:
118   - UDP backend (RC-pre2)
119     + Fragmentation library 
120     + actual plugin
121   - HTTP backend (RC-pre2)
122
123 0.9.0pre3:
124 * GUIs to implement:
125   - qt (RC-pre3)
126     + see discussions @ FISL about integration with event loop!
127 * Determine RC bugs and fix those!
128
129 0.9.0:
130 * Documentation
131   - update man pages
132   - update webpage documentation
133 * new webpage:
134   - expand bibliography
135   - convert documentation pages to books
136   - update books (especially for developers)
137   - create good Drupal theme for GNUnet
138   - make a NICE download page and figure out how to 
139     enable developers to publish TGZs nicely
140   - port "contact" page
141   - add content type for "todo" items?
142   - DNS activation
143 * Plugins to implement:
144   - MySQL database backends
145     + datacache
146     + datastore
147   - Postgres database backends
148     + datacache
149     + datastore
150   - vpn
151 * Determine RC bugs and fix those!
152
153
154 0.9.x:
155 * Plugins to implement:
156   - SMTP transport backend
157   - HTTPS transport backend
158     + improved HTTPS support in MHD
159     + actual plugin
160 * Remove KBlocks in gnunet-unindex (see discussion with Kenneth Almquist on gnunet-devs in 9/2009)
161 * Allow checking of presence of search results and/or content via command-line tools
162   (add options to gnunet-search / gnunet-download to limit search to local peer)
163 * STATISTICS:
164   - should use BIO instead of mmap