CHANGELOG.md 8.45 KB
Newer Older
Karsten Loesing's avatar
Karsten Loesing committed
1
2
3
4
5
# Changes in version 1.8.1 - 2017-06-08

 * Medium changes
   - Fix a regression in parsing microdescriptors and version 1
     directories introduced in 1.8.0.
Karsten Loesing's avatar
Karsten Loesing committed
6
7


Karsten Loesing's avatar
Karsten Loesing committed
8
# Changes in version 1.8.0 - 2017-06-07
9

10
11
12
13
14
 * Medium changes
   - Store raw descriptor contents as offset and length into a
     referenced byte[], rather than copying contents into a separate
     byte[] per descriptor.

15
16
17
18
 * Minor changes
   - Turn keyword strings into enums and use the appropriate enum sets
     and maps to avoid repeating string literals and to use more speedy
     collection types.
19
   - Simplify and avoid repetition in parse helper methods.
20
21
   - Fix a bug where Microdescriptor's getDigestSha256Base64() returns
     a hex string rather than a base64 string.
22
   - Move descriptor digest computation to DescriptorImpl.
23
24
   - Fix a bug in digest computation by making sure that the
     descriptor string actually contains the end token.
25
26
27
28
   - Fix a bug where both RelayDirectoryImpl and all NetworkStatusImpl
     subclasses fail to get indexes right if parts of raw descriptor
     strings contain non-ASCII chars.  In practice, this only affects
     version 1 directories which were last archived in 2007.
29
30


Karsten Loesing's avatar
Karsten Loesing committed
31
# Changes in version 1.7.0 - 2017-05-17
32

Karsten Loesing's avatar
Karsten Loesing committed
33
 * Medium changes
34
35
   - Fix a bug where unrecognized lines in extra-info descriptors
     below crypto blocks were silently skipped.
36
   - Add support for six new key-value pairs added by OnionPerf.
37
38
   - Fix a bug where DescriptorIndexCollector would not delete
     extraneous local files if remote paths start with /.
39
   - Add previously missing method to obtain the digest of a vote.
Karsten Loesing's avatar
Karsten Loesing committed
40
   - Deprecate setFailUnrecognizedDescriptorLines() in
41
42
43
     DescriptorParser and DescriptorReader and refer to
     getUnrecognizedLines() in Descriptor if applications really need
     to fail descriptors containing unrecognized lines.
44
   - Parse "padding-counts" lines in extra-info descriptors.
45

46
47
48
 * Minor changes
   - Accept extra arguments in statistics-related extra-info
     descriptor lines, as permitted by dir-spec.txt.
49
   - Streamline digest method names.
50

51

Karsten Loesing's avatar
Karsten Loesing committed
52
# Changes in version 1.6.0 - 2017-02-17
53

54
55
56
57
 * Major changes
   - Deprecate DescriptorDownloader in favor of the much more widely
     used DescriptorCollector.

58
59
60
61
 * Medium changes
   - Add two methods for loading and saving a parse history file in
     the descriptor reader to avoid situations where applications fail
     after all descriptors are read but before they are all processed.
iwakeh's avatar
iwakeh committed
62
63
64
   - Unify the build process by adding git-submodule metrics-base in
     src/build and removing all centralized parts of the build
     process.
65
66
   - Avoid deleting extraneous local descriptor files when collecting
     descriptors from CollecTor.
67
68
69
70
   - Turn the descriptor reader thread into a daemon thread, so that
     the application can decide at any time to stop consuming
     descriptors without having to worry about the reader thread not
     being done.
71
72
73
   - Parse "proto" lines in server descriptors, "pr" lines in status
     entries, and "(recommended|required)-(client|relay)-protocols"
     lines in consensuses and votes.
74
   - Parse "shared-rand-.*" lines in consensuses and votes.
75
76
   - Deprecate DescriptorCollectorImpl now that
     DescriptorIndexCollector is the default.
77
78


Karsten Loesing's avatar
Karsten Loesing committed
79
# Changes in version 1.5.0 - 2016-10-19
80

81
82
83
84
85
86
 * Major changes
   - Make the DescriptorCollector implementation that uses CollecTor's
     index.json file to determine which descriptor files to fetch the
     new default.  Applications must provide gson-2.2.4.jar or higher
     as dependency.

87
88
89
90
 * Minor changes
   - Avoid running into an IOException and logging a warning for it.


Karsten Loesing's avatar
Karsten Loesing committed
91
# Changes in version 1.4.0 - 2016-08-31
92

93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
 * Major changes
   - Add the Simple Logging Facade for Java (slf4j) for logging
     support rather than printing warnings to stderr.  Applications
     must provide slf4j-api-1.7.7.jar or higher as dependency and can
     optionally provide a compatible logging framework of their choice
     (java.util.logging, logback, log4j).

 * Medium changes
   - Add an alpha version of a DescriptorCollector implementation that
     is not enabled by default and that uses CollecTor's index.json
     file to determine which descriptor files to fetch.  Applications
     can enable this implementation by providing gson-2.2.4.jar or
     higher as dependency and setting property descriptor.collector to
     org.torproject.descriptor.index.DescriptorIndexCollector.

108
 * Minor changes
109
110
   - Include resource files in src/*/resources/ in the release
     tarball.
111
   - Move executable, source, and javadoc jar to generated/dist/.
112
113


114
115
116
117
118
119
120
# Changes in version 1.3.1 - 2016-08-01

 * Medium changes
   - Adapt to CollecTor's new date format to make DescriptorCollector
     work again.


Karsten Loesing's avatar
Karsten Loesing committed
121
# Changes in version 1.3.0 - 2016-07-06
122
123
124

 * Medium changes
   - Parse "package" lines in consensuses and votes.
125
126
127
128
129
130
131
132
   - Support more than one "directory-signature" line in a vote, which
     may become relevant when authorities start signing votes using
     more than one algorithm.
   - Provide directory signatures in consensuses and votes in a list
     rather than a map to support multiple signatures made using the
     same identity key digest but different algorithms.
   - Be more lenient about digest lengths in directory signatures
     which may be longer or shorter than 20 bytes.
133
   - Parse "tunnelled-dir-server" lines in server descriptors.
134

135
136
137
138
 * Minor changes
   - Stop reporting "-----END .*-----" lines in v2 network statuses as
     unrecognized.

139

Karsten Loesing's avatar
Karsten Loesing committed
140
# Changes in version 1.2.0 - 2016-05-31
141
142
143
144

 * Medium changes
   - Include the hostname in directory source entries of consensuses
     and votes.
145
   - Also accept \r\n as newline in Torperf results files.
146
147
   - Make unrecognized keys of Torperf results available together with
     the corresponding values, rather than just the whole line.
148
149
   - In Torperf results, recognize all percentiles of expected bytes
     read for 0 <= x <= 100 rather than just x = { 10, 20, ..., 90 }.
150
151
   - Rename properties for overriding default descriptor source
     implementation classes.
152
   - Actually return the signing key digest in network status votes.
153
   - Parse crypto parts in network status votes.
154
155
   - Document all public parts in org.torproject.descriptor and add
     an Ant target to generate Javadocs.
156

157
158
159
 * Minor changes
   - Include a Torperf results line with more than one unrecognized
     key only once in the unrecognized lines.
160
161
   - Make "consensus-methods" line optional in network statuses votes,
     which would mean that only method 1 is supported.
162
163
   - Stop reporting "-----END .*-----" lines in directory key
     certificates as unrecognized.
Karsten Loesing's avatar
Karsten Loesing committed
164
   - Add code used for benchmarking.
165

166

Karsten Loesing's avatar
Karsten Loesing committed
167
# Changes in version 1.1.0 - 2015-12-28
168
169

 * Medium changes
170
171
172
173
174
175
   - Parse flag thresholds in bridge network statuses, and parse the
     "ignoring-advertised-bws" flag threshold in relay network status
     votes.
   - Support parsing of .xz-compressed tarballs using Apache Commons
     Compress and XZ for Java.  Applications only need to add XZ for
     Java as dependency if they want to parse .xz-compressed tarballs.
iwakeh's avatar
iwakeh committed
176
177
178
179
180
   - Introduce a new ExitList.Entry type for exit list entries instead
     of the ExitListEntry type which is now deprecated.  The main
     difference between the two is that ExitList.Entry can hold more
     than one exit address and scan time which were previously parsed
     as multiple ExitListEntry instances.
181
182
183
184
185
186
   - Introduce four new types to distinguish between relay and bridge
     descriptors: RelayServerDescriptor, RelayExtraInfoDescriptor,
     BridgeServerDescriptor, and BridgeExtraInfoDescriptor.  The
     existing types, ServerDescriptor and ExtraInfoDescriptor, are
     still usable and will not be deprecated, because applications may
     not care whether a relay or a bridge published a descriptor.
187
188
189
190
191
   - Support Ed25519 certificates, Ed25519 master keys, SHA-256
     digests, and Ed25519 signatures thereof in server descriptors and
     extra-info descriptors, and support Ed25519 master keys in votes.
   - Include RSA-1024 signatures of SHA-1 digests of extra-info
     descriptors, which were parsed and discarded before.
192
   - Support hidden-service statistics in extra-info descriptors.
193
194
   - Support onion-key and ntor-onion-key cross certificates in server
     descriptors.
195

196
197
198
199
 * Minor changes
   - Start using Java 7 features like the diamond operator and switch
     on String, and use StringBuilder correctly in many places.

200

Karsten Loesing's avatar
Karsten Loesing committed
201
# Changes in version 1.0.0 - 2015-12-05
Karsten Loesing's avatar
Karsten Loesing committed
202
203

 * Major changes
204
205
   - This is the initial release after four years of development.
     Happy 4th birthday!
Karsten Loesing's avatar
Karsten Loesing committed
206