4566fd0f6c160c4cb80449c1df8dedf6ce5b31ba
[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
5 * FS (DHT not available)
6 * SETUP
7 * DV (distributed testing not available)
8 * TBENCH (distributed testing not available)
9 * TRACEKIT (distributed testing not available)
10 * HTTP transport
11 * FRAGMENTATION
12 * MySQL / Postgres plugins (datastore, datacache)
13 * UPNP
14
15
16 PHASE #2: (Goal: recover basic file-sharing functionality)
17 * TESTING (needed for DV, DHT, Topology)
18   - implement library for local testing
19     + modify configuration to allow controlling
20       connections for non-local starts
21     + CORE service does not start with valid peer ID (all zeross)
22       -- testcase fails!
23     + consider changing API for peer-group termination
24       to call continuation when done
25     + testbed creation with topology (needs working F2F topology) [Nate]
26     + testbed with churn [Nate]
27   - implement testcases for library
28     + get test for basic peer start to work!
29     + test basic peer connect
30     + test group start
31     + test basic peer re-configure [Nate]
32     + test topology creation [Nate]
33     + test churn generation [Nate]
34 * TOPOLOGY:
35   - implement testcases (needs TESTING)
36 * HOSTLIST:
37   - implement testcases
38 * FS (basic anonymous FS only)
39   - design network structs (CS)
40     + unindex
41     + search/download, response
42   - implement basic FS library
43     - unindex
44     - keyword-search
45     - download (need search to be done)
46   - design network structs (P2P)
47     + query
48     + response
49   - implement FS service
50     + datastore request queueing mechanism
51     + CS-functions (search, download, index, get_indexed, unindex)
52     + P2P-functions (query, response)
53   - implement testcases 
54     + URI API
55     + getopt API
56     + sharing API
57       ~ file-information
58       ~ publish (insert, index)
59       ~ download
60       ~ search
61       ~ unindex
62       ~ namespaces
63       ~ collection
64     + directory API
65 * new webpage
66   - install on proper server
67   - activate as ng.gnunet.org
68 => Deploy(able) development network
69
70
71 PHASE #3: (Goal: ready for pre-release) [completion-goal: end of 2009]
72 * Module features to implement:
73   - advanced FS API parts
74     + namespaces
75       ~ fundamental namespace API
76       ~ SBlock search
77       ~ KSBlocks!?
78     + collection
79     + location URIs (publish, search, download)
80     + persistence support (publish, unindex, search, download)
81     + datastore reservation (publishing)
82     + indexing: index-failure-cleanup
83   - implement adv. FS testcases 
84     + insert: sblocks, loc uris
85     + download: loc uris
86     + search: sblocks, skblocks, loc uris
87     + namespaces
88     + collection
89   - implement FS performance tests (needs TESTING)
90     + insert
91     + download
92     + search
93     + unindex
94   - non-anonymous FS service (needs DHT)
95     + basic DHT integration
96     + CS-DHT-functions (DHT-put of LOC)
97     + P2P-functions (DHT-get)
98   - setup (RC-pre0)
99     + default generation
100     + need to settle basic design; do we want to keep guile?
101   - testing (RC-pre0)
102     + implement library for distributed testing [Nate]
103     + implement testcases for distributed testing [Nate]
104   - tbench (RC-pre1)
105     + good to have for DV evaluation!
106   - DV (RC-pre1)
107     + write DV API 
108     + implement DV service [Nate & CG]
109     + implement DV library [Nate]
110     + implement DV transport plugin [Nate & CG]
111     + implement testcases [Nate]
112     + implement performance tests [Nate]
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   - gtk (RC-pre1)
122     + how to integrate scheduler with GTK event loop!
123   - fuse (RC-pre2)
124   - qt (RC-pre3)
125     + see discussions @ FISL about integration with event loop!
126 * Plugins to implement:
127   - UDP backend (RC-pre2)
128     + Fragmentation library 
129     + actual plugin
130   - HTTP backend (RC-pre2)
131 * Determine RC bugs and fix those!
132
133 => PRE-RELEASE
134
135
136 PHASE #4: [completion-goal: mid 2010]
137 * Documentation
138   - Doxygen generation
139   - lcov generation
140   - update man pages
141   - update webpage documentation
142 * new webpage:
143   - expand bibliography
144   - convert documentation pages to books
145   - update books (especially for developers)
146   - create good Drupal theme for GNUnet
147   - make a NICE download page and figure out how to 
148     enable developers to publish TGZs nicely
149   - port "contact" page; add impressum
150   - add content type for "todo" items?
151   - DNS activation
152 * Plugins to implement:
153   - MySQL database backends
154     + datacache
155     + datastore
156   - Postgres database backends
157     + datacache
158     + datastore
159   - vpn
160 * Determine RC bugs and fix those!
161
162 => 0.9.0 RELEASE
163
164
165
166
167 Post 0.9.0 features:
168 * SMTP transport backend
169 * HTTPS transport backend
170   - improved HTTPS support in MHD
171   - actual plugin