forked from ginhom/dnscrypt-proxy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
NEWS
340 lines (303 loc) · 14.7 KB
/
NEWS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
* Version 1.9.5
- The cache plugin didn't properly move cached entries between the
recent and frequent lists, resulting is suboptimal performance and
memory not being properly freed. This has been fixed.
- Many updates were made to the default list of resolvers.
- The forwarding plugin can now recover after all name servers have
temporarily been unreachable.
- Compatibility with older versions of MacOS has been restored.
- Official precompiled packages for Linux are now available.
* Version 1.9.4
- The default installation script in version 1.9.3 unconditionally replaced
the configuration file with the example one. This has been fixed.
- The resolver name can be set to `random` in order to pick a random resolver.
- Paths are not hardcoded any more in the sample systemd and plist files.
- The `dnscrypt-update-resolvers.sh` and `resolvers-check.sh` scripts have been
moved to the contrib/ directory.
- An `IPV4_ONLY` environment variable can be set to skip IPv6-only entries in
`resolvers-check.sh`.
- Precompiled iOS/Android/Windows packages have become more consistent, and
now include basic documentation.
- Tests are now run using random resolvers.
* Version 1.9.3
- This version can be compiled on Linux distributions using the musl C
library.
- Version 1.9.3 also restores compatibility with ancient Linux kernels that
didn't support `SO_REUSEPORT`, without having to explicitly compile the package
with `NO_REUSEPORT`.
- On Linux, the service now prints when the system doesn't have enough entropy
to initialize the PRNG.
* Version 1.9.2
- Compatibility with ancient libsodium versions (1.0.0, as still shipped
in Debian Jessie) has been restored.
- With newer libsodium versions, the XChaCha20-Poly1305 can now actually
be used on servers supporting this construction.
- The configuration file can now recursively include other configuration
files, with the `Include` keyword.
- Error messages were improved.
- The generate-domains-blacklist.py script now supports whitelists in
addition to blacklists, and provides more example feeds.
- The blocking plugin sometimes didn't match overlapping rules. This should
have been fixed for good.
- The `IgnoreTimestamps` and `LogLevel` options can now be controlled using
Windows registry keys.
- Log error messages whose level is lower than `LOG_NOTICE` now go to
`stderr` instead of `stdout`.
- On Linux, a BPF filter is attached to the client-side UDP socket in order
to drop invalid DNS queries right away.
- The `NO_REUSEPORT` preprocessor macro can be defined in order to avoid
enabling `SO_REUSEPORT` on older linux-sunxi kernels.
- The package can be compiled on Debian 6.
- `--version` now reports useful information about the way the server was
compiled.
* Version 1.9.1
- The blocking plugin introduced in version 1.9.0 didn't properly
handle overlapping rules. This has been fixed.
- The documentation and examples were updated.
- The minimum time to keep a record in cache can be specified in the
cache plugin, with the `--min-ttl` option.
- The example generate-domains-blacklist.py script produces a more
optimized list, without overlapping names.
* Version 1.9.0
- Support for TCP was added to the `hostip` tool.
- New plugin: `example-ldns-forwarding`. This plugin forwards queries for
a specific set of domain names to one or more non-DNSCrypt resolvers.
This can be used to send queries for private domains to the router or
to an internal DNS server.
- New plugin: `example-cache`. This plugin implements a simple,
zero-configuration DNS response cache.
- The default plugin paths, as loaded via the configuration file, use
the native module file names instead of libtool's `.la` files. Installing the
`.la` files has now become optional.
- Many changes and simplifications were made to the documentation.
- `-Z` (syslog prefix) doesn't imply `-S` any more.
- The `ResolverAddress` option can now be used even if a full
configuration was provided via `ResolverName` in order to override the
resolver IP and port.
- A new `contrib` folder is born, and currently contains a Python
script to automatically generate a malware/spam/ads/tracker blacklist
from public lists. More contributions would be more than welcome!
- Example startup scripts now use the configuration file.
- A `SIGHUP` signal sent to the proxy now reloads all the plugins.
This can be used after a plugin configuration update, or to rotate the log
files.
- `--ignore-timestamps` didn't work as expected. This has been fixed,
thanks to Toni Uhlig.
- `make install` does not overwrite an existing `dnscrypt-proxy.conf`
file any more. An up-to-date example is installed as
`dnscrypt-proxy.conf.example`.
- The query log and the logfile of hits for blacklisted domains/IPs
are now more detailed and more readable. As an alternative to human-readable
records, prefixing a log file name with "ltsv:" causes the log entries to use
the LTSV structured format. These logs can thus be easily sent to
Flowgger/ElasticSearch for visualization and reporting.
- The domain/ip blocking plugin was completely rewritten, and is now
extremely fast even with very lasrge blacklists of names and IP addresses.
It can now be used to locally block malware/spam/ads/trackers and other
unwanted content, based on prefixes, suffixes and keywords.
* Version 1.8.1
- Version 1.8.0 didn't use the same Windows registry key as past
versions. This has been fixed. In order to upgrade from 1.8.0,
it is recommended to uninstall the service before upgrading
(using the `dnscrypt-proxy --uninstall` command).
- The SDK used to build Android binaries was downgraded in order to
retain compatibility with Android 4.1 (Jelly Bean).
* Version 1.8.0:
- All the features of the proxy can now be enabled using a
configuration file.
- On Windows, a new option, `--service-name` can be used to set the
service name, so that multiple instances can run simultaneously.
- On Windows, `--install-with-config-file` can be used to install a
service using a configuration file.
- The protocol can now use the XChaCha20 cipher as a faster alternative
to XSalsa20.
- Time stamps are now being added to log files, including log files
from plugins.
- `SIGINT` & `SIGTERM` handlers have been added to give plugins a chance
to call a teardown function.
- A message is now displayed when servers are using a very long key
rotation period.
- The domain blocking plugin is now a `pre_filter`: blocked queries are
not sent to upstream resolvers any more [breaking change for logging
resolvers].
- The domain blocking plugin do not consider empty files an error any
more.
- The domain blocking plugin has a new option (`--logfile`) to log
queries sent to blacklisted IPs and names.
- Android's update-binary file is not part of the source distribution
any more.
- libevent2 has been updated.
- The resolvers list was updated to the latest version.
- iOS builds now require iOS 6.0.0.
- Windows builds now link ldns against LibreSSL.
* Version 1.7.0:
- Plugins are now enabled by default.
- Windows: new registry key: `LogFile`.
- New command-line option: `--ignore-timestamps` to ignore timestamps
when performing certificate validation.
- New command-line option: `--syslog-prefix` to add a prefix to log
messages.
- Certificates can now be retrieved using TCP.
- Libevent was updated to version 2.0.23.
- Certificates serial numbers are printed as a string if possible.
- The list of known public resolvers was updated.
- Builds for Win64 are now available.
* Version 1.6.1:
- Security: malformed packets could cause the OpenDNS deviceid,
OpenDNS set-client-ip, blocking and AAAA blocking plugins to use
uninitialized pointers, leading to a denial of service or possibly
code execution. The vulnerable code is present since dnscrypt-proxy
1.1.0. OpenDNS users and people using dnscrypt-proxy in order to block
domain names and IP addresses should upgrade as soon as possible.
* Version 1.6.0:
- New feature: public-key based client authentication (-K), for
private and commercial DNS services to securely authenticate the
sender of a query no matter what the source IP address is, without
altering the DNS query.
- On Windows, paths are now relative to the application folder. Which
means that the -L option is usually not required any more if the CSV
file is in the same folder as the dnscrypt-proxy executable. Full
paths to plugins are not required any more either; plugin names can be
given directly.
* Version 1.5.0:
- New option: -E, to use an ephemeral key pair for each query.
- Logging to files is supported on Windows.
- TCP FASTOPEN is now enabled on Linux.
* Version 1.4.3:
- libevent update, including a fix for CVE-2014-6272
- Two new public dnscrypt resolvers were added: opennic-us-wa-ns1 and
dnscrypt.org-fr.
- d0wn servers in France IP have changed.
- Compilation fixes.
* Version 1.4.2:
- New compilation switch: --with-systemd, to enable socket activation
support when using systemd.
- The list of public DNSCrypt-enabled resolvers was updated.
- Libevent2 updates.
* Version 1.4.1:
- Alternative ports to dnscrypt.eu servers have been added
- Android build scripts are now part of the package
- UDP queries timing out are not retried any more. This caused some issues
and was already better handled by stub resolvers and caching name servers.
* Version 1.4.0:
- Security: versions 0.11 to 1.3.3 were vulnerable to a denial of
service when running out of output buffer space. Reported by @iamultra.
- Windows: --uninstall now actually stops the service
- Windows: registry keys are automatically created for a given
provider when installing the service.
- The resolver to use and its configuration can now be specified as a
definition file + the name of the resolver to use. The new
command-line options to use are --resolvers-list=<csv file> (optional
on non-Windows platforms) and --resolver-name=<name>. This deprecates
--provider-key, --provider-name and --resolver-address.
- Documentation and diagnostics have been improved.
* Version 1.3.3:
- Try to send questions as big as the response can be. Upgrading is
highly recommended, as the server can refuse to respond to queries using
UDP if the response is larger than the question.
* Version 1.3.2:
- faster startup on iOS and Android
- New command-line switch: --test, in order to check if a certificate can be
used, with an optional time safety margin.
- The package now includes an AppArmor profile, thanks to InsanityBit.
- Plugins using ldns can now be compiled on Windows.
* Version 1.3.1:
- dnscrypt-proxy doesn't ship its own, possibly outdated copy of libsodium
any more, and always picks the system one instead.
- Minor compilation improvements for iOS, Android and FreeBSD.
* Version 1.3.0:
- The bundled NaCl library with only reference implementations has been
replaced with libsodium, leading to significant performance improvements.
- A new command-line switch, --loglevel, allows adjusting the log verbosity.
* Version 1.2.1:
- Add support for certificates split into multiple TXT records.
Contributed by Yecheng Fu, thanks!
* Version 1.2.0:
- A pre-filter can now totally bypass the resolver and directly send a
reply to the client.
- A new example plugin has been shipped: ldns-aaaa-blocking. It
directly sends an empty response to AAAA queries in order to
significantly speed up lookups on hosts without IPv6 connectivity
(but with clients still asking for AAAA records anyway).
- Example plugins requiring ldns can be compiled on Windows.
- Paths with a drive name are now recognized as absolute paths on
Windows.
* Version 1.1.0:
- dnscrypt-proxy can now use plugins in order to alter/inspect
queries and responses before and after they are relayed.
See README-PLUGINS.markdown for more information.
- The default max payload size has been trimmed down to 1252 bytes
for compatibility with some scary network setups.
- The --local-port and --resolver-port options are gone for good.
They had been deprecated for a while and were undocumented since
version 1.0.
- Multiple certificates are now properly handled.
- Memory leaks have been fixed, a big bad use-after-free condition
has been fixed, uninitialized variables have been initialized.
Upgrading is recommended, especially on Windows.
* Version 1.0.1:
- dnscrypt-proxy and hostip can now be compiled for Android and
Solaris.
- The proxy can now run as a Windows service. The new --install and
--uninstall command-line switches can automatically register the proxy
as a service. Startup options are read from the Windows registry.
See the README-WINDOWS.markdown file for details.
* Version 1.0:
- Autotools scripts have been improved.
- 1.0.
* Version 0.12:
- Datagrams are resent after running out of memory, or if the queue
was full.
- Missing compilation flags broke 0.11 on some Linux distributions.
This has been fixed.
* Version 0.11:
- A new tool, hostip, can resolve host names before dnscrypt-proxy is
started. This should help resolving chicken-and-egg problems on
routers, as reported by LanceThePants.
- The --local-port and --resolver-port options have been deprecated.
Please use --local-address=<ip>:<port> and
--resolver-address=<ip>:<port> instead.
- Improved stability on Win32.
* Version 0.10.1:
- The daemon didn't start on some Linux distributions lacking the
RANDOM_UUID sysctl. This has been fixed.
- The config.guess files have been patched in order to run out of the
box on Bitrig.
* Version 0.10:
- Almost a complete rewrite, with libuv being replaced by libevent.
- The max number of simultaneous queries is now global, not
per-protocol.
- As an insane amount of routers and ISPs are hijacking port 53, the default
server port is now 443.
- iOS binaries are now smaller.
- More dtrace probes.
* Version 0.9.5:
- Full IPv6 support.
* Version 0.9.4:
- The --tcp-port option is gone. The resolver port can now be set
with --resolver-port= and forcing use of TCP can be achieved with
--tcp-only.
- portage files for Gentoo have been added.
- Libuv has been updated.
* Version 0.9.3:
- Support for native Windows builds.
- --daemonize has been fixed.
* Version 0.9.2:
- Support for cross-compilation. In particular, the proxy can now
compile and work on iOS.
* Version 0.9.1:
- DNSCrypt should compile out of the box on DD-WRT and other
uclibc-based systems.
* Version 0.9:
- libuv has been updated.
- Enhanced compatibility with non-Intel architectures.
* Version 0.8:
- Support for Windows (through Cygwin, for now) has been improved.
- Documentation has been improved.
- The package now compiles on Dragonfly BSD-current.
- Signatures are now using ed25519 instead of edwards25519sha512batch.
- The proxy now compiles on Openwall Linux.
- Libuv has been updated.
- A sample .plist file and a Homebrew formula for OSX are now provided.
* Version 0.7:
- Initial public release.