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