ChangeLog 261 KB
Newer Older
1
2
3
4
5
6
7
8
971.	[bug]		marcin
	DHCPv6 server extends the lifetime of the client's lease
	in the database when the client sends the Request message.
	This prevents premature lease expiration before the client
	renews the lease, according to the timers and lifetimes
	returned by the server.
	(Trac #3913, git 1d64829a3f1a8288dc833ed388d9ffc9fe4cf491)

9
10
970.	[bug]		fdupont
	Refactored some code to suppress cppcheck warnings.
Francis Dupont's avatar
Francis Dupont committed
11
	(Trac #3919, git 26be6ac4cefde012ca8ef12607b6beaadca13eed)
12

13
14
15
16
17
18
19
969.	[func]		tomek
	KEA_SOCKET_TEST_DIR environment variable can be used to specify
	the directory for opening Unix sockets during tests. That may
	be used to avoid path length limitations when running unit-tests
	in deeply nested directories.
	(Trac #3918, git 9cfd502e8d4605eaf34f8744f90272dc3e8a3e34)

20
21
22
23
968.	[func]		fdupont
	Changed all occurrences of unlink() to the more portable remove()
	to avoid problems on operating systems where the former is not
	available.
Francis Dupont's avatar
Francis Dupont committed
24
	(Trac #3841, git 3752529ed3d72137f6899ef8225a0b231db5b1f0)
25

Tomek Mrugalski's avatar
Tomek Mrugalski committed
26
27
28
29
30
967.	[doc]		tomek
	Management API section added in the DHCPv6 chapter of the Kea
	User's Guide
	(Trac #3917, git 21305d2da26090e3fad1ff9fb242a2bbb6b7e56b)

31
32
966.	[func]		fdupont
	Include database software details in extended version information.
Francis Dupont's avatar
Francis Dupont committed
33
	(Trac #3882, git b0e166c4d8b0383ebd6e2f51d55eed68a2bcafa8)
34

35
965.	[func]		sar
36
	Per IPv6 subnet statistics (subnet[id].assigned-nas,
37
38
	subnet[id].total-nas, subnet[id].assigned-pds, and
	subnet[id].total-pds) has been implemented.
39
	(Trac #3799, git 4aa4808268bbc54290578f60ba60ed33cf344712)
40

Tomek Mrugalski's avatar
Tomek Mrugalski committed
41
42
43
44
45
46
47
964.	[doc]		tomek
	User's Guide and Developer's Guide updated with statistics and
	control channel description.
	(Trac #3800, git 7ce8ca560370ec5f9bd4d5199a177b441f08a47e)

963.    [func]		tmark
	DHCPv6 server now supports a control channel, implemented over
48
49
50
51
52
	a UNIX socket. Currently supported commands are: statistic-get,
	statistic-reset, statistic-remove, statistic-get-all,
	statistic-reset-all, statistic-remove-all, and shutdown.
	(Trac #3797, git f49828612d9030c9f3441acaf4b3a9f60b492a3e)

53
54
55
56
962.	[func]		fdupont
	Make the parsing of options and vendor options more consistent
	between v4 and v6. In addition make the parsing more robust
	against malformed packets.
Francis Dupont's avatar
Francis Dupont committed
57
	(Trac #3618, git f4066793c5e034386c689fd72d2a91a70ffb6d5f)
58

59
60
61
62
961.	[func]		fdupont
	Improved error messages when handling invalid or malformed
	configuration file. File and line number are printed, when
	available.
Francis Dupont's avatar
Francis Dupont committed
63
	(Trac #3697, git 70fc36e164e988c251bdaaee7e27c5f6407e0f4c)
64

65
960.	[build]		fdupont
Francis Dupont's avatar
Francis Dupont committed
66
67
	Get rid of the last bundy pieces of code.
	(Trac #3732, git 6b7da42f902fabb6855e54a19ea472c18ba82a93)
68

Francis Dupont's avatar
Francis Dupont committed
69
70
71
72
959.	[build]		fdupont
	Removed no longer used logging in cc and config libraries.
	(Trac #3732, git 8d0324f4786900db953489ebaa9e018b1238543f)

73
74
75
76
77
958.	[func]		tomek
	DHCPv4 server now supports control channel, implemented over UNIX
	socket. Currently supported commands are: statistic-get,
	statistic-reset, statistic-remove, statistic-get-all,
	statistic-reset-all, statistic-remove-all, shutdown.
Tomek Mrugalski's avatar
Tomek Mrugalski committed
78
	(Trac #3880, git 688658395518f0b97d5384af81ceab5206691ad5)
79

Tomek Mrugalski's avatar
Tomek Mrugalski committed
80
81
82
83
84
957.	[func]		tomek
	Per IPv4 subnet statistics (subnet[id].assigned-addresses and
	subnet[id].total-addresses) has been implemented.
	(Trac #3798, git bab2030f56bbf390959f9f9238a8acc62d583c70)

85
86
87
88
89
956.	[func]		marcin
	Improved log messages emitted by the allocation engine,
	which now uses a dedicated logger.
	(Trac #3852, git 923928774f4f59c887d768cf155b5978e838a6f2)

90
91
92
93
94
95
96
955.	[func]		tmark
	Added unit tests to kea-admin for testing the lease-dump command
	with a PostgreSQL backend. Updated PostgreSQL database installation
	instructions in Kea Administrator's guide to include use of kea-admin
	tool.
	(Trac #3884, git 0772b7df2a89e1019141be1d0ddec30d53c4b919)

97
98
99
100
101
102
103
954.	[func]		fdupont
	Enhance the versioning information printed by the executables and
	make it more consistent across all of the executables. "-v" is for
	basic Kea version information, "-V" provides more detailed
	versioning and versions for external dynamic libraries, finally
	"-W" provides the configure report from the configuration step
	during the build of Kea.
Francis Dupont's avatar
Francis Dupont committed
104
	(Trac #3513, git 584cf666e101c6cb5c9af76175ddd867ece85764)
Francis Dupont's avatar
Francis Dupont committed
105
	(Trac #3859, git 384e6c6225de18fc97d606e4a1972baeef598ba4)
106

107
108
109
953.	[bug]		fdupont
	Corrected the setting of string characters to values above 127
	in HMAC tests.
Francis Dupont's avatar
Francis Dupont committed
110
	(Trac #3829, git 54f4ec64e513fea1547631122dc1af8579fae3db)
111

112
113
114
115
952.	[bug]		fdupont
	Made some loop indexes an unsigned type to avoid compiler warnings
	where the termination condition is comparison with an unsigned
	value.
Francis Dupont's avatar
Francis Dupont committed
116
	(Trac #3833, git 3db9f1d78f59856b982a1ff84c3b5a1ba7ea39df)
117

118
119
951.	[build]		fdupont
	Removed BUNDY configuration backend.
120
	(Trac #3732, git 96364cbbb15318c8f55d5b287cda0990d3eaae32)
121

122
123
124
125
126
127
950.	[doc]		marcin
	Updated section about logging in the User Guide. Also,
	updated Hooks Developer's Guide with the recommendations for
	the developers about use of logging in hooks libraries.
	(Trac #3805, git b403de1f335a2fb5098c9abc0858b8137892f868)

128
129
130
131
132
133
949.	[func]		tmark
	kea-admin now supports dumping MySQL and PostgreSQL lease tables
	to CSV file, via a new command "lease-dump".  This is primarily
	intended for use as a diagnostic tool.
	(Trac #3802, git 6ec774e8523e7f8415d6cd18c34062489e127847)

134
135
136
948.	[bug]		fdupont
	libdhcpsrv: check if new host reservation tries to use an already
	reserved address.
Francis Dupont's avatar
Francis Dupont committed
137
	(Trac #3652, git 4f10b78341b197bd321fbf2ec71db7420e40718d)
138

139
140
141
142
947.	[func]		marcin
	DHCPv6 server now supports Rapid Commit option.
	(Trac #3070, git a6b6156aaa95ab74c69a537e90483f82e9fbe4a2)

143
144
145
146
147
946.	[doc]		tmark
	Added doucmentation for kea-admin "lease-dump" command to the
	Kea Admininstrator's Guide and kea-admin man page.
	(Trac #3803, git 54b59b7ef02f6428405794066ea779e9bd4c0b6e)

148
149
150
151
152
153
154
945.	[func]		marcin
	Improved log messages emitted by the DHCPv6 server. Also,
	the server is now using multiple distinct loggers for logging
	messages pertaining to different functional parts of the
	code, e.g. packet transmission, lease allocation, DDNS etc.
	(Trac #3807, git c95ebdaf39c3d8d78d83d53db15824c60078f566)

155
156
157
158
159
944.    [func]      tmark
	kea-admin commands lease-init, lease-version, and lease-upgrade
	now support PostgreSQL. Note that at this time the PostgreSQL
	backend only supports Kea schema version 1.0, so there are no
	upgrades available.
160
	(Trac #3883, git 990a0d72fa247e4a12e2608994204c48274e4cd6)
161

162
943.	[func]		sar
163
164
165
166
	Split the DHCP-DDNS logging messages amongst several loggers to
	allow the administrator finer control over debugging messages.
	Messages pertaining to the name change requests processing include
	an ID, currently the DHCID, to identify the transactions.
167
	(Trac #3808, git 4fbe08234049de6ef67bb5cdb244d180a7a4c3a9)
168

Tomek Mrugalski's avatar
Tomek Mrugalski committed
169
170
171
172
173
942.	[func]		tomek
	18 new statistics added in DHCPv4 server: generic packet counters,
	per packet type counters, parsing failure and packet drops.
	(Trac #3794, git a61f40c44910a09699a9a566a5ec35ab758564ba)

174
175
176
177
178
941.	[bug]		marcin
	Configuration parser for host reservations returns an error
	when an unsupported parameter is specified.
	(Trac 3810, git 54ee0f6328a303c366dd8239e768dfc4a23a5d9b)

179
180
181
940.	[bug]		fdupont
	DHCPv4 server drops DHCPRELEASE messages sent from a bad
	location (i.e., no subnet can be selected)
Francis Dupont's avatar
Francis Dupont committed
182
	(Trac 3504, git f0f13ac74779f76ed7af91bd5dab3d11ba00be79)
183

184
185
186
187
939.	[bug]		fdupont
	Small fix in HooksDhcpv4SrvTest.subnet4SelectSimple unit-test.
	(Trac 3881, git a21afdffec41fceb61e6760d4108d670b2eabe75)

188
189
190
938.	[build]		fdupont
	Removed Python from the log library (code, message compiler and
	documentation)
Francis Dupont's avatar
Francis Dupont committed
191
	(Trac #3734, git d24b7c9716c6eb7a3e9dd2cb3fd2d1bfe4e1201f)
192

193
194
195
937.	[bug]		fdupont
	The log ID LOG_UNRECOGNISED_DIRECTIVE was changed to
	LOG_UNRECOGNIZED_DIRECTIVE to follow US English spelling.
Francis Dupont's avatar
Francis Dupont committed
196
	(Trac #3762, git 235e3304746352e9341008225f9f2392586a9f66)
197

198
199
200
201
202
936.	[bug]		fdupont
	Added an ASSERT to avoid a crash in HooksDhcpv4SrvTest
	subnet4SelectSimple unit test. Fixed out of bounds vector accesses
	in perfdhcp (which should not be able to handle links
	with long (i.e., more than 6 bytes) link-layer addresses).
Francis Dupont's avatar
Francis Dupont committed
203
	(Trac #3868, git c20f47e19d6060605c0611754db7b66b08553caa)
204

205
206
935.	[bug]		fdupont
	Fixed 3 out of bounds accesses on vectors in DHCP++ code.
Francis Dupont's avatar
Francis Dupont committed
207
	(Trac #3854, git de263ad0008f3494a85592f78db1ec662b68e689)
208

209
210
211
212
934.	[bug]		fdupont
	Renamed the DHCP-DDNS constant INVALID_SOCKET to SOCKET_NOT_VALID
	to avoid conflicting with a constant of that name defined on some
	operating systems.
Francis Dupont's avatar
Francis Dupont committed
213
	(Trac #3861, git 28205225ceed03ff3126e43cd06cedbaa7d8d657)
214

215
216
217
218
219
220
221
222
933.	[func]*		marcin
	DHCPv4 server by default identifies a client using the
	client-identifier, if present. The new configuration
	parameter 'match-client-id' allows for disabling this
	behavior, i.e. 'chaddr' field is used to identify the
	client instead.
	(Trac #3747, git b9dc6ffd0f3396e9da8e0c83fd82164b8b8af011)

223
224
225
226
227
228
932.	[func]		kalmus
	MySQL schema has been extended with tables that can store
	host reservation. This ticket updates database schema only,
	the tables are not in use yet.
	(Trac #3567, git d2cd5d53b3f31422a342c9bb8946dad9ed1ea032)

229
230
231
232
233
234
235
236
931.	[func]		marcin
	Improved log messages emitted by the DHCPv4 server. Also,
	the server is now using multiple distinct loggers for logging
	messages pertaining to different functional parts of the
	code, e.g. packet transmission, lease allocation, DDNS etc.
	For complete list of logger names see User Guide.
	(Trac #3806, git 7b148c2dd5e2696a541883223ce1efd2de81f143)

237
238
239
240
241
242
243
930.	[func]		tomek
	Statistics Manager is now implemented. There is a new library
	libkea-stats that governs statistics collection. Its usage will
	be added in the upcoming tickets.
	(Trac #3793, git 68e9554ecabfc2a79731eeec1c706522e4d39332)

929.	[build]		fdupont
244
245
246
	Corrected problem in build system whereby specifying an
	installation directory on the "configure" command line that
	included a "+" in the name caused the build to fail.
Francis Dupont's avatar
Francis Dupont committed
247
	(Trac #3713, git 741ff09b743307bad28ae13db440e5e0f402d319)
248

249
250
251
928.	[build]		fdupont
	A CONFIG_H_WAS_INCLUDED define has been added to provide
	a way in source files to check whether config.h has been included.
Francis Dupont's avatar
Francis Dupont committed
252
	(Trac #3812, git cbb135d5f217b0692dcdbc9cfcc04f6a0dbc3922)
253

254
927.	[bug]		tmark
255
	DHCPv4 no longer attempts to update the lease database with the
256
257
258
	generated FQDN when processing DHCPDISCOVERs.
	(Trac #3779, git 0b413ee8aba1afa1643b216a1e8c35103c6c975b)

259
260
261
262
926.	[bug]		marcin
	Fixed the crash during the logging deinitialization.
	(Trac #3823, git 435b958860ec7b921645bd5923fff96ea4341f19)

263
264
265
266
267
268
925.	[func]		marcin
	libkea-hooks logs when the callouts execution begins or ends
	for the particular hook. It also logs the execution time of
	individual callouts and the total time for all callouts.
	(Trac #3804 git dd1432d7807e7d3b54c87dd4b3155d3110619fbd)

269
270
271
272
273
924.	[bug]		marcin
	Removed shell warning about the "missing format character"
	in the keactrl usage.
	(Trac #3784, git aa683395a4cd75af5340eb8603fe46b7b0dd8f4e)

274
275
923.	[func]		tmark
	The DHCPv4 server now logs packets it has either dropped as invalid
276
	or to which it has replied with a NAK to a separate logger,
277
278
279
	"kea_dhcp4.bad_packet".
	(Trac #3743, git cb91ca851099423e1b6c39cca3f3e2ba29795a51)

280
281
282
922.	[build]		fdupont
	The config.h file should never be included by another include file.
	Copy missing header files to the install directory.
283
	(Trac #3782, git ea6e9d166faa54b1f9781bc56d7d8fee6c87b1f9)
284

285
286
921.	[func]		marcin
	libdhcpsrv: Added log traces to the host manager.
287
	(Trac #3699, git 75b75c89db88eb1a81e76f5550f2a5b3155ce42d)
288

289
290
291
292
293
920.	[bug]		marcin
	Corrected issues with logging initialization in hooks
	libraries. The dynamically loaded hooks libraries may now
	define their own loggers which are configurable using Kea
	configuration file.
294
	(Trac #3198, git 8216a6b1a2ed6e2b38919280809ee21fc4107fd6)
295

296
297
Kea 0.9.1 released on March 31, 2015

298
299
919.	[doc]		stephen
	Corrected some configuration examples in the documentation.
300
	(Trac #3772, git e9f084525bc1eec1cca635c00f33228bf7fac6a4)
301

302
303
918.	[func]		tomek,tmark
	DHCPv6 server now supports static reservations of hostnames
304
305
	for clients.  Note this resolves #3708 by reducing the number
	of calls to selectSubnet to once per client request.
306
	(Trac #3689, git c13c824d9948f7e3f71a65ed43798f3b5c14042c)
307

308
309
310
311
312
313
917.	[bug]		marcin
	DHCPv4 server may allocate lease for the client which is
	using a non-unique identifier (HW address or client id),
	if the other identifier is unique.
	(Trac #3768, git 0f7a029e2a2a7652d49a0bcd9f49e879fac9136f)

Shawn Routhier's avatar
Shawn Routhier committed
314
916.	[func]		sar
315
316
317
318
	Add a log message that indicates when the v4, v6 or
	DHCP-DDNS server has completed processing its
	configuration and is about to enter the loop to process
	messages.
319
	(Trac #3755, git c71c7836804842bae51fe79fd599c57f5b3d007d)
320

321
322
323
324
325
326
327
915.	[func]		tomek, marcin
	The DHCPv6 server now supports the Relay-Supplied Options
	option,	as defined in RFC 6422. The relay can insert options
	in the relay forward message that the server will send back
	to the client if certain criteria are met.
	(Trac #3705, git 4772ee589712f5359ecbd79ebf71fbc7bb68741b)

328
329
330
331
332
333
334
914.	[bug]		marcin
	DHCPv4 server: corrected the logging message issued when
	the server could not allocate or offer the lease for the
	client. The corrected message contains the client-id,
	hardware address, ciaddr and requested-ip-address.
	(Trac #3737, git 4c56e1348c5d50eaa5b3083a0a8c346966e1b603)

335
913.	[bug]		sar
Shawn Routhier's avatar
Shawn Routhier committed
336
337
	Handle recovery properly should the LFC crash while
	manipulating files after completing processing.
338
	(Trac #3759, git bb3b4d14119392261a1766da2b406fa46d4c0f21)
Shawn Routhier's avatar
Shawn Routhier committed
339

340
912.	[doc]		sar
341
342
	Added sections on LFC to the administrators and developers
	guides.
343
	(Trac #3720, git 828b801e6a4616de331588076ab9c4c35677595)
344

345
346
347
348
349
350
351
911.	[func]*		marcin
	libdhcp++: the C++ objects representing network interfaces
	(Iface objects) are now non-copyable. As a result, the API
	of the Interface Manager functions returning the pointers
	to the Iface objects has changed.
	(Trac #3715, git 7415c74e38e13385a75e7200cb23b7d6ca86df7f)

352
353
354
355
356
910.	[func]		marcin
	DHCPv4 server supports static reservations of the hostnames
	for the clients.
	(Trac #3688, git b5c50e2aff64da05b439da8d5fa4913fc8a704ca)

357
358
359
360
361
909.	[bug]		marcin
	Removed many cppcheck errors in the code. Also removed the
	dhcp-ubench test tool.
	(Trac #3736, git 552aea126e968b78292ae80c1c6a03c9ef4dcdcd)

362
363
364
365
366
908.	[bug]		marcin
	Handle overflows during time conversions in the MySQL and
	PostgreSQL lease database backends.
	(Trac #3673, git 27b4e4590fdee507f0e877d7b771dc6c6457a4b5)

367
368
369
370
371
372
373
907.	[doc]		tmark
	Corrected depictions of kea-admin command line options for
	database-name in Kea Administrator Reference. Prior to this
	the document showed "-d" as the database name option, when
	in fact it is "-n".
	(Trac #3742, git ec427e4c9d008abc800f87eda3c0024b35e4c2e2)

374
375
376
906.	[doc]		tmark
	Added description of a restriction on extracting a MAC
	address from an IPv6 link-local address to the Kea
377
	Administrator Reference, section 8.8, item "ipv6-link-local".
378
	(Trac #3691, git ca9f5541cb36f815ac614c5c21088d545eafcac6)
379

380
381
382
383
384
905.	[func]		marcin
	DHCPv4 server assigns an address from the dynamic address
	pool if the reserved address is in use by another client.
	(Trac #3694, git 95b09ff53b941691cba172c933de0682b05a0d85)

385
386
387
388
389
390
391
392
393
904.	[bug]		marcin
	FreeBSD-only change: Disabled unit test expecting the death
	of the process when conditional variable was destroyed when
	the thread was still waiting for the variable. This is due
	invalid behavior of the pthread_cond_destroy on FreeBSD
	which should return EBUSY in such case, whereas it returns
	success error code.
	(Trac #3710, git bdb442402ef023055715baf597c401c9974a7fb2)

394
395
396
397
398
399
903.	[bug]		stephen
	Corrected arithmetical error in the rate control module of
	perfdhcp which led to the incorrect calculation of the rate
	at which packets should be sent.
	(Trac #3729, git bb5bca3d9b68abc4b83abdd204bfb075dda630ac)

400
401
402
403
404
405
902.	[bug]		marcin
	Fixed the bug in the DHCPv4 server whereby the server
	reconfiguration (using the SIGHUP signal) failed because
	of sockets remaining open since the previous configuration.
	(Trac #3730, git 3ceb0cd97cf5e44e8fc151d0a38db553530dd3ed)

406
407
Kea 0.9.1beta released on February 18, 2015

408
409
410
411
412
413
414
901.	[bug]		tomek
	Previously, the DHCPv4 and DHCPv6 servers gave up after
	100 failed lease selection attempts. Now both DHCPv4 and
	DHCPv6 servers calculate the number of attempts required
	to find a lease using the pool capacity.
	(Trac #3711, git cb5533a1bf1023faf61c1b8ade6ac8fa425f46c2)

415
416
417
418
419
900.	[doc]		marcin
	Documented configuration of the Lease File Cleanup (LFC) in
	the Kea Administrator Reference.
	(Trac #3672, git da3c676f009785204f9d84ca008890959bffcc18)

Tomek Mrugalski's avatar
Tomek Mrugalski committed
420
421
422
423
424
425
426
427
899.	[func]		tomek
	reservation-mode parameter has been added to DHCPv6 server.
	It controls what host reservation types are allowed and may
	improve performance in certain situations. It is also
	accepted in the DHCPv4 configuration, but currently not
	used.
	(Trac #3565, git cfbe13ad05aac23e09357fc78507cf9a82c908e6)

428
429
430
898.	[func]		marcin
	The DHCPv4 server configuration allows for opening multiple
	sockets on a single interface with multiple IPv4 addresses
431
	assigned. This facilitates the use case when different relay
432
433
434
	agents send messages to different addresses on the interface.
	(Trac #3695, git 3116243706a2dbcae3f9b5b3af9d2241a07b9ab2)

435
436
437
438
897.	[bug]		fdupont
	Removed a double free of the read_buffer_ field of Iface
	objects after (spurious) copy (partial as copies are not
	yet fixed).
Francis Dupont's avatar
Francis Dupont committed
439
	(Trac #3712, git 0b38ff6a6e77eb4182bfd7c0c681bef22ad5f634)
440

441
442
443
444
445
896.	[bug]		fdupont
	Removed exit() in D2 for version command line processing.
	This interfered with how the unit-tests were run.
	(Trac #3616, git 758a61e277675e89d857a22c3f8e844de307dca6)

Tomek Mrugalski's avatar
Tomek Mrugalski committed
446
447
448
449
895.	[doc]		tomek
	Host reservation for DHCPv4 and DHCPv6 is now documented.
	(Trac #3575, git a981e42eb0f39d27795364a6862b3a5e574e540a)

450
451
452
894.	[bug]		fdupont
	Accept empty options or sub options in DHCPv4 messages unpacking
	routines.
Francis Dupont's avatar
Francis Dupont committed
453
	(Trac #3661, git 42a4854208ec16834c590a9316b9a5306c60a3bb)
454

455
456
457
458
459
893.	[func,bug]	fdupont
	Changed the qualifying-suffix parameter in the dhcp-ddns
	configuration element to be mandatory with no default value when
	updates are enabled (i.e., the enable-updates mandatory parameter
	is true).
Francis Dupont's avatar
Francis Dupont committed
460
	(Trac #3632, git 12808651448837c611e4f6a262f7a1eb3deaf8da)
461

462
892.	[func]		sar
Shawn Routhier's avatar
Shawn Routhier committed
463
464
465
466
	A class, LeaseFileStats, has been added to provide simple
	statistics for use with lease files.  Also added logging
	to the kea-lfc process per the design.
	See http://kea.isc.org/wiki/LFCDesign for the design.
467
	(Trac #3667, git 7f36e034fe79d85f317d7d07e2fe636d6cdf1f6e)
Shawn Routhier's avatar
Shawn Routhier committed
468

Tomek Mrugalski's avatar
Tomek Mrugalski committed
469
470
471
472
473
891.	[func]		tomek
	libdhcpsrv: Allocation Engine now uses statically assigned
	addresses when processing DHCPv6 renewals.
	(Trac #3677, git 9ce50790c91624937ff2b622e4afff36d5d3cc2d)

474
475
476
477
478
479
480
481
482
483
890.	[func]		marcin
	It is now possible to specify whether the DHCPv4 server
	should use raw sockets or IP/UDP datagram sockets to
	receive and send DHCP messages. The configuration format
	has been changed for the selection of interfaces on which
	the DHCPv4 and DHCPv6 servers should listen. The
	configuration files using an old format are incompatible
	with the latest version of Kea.
	(Trac #3604, git c726bbc4eae0f576f6791c7490bfba8c30a401d9)

484
485
486
487
488
489
889.	[bug]		marcin
	Resolved a bug in the DHCPv4 allocation engine whereby the
	client could request and obtain an address reserved for
	another client.
	(Trac #3690, git 1afa4e24b0fcdd6d3a2e596663ce1102ffe2340d)

490
491
492
493
494
495
888.	[func]		marcin
	DHCPv4 and DHCPv6 servers launch the kea-lfc program, according
	to the value of lfc-interval configuration parameter for the
	Memfile lease database backend.
	(Trac #3669, git c92665ce05d71e9e5cad9a0679018e9e3f7e3be5)

496
887.	[func]		sar
497
498
499
	A new process, kea-lfc, has been added. It is meant to
	be periodically executed by the DHCPv4 and DHCPv6 servers
	to remove redundant information from the lease files.
500
501
502
503
	See http://kea.isc.org/wiki/LFCDesign for the design.
	(Trac #3664, git cc85938b35e2d4bd00ccb74f1b83d3017ab0e41b)
	(Trac #3665, git b1707981f48b13895b50bf27176dede866576292)
	(Trac #3687, git 1e92382aaa2fbff08bbf1d6bbf0add195a7b6fae)
504

Tomek Mrugalski's avatar
Tomek Mrugalski committed
505
506
507
508
509
886.	[func]		tomek
	libdhcpsrv: Allocation Engine now uses statically assigned
	addresses when it allocates leases for the DHCPv6 clients.
	(Trac #3563, git b86b24fd011c0617515d62b7091d56fdfd1a7360)

Tomek Mrugalski's avatar
Tomek Mrugalski committed
510
511
512
513
885.	[func]		tomek
	Information-Request (stateless mode) in DHCPv6 is now supported.
	(Trac #2949, git 3185d229c39ed4660e9bc98a7f4a9d0dfbe64a04)

514
515
516
517
518
519
884.	[func]		marcin
	The DHCPv6 server configuration now allows for defining a pool
	for prefix delegation in which prefixes do not match a
	subnet prefix.
	(Trac #3647, git 5455d96cbf773e678bd6b1c3e31bfdeb617e6c13)

520
521
522
523
524
883.	[bug]		marcin
	libdhcpsrv: Prevent infinite loops in the allocation engine,
	when the address pool becomes exhausted.
	(Trac #3692, git f1e464558c89a6dc88ab28a25dd14a65fee62578)

525
882.	[func]		sar
526
527
528
	A utility class has been added which handles writing and
	deleting pid files as well as checking if the process with
	the given pid is running.
529
	(Trac #3687, git 1e92382aaa2fbff08bbf1d6bbf0add195a7b6fae)
530

531
532
533
534
535
536
881.	[func]		kalmus
	Extracting hardware/MAC address from the DHCPv6 remote-id
	option is now implemented.
	(Trac #3552, git 6db5fc158133b3f308c43f1fe2fa54a6f89baae1)

880.	[doc]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
537
538
539
	kea-admin is now described in Kea User's Guide.
	(Trac #3644, git fa83c48826e41663d93e56ec7fd6983e9b0b2cd1)

540
541
542
879.	[bug]		fdupont
	Drop DHCPREQUEST message from an unknown client in the
	INIT-REBOOT state.
543
	(Trac #3656, git 8e205adc35d8e72d1802d5ee9056e6c4ac78274a)
544

545
546
547
548
549
550
551
552
878.	[func]		marcin
	DHCPv4 and DHCPv6 server now support the lfc-interval
	parameter which configures the interval in which the
	Memfile lease database backend executes the Lease File
	Cleanup (LFC). Note: the LFC is currently no-op and will
	be implemented shortly.
	(Trac #3668, git 2ce54eeb607d2caa0901125b5d86a373e9e3f165)

553
554
555
556
557
558
877.	[func]           marcin
	DHCPv4 server drops unicast packets sent to the IPv4 address
	on which the server is not configured to listen.
	(Trac #3547, git 803f1f0f145b0f252ffc3637f758a47e0061de85)

876.	[func]          tomek
559
	Two new MAC acquisition methods implemented for DHCPv6:
560
561
562
563
	docsis-modem (which extracts MAC address from an option inserted
	by a cable modem) and docsis-ctms (which extracts MAC address from
	an option inserted by CMTS which acts as a DHCPv6 relay agent).
	(Trac #3553, git ad0a3772774bc5f9831a5ba16725a5a22887b8cb)
564

565
566
567
568
569
570
571
875.    [bug]           afidalgo, marcin
	The DHCPv4 server no longer appends the trailing dot to the
	hostnames sent to the clients in the Hostname option (12).
	Appending trailing dot confused some DHCPv4 clients.
	Credits to Alexis Fidalgo for submitting a patch.
	(Trac #3636, git 450867e6987f4c786ad6c2cc95cabcff601c1b48)

572
874.    [func]           marcin
573
574
575
576
577
578
	Changes to the Memfile lease database backend to load
	leases from multiple files during startup or server
	reconfiguration. This change is required by the Lease File
	Cleanup feature, which leads to the creation of additional
	files holding cleaned up lease information.
	(Trac #3671, git 667de2ef9044e97c76b15cacc7285132cdffdfcf)
579

580
581
582
583
584
585
873.    [bug]           wlodek
	Removed references to non-existing pgsql_test.sh script
	from Makefile.
	(Trac #3662, git ab69f38dd82cf3c3736588e03c1dc568de3ae6d6)

872.    [func]          wlodek
586
587
588
589
	Check for required header file errcode.h for PostgreSQL
	backend added to configure process.
	(Trac #3663, git d666dd9263ba1aaf88bec5b8e5ae3f0cb8e5c1db)

590
871.	[func]		kalmus, tomek
591
	DHCPv6 is now able to extract MAC from DUID-LLT and DUID-LL.
592
	(Trac #3548, git f6d9630e2762a0f256a2b7825d74d2bce8fe4c60)
593

594
595
596
870.	[func]		fdupont
	Cleanup the cryptolink API (e.g., removing spurious 'magic'
	zero length parameters).
Francis Dupont's avatar
Francis Dupont committed
597
	(Trac #3606, git 55d2df9d78321b3844217055e376ae44ac962d8f)
598

599
600
601
602
603
604
869.	[func]		tomek
	'mac-sources' configuration parameter added. The DHCPv6 server
	can now be configured to use various MAC/Hardware address
	sources.
	(Trac #3554, git 2e7c32e7c19372f0c97968ef7c8256509d80fdfc)

605
868.    [func]          marcin
606
607
608
609
610
	DHCPv4 server configuration allows for selection of the
	address on the interface that server should listen on.
	This is specifically useful in the environments with
	multiple IPv4 addresses assigned to one interface.
	(Trac #3539, git ff71887c605eedc3914bacfd2e551da7bddcc0d6)
611

612
613
614
615
616
617
867.	[func]		marcin
	libdhcpsrv: Allocation Engine uses statically assigned
	addresses when it allocates or renews leases for the
	DHCPv4 clients.
	(Trac #3564, git 7b192fe314c12e38622742b3b338e997934f862f)

618
866.	[doc]		stephen
619
	Corrected documentation concerning the way to configure hooks
620
621
622
	libraries.
	(Trac #3635, git 42d1c98a2e66ab7fc3e372365edad1f5709df885)

623
624
625
626
627
628
629
865.	[func]		marcin
	Host reservations can be specified in the DHCPv4 and DHCPv6
	servers configuration. The reservations are loaded, but they
	are currently unused.
	(Trac #3562, git 1ba5ec3b7831ef8126be17b9542d9b89a419e7dd)
	(Trac #3628, git 00b49298ec5e5e5c722e5938547c86c954fc76e1)

630
631
632
633
634
864.	[func]		tomek
	MySQL backend is now able to store information about hardware
	addresses and associated information in DHCPv6.
	(Trac #3556, git 08a29d8d2374bc3c6b3799d5dd97f586ee869392)

Tomek Mrugalski's avatar
Tomek Mrugalski committed
635
636
863.	[func]		tomek
	A new tool called kea-admin added. It allows database maintenance.
637
	Initialization of a new database, version check and upgrade between
Tomek Mrugalski's avatar
Tomek Mrugalski committed
638
639
640
641
	version is now supported. Currently the only backend supported is
	mysql, but support for memfile and pgsql is planned.
	(Trac #3599, git cf22f8d212f2435957f89b51722f8e26e14635f2)

642
862.	[func]		dgutier, tomek
643
644
	Support for client link-layer address option (RFC6939) has
	been added.
645
646
	(Trac #3551, git dabdf965d92085f86d5e96c8dadce0f0a8f7c8e3)

647
648
649
650
651
861.	[func]		marcin
	The configuration parameters for a DHCPv4 and DHCPv6 options are now
	optional.
	(Trac #3467, git 7bf8cef161e6dd00a7f2b2fe8ec04e1958d6db3f)

652
653
654
655
656
860.	[bug]		marcin
	Fixed calculation of the Client FQDN option length for the ASCII
	domain name encoding.
	(Trac #3624, git 5a120d9bf85e27ea5b2674d35af0f2774e4cd2a7)

657
658
659
660
661
662
663
859.	[func]		marcin
	Implemented Host Manager, which can retrieve host reservations
	specified in the server's configuration. Future tickets will
	extend Host Manager to retrieve reservations from other sources,
	e.g. SQL databases.
	(Trac #3561, git faac5e9746dbf82eb04ffef95658e4b4c7d64a4a)

664
665
666
667
668
858.	[bug]		marcin
	Added missing "lease-database" entry to the default DHCPv6
	server configuration, in kea.conf.
	(Trac #3630, git 0f7ff732ea2add45a24e040eae8a0dda27532a31)

669
670
671
857.	[func]		fdupont
	Improve the cryptolink code, for instance use a constant
	time comparison.
Francis Dupont's avatar
Francis Dupont committed
672
	(Trac #3602, git 0c1f433da650330b40fe1a67bae4716c9184f636)
673

674
675
676
677
678
856.	[build]		marcinw
	callout_manager.h and server_hooks.h headers are now exported,
	so statically linked libraries can be tested.
	(Github #4, git 00b5f3fa0369c13021bf4fb78c6450e524e4e411)

Francis Dupont's avatar
Francis Dupont committed
679
680
681
682
683
855.	[build]		fdupont
	Use convenience archives for objects used in a makefile and
	its parent makefile: before sources were compiled twice using
	the broken subdir-objects option of automake, now objects
	are put into a convenience static library (so an archive).
Francis Dupont's avatar
Francis Dupont committed
684
	(Trac #3631, git d7954b4234114d8fa41aa51f671d4faa1724b748)
Francis Dupont's avatar
Francis Dupont committed
685
686
687
688
689
690

854.	[bug]		marcin
	Corrected a regression on "make distcheck" which appeared after
	implementation of #3162 (partial fix).
	(Trac #3629, git 9bb6b76a24e4356b30e59631e76e32c3096fb515)

691
692
693
694
695
696
697
853.	[func]		tomek
	Lease6 now is able to store MAC/hardware address information. Memfile
	memfile backend has been updated to store/retrieve that additional
	piece of information. Server now tries to use available methods to
	obtain MAC/hardware address from incoming packet.
	(Trac #3555, git ab76a9e7a9d39cb3cf533729473b63a2d2401ac7)

698
699
700
701
702
852.	[func]		tomek
	Pkt6 class is now able to generate client's MAC from source IPv6
	link-local address if EUI-64 identifier was used.
	(Trac #3549, git d92e76860e6931477b3e60e5be8978302973f88f)

703
851.	[bug]		tmark
Francis Dupont's avatar
Francis Dupont committed
704
705
	Corrected a segmentation fault that was occurring under OS-X
	during D2 module shutdown.
706
707
	(Trac #3470, git f7822568abd04c12faa3cde34fadaac238a373d3)

708
709
850.	[build]		fdupont
	Moved optional gtest sources to ext/gtest.
Francis Dupont's avatar
Francis Dupont committed
710
	(Trac #3162, git 055512758f5c79f29eb375126d496483c9a6d0a1)
711

712
849.	[bug]		tomek
713
714
715
	DHCPv6 component now processes incoming vendor-class options
	properly (packets are classified as VENDOR_CLASS_[content of the
	vendor-class option]).
716
	(Trac #3486, git 62409cd9531b081943b8f3567f7b0dca36b18802)
717

718
719
848.	[func]		fdupont
	Added truncated HMAC support to TSIG, as per RFC 4635.
Francis Dupont's avatar
Francis Dupont committed
720
	(Trac #3593, git ae3a9cd1a0d2dc07b7092368149381d69bc2c61a)
721

722
847.	[build]		fdupont
Francis Dupont's avatar
Francis Dupont committed
723
	Removed no longer used configuration option --with-shared-memory
724
	and associated files and variables.
Francis Dupont's avatar
Francis Dupont committed
725
	(Trac #3614, git adee8c93f7c7c1303390dd63dbeae74a48a34845)
726

727
728
729
846.	[bug]		fdupont
	Fixed subdir-objects warnings from recent versions of autotools,
	e.g., on Apple OSX.
Francis Dupont's avatar
Francis Dupont committed
730
	(Trac #3162, git e25c7477f3c35cdaa0f038732f697224bfd44847)
731

732
733
734
735
736
845.	[func]		marcin
	Implemented Host class for storing information about IPv4 and IPv6
	reservations for the host.
	(Trac #3560, git fb5e1883b01ce6388d1b7a92c61061b493c36713)

737
738
739
740
844.	[bug]		tmark, marcin
	Fixed multiple issues in the DHCP-DDNS unit tests.
	(Trac #3615, git fec824d36121b12e98dd407a0bdf1bc71c8de18d)

741
742
743
744
745
843.	[bug]		marcin
	DHCPv4 server sets ciaddr to 0 in DHCPOFFER and DHCPNAK messages to
	adhere to section 4.3.1 of RFC2131.
	(Trac #3367, git 9f05a29caa960df2b09b7a8c23100da8b40e73d0)

746
747
748
749
750
842.	[func]		marcin
	DHCPv4 server logs when the packet sent by the client contains
	invalid combination of giaddr/hops before discarding the packet.
	(Trac #3537, git 760c652b54dcdfdfbd1a0014da43d3c31e848f02)

751
752
753
754
755
756
841.	[func]		tomek
	Pkt4 and Pkt6 class have a common base now. A lot code duplication
	removed. Added getMAC() method that will be used to extract MAC
	in DHCPv6.
	(Trac #3546, git 6e68af7dfe15e4d461bf068f545d2bdaaa8fcfb0)

757
840.	[func]		nicolas
758
759
760
761
762
	PktFilterInet::send method now sets source IPv4 address
	explicitly.  This enabled perfdhcp to control its source address
	on systems that have more than one address assigned to a given
	interface. Thanks to Nicolas Chaigneau from Capgemini for
	providing this fix.
763
764
	(Github #2, git 6ac36ed7a1d97bcf52ffb2aec7cbf116e58e5803)

765
839.	[doc]		adam
766
767
	DHCPv4 examples corrected in Kea ARM. Thanks to Adam Osuchowski
	from Silesian University of Technology for providing this fix.
768
769
	(Github #1, git 15785c0e28190659b037cfcca19f0267ccd9049f)

770
838.	[bug]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
771
772
773
	Kea components now use the KEA_LOCKFILE_DIR environment variable
	to specify the directory of the logging lockfile. Locking can be
	disabled completely by setting the variable to 'none'.
774
775
	(Trac #3591, git d4556e1d21766b94f2f0cda59df15e47e6f2676e)

776
777
778
779
780
837.	[bug,doc]	tomek
	Logging configuration examples in kea.conf fixed. Also updated
	Kea documentation for logging.
	(Trac #3536, git 2cf3f6b9cb3d2ae6fc7b0940b55490f109ddd2f9)

781
782
783
836.	[bug]		fdupont
	Moved duplicated getXXXHashAlgorithm() function to new
	xxx_common.h include files in the cryptolink library.
Francis Dupont's avatar
Francis Dupont committed
784
	(Trac #3471, git 8cf2ee46b3d7398f4f716435be3d9b19bf3599f5)
785

786
787
788
789
835.	[build]		fdupont
	The configure script checks if OpenSSL supports SHA-2, in order
	to avoid very old (and likely subject to unfixed security bugs)
	OpenSSL versions.
Francis Dupont's avatar
Francis Dupont committed
790
	(Trac #3482, git c779a0ef23d2092cf896276dab1fbcb190380374)
791

792
793
794
795
796
834.	[bug]		marcin
	Corrected the definition of the example DHCPv4 and DHCPv6 address
	pools in the default kea.conf file.
	(Trac #3538, git 8712cc0df77368940d8d3d11811a9ac9504bce12)

797
798
799
800
801
802
803
833.	[func]		marcin
	Configuration Manager supports two stage configuration. In the
	first stage a temporary configuration is created and in the
	second stage this configuration is committed. If configuration
	fails at the first stage, the temporary configuration is rolled
	back and the server continues to use the old configuration.
	(Trac #3534, git 4ecee3c0c97fe417b050317356f9093ba3771a15)
804
805
806

Kea 0.9 released on August 29, 2014

807
832.	[bug]		jiri
808
809
	Compilation fix for PostgreSQL on i686. Thanks to Jiri Popelka
	from RedHat for providing a patch!
Tomek Mrugalski's avatar
Tomek Mrugalski committed
810
	(Trac #3532, git 96a06654f2177444dcea3a0e9f6fa06947855497)
811

812
831.	[func]		marcin
813
	DHCP servers check if the interfaces specified in the configuration,
814
	to be used to receive DHCP messages, are present in the system.
815
816
817
818
819
	If the interface doesn't exist, an error is reported. In addition,
	the SO_REUSEPORT flag is set for IPv6 sockets as multiple multicast
	sockets can be bound to the DHCPv6 server port.
	(Trac #3512, git 5cbbab2d01c6e1bf6d563ba64d80bc6bc857f73d)

820
830.	[build]		jreed
Tomek Mrugalski's avatar
Tomek Mrugalski committed
821
	The configure script no longer requires pkg-config.
822
823
	(Trac #3511, git 99a5a2db8c011b358873d485ac48f7c78ac6374c)

Jeremy C. Reed's avatar
Jeremy C. Reed committed
824
829.	[build]		wlodek
825
	Lettuce DNS tests removed with all related python code,
826
	most of them will be used in Forge project which can be found
827
	http://kea.isc.org/wiki/IscForge
828
829
	(Trac #3420, git e51bcbeedbc169050751c1b896726965243667be)

830
831
832
833
834
828.	[bug]		marcin
	Corrected the IfaceMgrTest.detectIface unit test that failed on
	Linux systems with virtual interfaces present.
	(Trac #3527, git 7aa01a6965b6e9fc39ff005803cada7f58f2e628)

835
827.	[build]		jiri, tomek
836
837
	Deprecated AC_PROG_LIBTOOL macro replaced by LT_INIT. Thanks to
	Jiri Popelka from RedHat for providing a patch!
838
	(Trac #3525, git 6c0aacf29fae1d0501ca69ff6324df8d4fc8c7ee)
839

840
826.	[bug]		jiri, tomek
841
842
	Compilation fix for Red Hat running on armv7. Thanks to Jiri
	Popelka from RedHat for providing a patch!
843
844
	(Trac #3526, git eac5a80472dcb78b538c2ed34cc0534f801e5145)

845
825.	[bug]		jiri, tomek
846
847
	Example JSON configuration files permission fix. Thanks to Jiri
	Popelka	from RedHat for providing a patch!
848
849
	(Trac #3524, git 822a39ba33870f70787a1f666aed772e06d04d79)

850
851
852
853
824.	[bug]		marcin
	Kea deamons report configuration summary when the configuration is
	applied successfully.
	(Trac #3477, git f39d208024f720f72c931016cfa50a54e80f8c61)
854
855

823.	[build]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
856
	query_cmp tool removed from the source code.
857
858
	(Trac #3509, git f61c800059bd5e5c74e435d7dd97ae561d29151a)

859
822.	[build]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
860
	'host' program was removed from examples.
861
862
	(Trac #3421, git aeea893fb1c52d20258929a62a59ae2e7bd12e3d)

863
864
865
866
867
821.	[bug]		marcin
	DHCP servers no longer log an error when Interface Manager fails to
	receive a packet as a result of signal being received.
	(Trac #3478, git d80c83aef8e103dd483234429d35aeb66149e0b9)

868
869
870
871
872
820.	[bug]		marcin
	Corrected the IfaceMgrTest.detectIfaces unit test which reported
	false positives for specific network configurations.
	(Trac #3517, git 9affa1b2210f5cc9d7a99724e5d5c8979409cefd)

873
874
Kea 0.9beta1 released on August 13, 2014

875
876
877
878
879
880
881
882
819.	[build]		marcin
	Renamed variables in the configure.ac so as their names do not
	refer to BIND10 project. As a result of renaming the B10_CXXFLAGS
	to KEA_CXXFLAGS in configure.ac all dependent Makefiles had to
	be updated in the tree. The AX_BOOST_FOR_BIND10 macro has been
	renamed to AX_BOOST_FOR_KEA.
	(Trac #3507, git 6616b1c0ad0a78e11bca9395fafb8efdba8d8b9c)

883
818.	[func]		tomek
Jeremy C. Reed's avatar
Jeremy C. Reed committed
884
	DHCPv4, DHCPv6 and DDNS components now report their versions.
885
886
	(Trac #3508, git 3f46c74ffa0ea1197e1fa62cb2f6580931be35f3)

887
888
889
890
891
817.	[bug]		marcin
	DHCPv4 and DHCPv6 servers will log an error during an attempt to
	open socket on the interface which is down or not configured.
	(Trac #3487, git fadc776914aa858ce637aab1513ab3d87631f612)

Tomek Mrugalski's avatar
Tomek Mrugalski committed
892
816.	[doc]		tomek
893
	AUTHORS file rewritten.
Tomek Mrugalski's avatar
Tomek Mrugalski committed
894
	(Trac #3469, git 6ef55abaa1ef79e09ad332c0da28dee7bfed70fe)
895

896
815.	[func]		tomek
897
898
899
	Pool definitions in DHCPv4 and DHCPv6 are now lists of
	structures. This makes adding new per-pool parameters easier in
	the future.
900
901
	(Trac #3464, git 4bd0c0eda9d86608f8802d28bd360239fe88e905)

Jeremy C. Reed's avatar
Jeremy C. Reed committed
902
814.	[func,doc]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
903
904
	It is now possible to specify logging parameters in a
	configuration file for DHCPv4, DHCPv6 and DHCP-DDNS components.
905
906
	(Trac #3427, git 23285903645c36fc35c6866a74c50c74089cd255)

907
813.	[func]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
908
909
910
911
	Functions, methods and variables referring to BIND10 were renamed
	to Kea. In particular, system variables (B10_LOGGER_ROOT,
	B10_LOCKFILE_DIR_FROM_BUILD etc.) were renamed. B10_ prefix was
	replaced with KEA_.
912
913
	(Trac #3417, git 1db8988de6af435fa388dc9c7f909c4a004a01d0)

914
812.	[doc]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
915
916
	DHCPv6 and DDNS sections in Kea Administrator Reference Manual
	has been updated. Usage of keactl has been documented.
917
	(Trac #3468, git 3945fc6211bcadb9bece7147039a6b50ebcf936b)
Tomek Mrugalski's avatar
Tomek Mrugalski committed
918
919
	(Trac #3466, git fa9570d19c73cbe7effc75589b7eb855c411f6a3)

920
921
922
923
924
811.	[doc]		tmark
	Added documentation of message protocol between DHCP servers and the
	DHCP-DDNS process.
	(Trac #3505, git 6d9aed2f8fe181714e8260493c6cc06e13d0edd0)

925
810.	[func]		stephen
Jeremy C. Reed's avatar
Jeremy C. Reed committed
926
927
928
	perfdhcp is now installed in sbin as it requires root privilege
	to run. The perfdhcp source has been moved to the directory
	src/bin/perfdhcp.
929
930
	(Trac #3481, git d101aed6156a993476fa1164f0b0ec8395f5886c)

931
809.	[func]		stephen
Jeremy C. Reed's avatar
Jeremy C. Reed committed
932
933
934
	sockcreator is no longer built or installed.  The code is being
	retained in the repository for the moment, but may be deleted at
	some point in the future.
935
936
	(Trac #3480, git 2a55a469dde8fcc053b49e287c30d0906baa91b4)

937
938
939
940
941
808.	[func]		stephen
	Reduced number of startup and shutdown messages in the
	DHCP-DDNS process by making some of them debug messages.
	(Trac #3479, git bca0bae285de9ce904c0afd21af777dac2edb4e6)

942
943
944
945
807.	[func]		marcin
	DHCPv6 server responds to Confirm messages from clients.
	(Trac #3269, git 4f43c309a994e30c07f5aa27057552fb195ec284)

946
947
948
949
806.	[func]		marcin
	DHCPv4 server processes Requested IP Address option (50).
	(Trac #3320, git ad411a177a32bbe6a93f4baf813d985558c99e2f)

950
951
952
953
805.	[func]		stephen
	Changed all occurrences of "BIND 10" in message files to "Kea".
	(Trac #3416, git e88090b57a75424920d9b96efbf50e3554048828)

954
955
956
957
804.	[func]		marcin
	DHCPv4 server supports DHCPINFORM messages from the clients.
	(Trac #3390, git 77f8577b1dbb52bdc6deb8bed3eef6ce7abc33fd)

958
959
960
961
962
963
964
965
803.	[func]		marcin
	DHCPv4 server supports responding to directly connected clients on
	FreeBSD, NetBSD and OpenBSD using Berkeley Packet Filtering. This
	also resolves the problem reported in #3438 that the server doesn't
	pick the correct interface to respond to the client and the client
	never gets the response from the server.
	(Trac #2893, git 9fba39d93b9ece950c4294230984d6315dfa11f6)

966
802.	[doc]		tomek, marcin
Tomek Mrugalski's avatar
Tomek Mrugalski committed
967
	Developer's Guide updated to Change BIND 10 references to Kea.
968
	Documentation for Keactrl added.
969
970
971
	(Trac #3396, git 271450edbc63e9022f877c9aa3d1dc290708f151)
	(Trac #3466, git fa9570d19c73cbe7effc75589b7eb855c411f6a3)

972
973
974
975
801.	[build]		fdupont
	Detect all OS X versions more recent than 10.9 (where
	pthread_cond_destroy() doesn't work as documented,
	which makes some of unit tests to fail).
Francis Dupont's avatar
Francis Dupont committed
976
	(Trac #3473, git d620ef6659598bcc1f4c30241e845348770e264e)
977

978
979
800.	[bug]		marcin
	DHCPv6 server is now usable on FreeBSD, NetBSD and OpenBSD systems.
Jeremy C. Reed's avatar
Jeremy C. Reed committed
980
981
982
	It can receive messages sent to ff02::1:2 multicast address. Also,
	fixed the bug whereby the DHCPv6 server failed to bind the socket
	to global unicast address on BSD systems due to invalid scope id
983
984
985
	setting.
	(Trac #3437, git f4c2fe2fc37a37f1510e138e1f6c4ccd757e1f06)

986
987
988
989
990
991
799.	[func]		tmark
	Configuration parsing for all Kea servers has been enhanced to include
	the location of the error within the configuration file presented as
	file name, line number, and column within the configuration file.
	(Trac #3436, git b927deb2b4579f93ba74d4be8f5a3a4eaa3c6422)
	(Trac #3409, git 777dbdb29a641f7d8661f9cc2c22f1cb9fe7eb14)
992

993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
798.	[build]		tomek
	JSON configuration backend is now the default. BUNDY backend
	is now deprecated after #3413 removed the BIND10/Bundy framework.
	(Trac #3476, git 727b65f2c62bbd7dc599b2e7956167e2b3c34098)

797.	[build]		tomek
	Removed a lot of remaining BIND10 framework: bind10, bindctl,
	cfgmgr, cmdctl, msgq, stats, sysinfo, tests, usermgr from src/bin
	directory, also src/lib/python directory. Python3 is not
	required anymore, unless documentation generation is enabled.
	(Trac #3413, git d7b297ac475193f687d07b0489ac74585d4f3814)

796.	[doc]		tomek
	User's Guide renamed to Kea Administrator Reference Manual,
	removed sections specific to BIND10/Bundy framework, rewritten
	general and DHCPv4 specific examples.
	(Trac #3418, git 73e6019d83760f0500890240e2e187dcd5e1e14c)

795.	[func]		marcin
	Added support to keactrl to start, stop, reconfigure and gather
	status of the DHCP-DDNS server.
	(Trac #3465, git 6bc61470c9ccee001fe282d0f879bcddac0b8721)

794.	[func]		fdupont
	cryptolink: add OpenSSL crypto backend as an alternative to Botan
	by specifying --with-openssl[=PATH] on the "configure" command
	line. Add hash support to the cryptolink API and use it in DHCP
	DDNS, removing the Botan dependency.
	(Trac #2406, git 4b4110dd68706b4171fc6d8a6f4f2a9cd820edac)

793.	[func]		tmark
	DHCP-DDNS: Implemented dynamic reconfiguration of the server,
	triggered when the SIGHUP signal is received by the server's
	process. Also, server performs a graceful shut down when SIGINT
	or SIGTERM signal is received.
	(Trac #3407, git f1a224df1e46098748ba60205be09ada4600515f)

792.	[func]		marcin
	Implemented keactrl script used to start, stop, reconfigure Kea
	servers and get their status and configuration data. This script
	is installed only if the JSON configuration backend is in use.
	(Trac #3422, git e1d164c7a9a54a7aacea88c8c57cd2826e06012b)

791.	[func]		tmark
	DHCP-DDNS: Now supports configure.ac parameter: --with-kea-config.
	It allows selecting configuration backend and accepts one of two
	values: BUNDY, which uses Bundy (former BIND10) framework as Kea
	0.8 did, or JSON, which reads configuration from a JSON file.
	(Trac #3401, git 8e69209caafc81041229f3d9601599f3d98fc86e)

790.	[func]		marcin
	DHCPv4 server: Implemented dynamic reconfiguration of the server,
	triggered when the SIGHUP signal is received by the server's
	process. Also, server performs a graceful shut down when SIGINT
	or SIGTERM signal is received.
	(Trac #3405, git dd0270bd91cf8fc958b8b388950d343d311ee99e)

789.	[bug]		marcin
	DHCPv4 server sends Renewal Time (58) and Rebinding Time (59)
	options to the client when the appropriate timers are set
	in the configuration. Previously, the timers were ignored.
	(Trac #3336, git b3c8a079889411182ade517c85aa4fe5d6b8719a)

788.	[func]		tomek
	DHCPv4 server: New parameter added to configure.ac: --with-kea-config.
	It allows selecting configuration backend and accepts one of two
	values: BUNDY, which uses Bundy (former BIND10) framework as Kea
	0.8 did, or JSON, which reads configuration from a JSON file.
	(Trac #3399, git 6e4dd3ae58c091ba0fd64c87fa8d7c268210f99b)

787.	[func]		marcin
	DHCPv6 server: Implemented dynamic reconfiguration of the server,
	triggered when the SIGHUP signal is received by the server's
	process. Also, server performs a graceful shut down when SIGINT
	or SIGTERM signal is received.
	(Trac #3406, git 3be60fa6ac521aecae6ae92d26dc03792bc76903)

786.	[func]		tmark
	DHCP-DDNS now supports DDNS updates with TSIG.  Please refer to the
	Kea Guide for details. Prior to this TSIG keys could be defined but
	were not used.
	(Trac #3432, git 80fea12a53d1e832d4e7b710ca6ea613300f73ea)

785.	[bug]		marcin
	DHCPv6 server avoids collisions between prefixes that are allocated
	as a result of receiving hints from the clients. Previously the
	whole prefix (including bits beyond the prefix length) was used to
	search existing leases in the lease database. If not found, the
	new lease was crated for the prefix sent by the client. If another
	client sent the same prefix but with different non-significant bits
	the prefix was allocated. This led to prefix collisions. Currently,
	server ignores bits beyond the prefix length when searching for
	existing leases.
	(Trac #3246, git 50de7df4195195e981ae9c8c6f1b4100047d5bb5)

784.	[func]		tmark
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1089
1090
1091
1092
	DHCP_DDNS's configuration was changed. The unused parameter,
	"interface" was deleted.  Three new parameters, "ncr_protocol",
	"ncr_format", and "dns_server_timeout" were added.  Please refer to
	Kea Guide for details.
1093
1094
1095
1096
1097
1098
1099
1100
1101
	(Trac #3268,    git bd60252e679f19b062f61926647f661ab169f21c)

783.	[func]*		tomek
	DHCPv6 server: New parameter added to configure: --with-kea-config.
	It allows selecting configuration backend and accepts one of two
	values: BUNDY, which uses Bundy (former BIND10 framework as Kea
	0.8 did, or JSON, which reads configuration from a JSON file.
	(Trac #3400, git 7e9fdfa644b81f72bfa5300b7ddcdb9754400769)

1102
1103
1104
1105
1106
782.	[func]		tmark
	Added sender-ip, sender-port, and max-queue-size parameters to
	the dhcp-ddns configuration section of both b10-dhcp4 and b10-dhcp6.
	(Trac #3328,    git 8d8d0b5eedaab20bf1008dfb3a6913eb006a6e73)

1107
1108
1109
1110
1111
1112
1113
781.	[func]		marcin
	libkea-dhcpsrv: the Memfile lease storage backend returns leases
	of a specified type. Previously, it ignored the lease type parameter
	and returned all leases for a particular client. Thanks to David
	Carlier for helping to implement this ticket.
	(Trac #3148, git d2f0edf473716cd747a21d6917e89ba55c148d8e)

1114
1115
1116
1117
1118
1119
1120
1121
780.	[func]		marcin
	libkea-cc: JSON parser stores information about the position
	of the data element values in the JSON string. The position
	comprises the line number and the offset within this line where
	the specific value resides. This functionality is intended to
	be used for error logging during configuration parsing.
	(Trac #3408, git 115a52a6713340fc589f6f95d73d242931239405)

1122
1123
1124
1125
1126
779.	[doc]		tmark
	Added a section to the developer's guide for Kea's DHCP-DDNS
	component, D2.
	(Trac #3158,    git  7be263c7372b1401a8b4288742854f96b5bec0d6)

1127
1128
bind10-1.2.0 (kea 0.8) released on April 17, 2014

1129
1130
bind10-1.2.0rc1 released on April 8, 2014

1131
778.	[func]*		marcin
1132
1133
1134
1135
1136
1137
	libdhcpsrv: the Memfile lease storage backend now writes
	leases into a CSV file. Configuration parsers for b10-dhcp4
	and b10-dhcp6 use the new configuration parameters to
	control the location of the lease file. It is possible to
	disable lease writes to disk using configuration for testing
	purposes.
1138
1139
	(Trac #3360, git 09e6e71abf8bc693e389ebd262fd149b43c1f1d4)

1140
777.	[func]		tmark
1141
	If b10-dhcp-ddns is configured to listen on an address other than
1142
	loopback, it will issue a log message warning the user that this is
1143
	insecure and is supported for testing purposes only.
1144
1145
	(Trac #3383,    git  652aa4de2fa82fdf3de569d01d9f4aa618fc1972)

1146
776.	[func]		tomek
1147
	b10-dhcp4 and b10-dhcp6 now support using PostgreSQL as the backend
1148
1149
	for storing lease data.  This backend is enabled by specifying
	--with-dhcp-pgsql on the "configure" command line. Without this
1150
	switch the PostgreSQL backend is not compiled leaving BIND 10 able to
1151
	be built on systems without PostgreSQL installed.  Thanks to David
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1152
	Carlier who contributed the initial patches for this work.
1153
1154
	(Trac #3080,    git  1aae8b1fab3008e62c4f085948b1abadad512447)

1155
775.	[func]		marcin
1156
1157
1158
	b10-dhcp4, b10-dhcp6: added a new parameter to subnet configuration.
	This parameter allows subnet ids to be set to arbitrary values or
	automatically generated values. Generated subnet ids are renumbered
1159
	each time one or more subnets are removed.  Setting the ids to
1160
	specific values prevents this renumbering.
1161
	(Trac #3281, git d90e9a0642fbb16a4e664160b4812f61fb81f1aa)
1162

1163
774.	[doc]		marcin
1164
1165
1166
1167
	Updated information in the BIND 10 Guide about the standards supported
	by Kea and its current limitations.
	(Trac #3258, git ff52b86206e3a256a02ca6d5cde55040550ba86a)

1168
773.	[doc]		tmark
1169
1170
1171
1172
1173
1174
	Added sections to the BIND 10 guide on configuring and using the
	DHCP-DDNS feature of Kea.  Chapter 19, describes the new DHCP-DDNS
	server and its configuration. Additions to chapters 17 and 18
	describe configuring the DHCP servers to work with the new server.
	(Trac #3283, git 806eea955c61eba2d7268958a740a8e8ea63bdaf)

1175
772.	[bug]		tmark
1176
1177
1178
1179
1180
1181
1182
1183
	b10-dhcp4 and b10-dhcp6 now both correctly support DDNS updates
	when honoring client requested delegation. When DDNS is enabled,
	and the client's FQDN indicates they will do the forward updates,
	the servers will now post a DDNS update request to b10-dhcp-ddns
	for the reverse updates. Prior to this the servers were posting no
	DDNS update requests when honoring client delegation.
	(Trac #3352, git b1a0f405463723d539b2e6ed2dcdd692d7796b88)

1184
1185
1186
771.	[bug]		tmark
	Ticket #3339 (entry 760) was reverted to fix regression
	where components added through bindctl, could not be removed.
1187
1188
	(Trac #3374, git c641e2d0569df3ca3e5a93beaf0ecf39db07e402)

1189
770.	[bug]		tmark
1190
	Configuration parsing in b10-dhcp6 and b10-dhcp4 for the "dhcp-ddns"
1191
1192
1193
1194
	section of their configurations now supplies hard-coded default values
	rather than those from their spec files.  This is a temporary solution
	to circumvent an issue in the configuration libraries which causes
	map-items to behave incorrectly.
1195
	(Trac #3358, git 983d8acec3a7ccb1ffef662eac7518aed5f99381)
1196

1197
769.	[func]		marcin
1198
1199
1200
	b10-dhcp6: Implemented support for Rebind message.
	(Trac #3232, git 3649413932857470558a6f19e0b0e181b3fc0fda)

1201
768.	[bug]		tmark
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1202
1203
1204
1205
1206
	b10-dhcp-ddns now treats a DNS server response code of
	NXRRSET as a successful outcome when processing a request
	to remove DNS data.  This corrects a defect in which
	b10-dhcp-ddns would incorrectly fail a request to remove
	DNS data when the DNS server's response was NXRRSET.
1207
1208
	(Trac #3362, git da3b0d4f364d069ffdb47723545798ac589fae42)

1209
767.	[func]		tomek
1210
1211
1212
	Unit-tests for all DHCP database backends are now shared.
	This improves test coverage for memfile and any future
	backends that may appear.
1213
1214
	(Trac #3359, git 3d6c11630ada9d0681a813cf026f6bb16aabb9fa)

1215
1216
bind10-1.2.0beta1 released on March 6, 2014

1217
1218
1219
1220
1221
1222
1223
1224
766.	[func]		muks
	--disable-dns and --disable-dhcp configure arguments have been
	added to conditionally disable the DNS or DHCP components
	respectively. This facility can be used to do a DNS or DHCP-only
	build of BIND 10. DNS and DHCP components are both enabled by
	default.
	(Trac #2367, git 81a689b61b1c4abf8a1a4fcbe41cfc96fd11792a)

1225
765.	[bug]		tomek
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1226
1227
	b10-dhcp4: Fixed a minor bug in eRouter1.0 class processing. The
	server no longer sets giaddr field.
1228
1229
	(Trac #3353, git 23c22e9b1141c699f361d45c309e737dfecf6f3f)

1230
764.	[bug]		tomek
Tomek Mrugalski's avatar
Tomek Mrugalski committed
1231
1232
	b10-dhcp4: Fixed a bug caused client classification to not work
	properly.
1233
1234
	(Trac #3343, git 1801400ac874380e7a565d373b4bae96a49e21f7)

1235
1236
1237
1238
1239
1240
1241
1242
1243
763.	[func]		tmark
	b10-dhcp-ddns may now be configured to disable DNS updates in
	in a given direction by simply not defining any domains for that
	direction in its configuration.  This allows it to be configured to
	support either forward DNS or reverse DNS only.  Prior to this if
	a request was received that could not be matched to servers in a
	given direction it was failed immediately.
	(Trac #3341, git 01f26bce1d9faaddb8be59802f73891ea065b200)

1244
1245
1246
1247
1248
762.	[func]		tmark
	If configured to do so, b10-dhcp6 will now create DHCP-DDNS update
	requests and send them to b10-dhcp-ddns for processing.
	(Trac# 3329, git 239956696465a13196a2b6bc0f3a61aed21a5de8)

Stephen Morris's avatar
Stephen Morris committed
1249
1250
1251
1252
761.	[doc]		stephen, jreed
	Added "man" page for perfdhcp.
	(Trac #2307, git ff2f538912c205fbdb1408ee613c09b90de53514)

Jeremy C. Reed's avatar
Jeremy C. Reed committed
1253
1254
1255
1256
1257
1258
760.	[bug]		tmark
	When merging a map of configuration elements into another, elements
	that are themselves maps will be merged. In particular, this
	corrects a defect which caused a configuration commit error to
	occur when using bindctl to modify a single a parameter in
	dhcp-ddns portion of b10-dhcp4 configuration.
1259
1260
	(Trac# 3339, git 3ae0d93d89f3277a566eeb045191a43b2dd9d9b1)

1261
759.	[func]		tomek
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1262
1263
1264
1265
1266
	b10-dhcp4, b10-dhcp6: IP address of the relay agent can now be
	specified for both IPv4 and IPv6 subnets. That information allows
	the server to properly handle a case where relay agent address
	does not match subnet.  This is mostly useful in shared subnets
	and cable networks.
1267
1268
	(Trac #3322, git 5de565baea42c9096dff78ed5fbd05982a174469)

Jeremy C. Reed's avatar
Jeremy C. Reed committed
1269
1270
1271
1272
1273
758.	[bug]		tmark
	b10-dhcp4 now correctly handles DHO_HOST_OPTION.  This corrects
	a bug where the server would fail to recognize the option in the
	DHCP request and then skip generating the appropriate DHCP-DDNS
	update request.
1274
1275
	(Trac #2426, git 985d66cba7665a71e17ef70c5d22c767abaad1b6)

1276
757.	[func]		tmark
Jeremy C. Reed's avatar
Jeremy C. Reed committed
1277
1278
1279
1280
1281
1282
1283
	b10-dhcp6 now parses parameters which support DHCP-DDNS updates
	via the DHCP-DDNS module, b10-dhcp-ddns.  These parameters are
	part of new configuration element, dhcp-ddns, defined in
	dhcp4.spec. These parameters influence when and how DDNS updates
	requests are created but communicating them to b10-dhcp-ddns is
	not yet supported.  That will be provided under separate ticket,
	Trac #3222.
1284
1285
	(Trac# 3034, git 22c667a66536ff3e3741bc67025d824644ed4e7d)

1286
1287
1288
1289
1290
1291
1292
1293
1294
1295
756.	[bug]		marcin
	b10-dhcp6: server parses DHCPv6 Vendor Class option. Previously
	the server failed to parse Vendor Class option having empty opaque
	data field because of the invalid definition in libdhcp++. The
	DHCPv6 Vendor Class option and DHCPv4 V-I Vendor Class option is
	now represented by the new OptionVendorClass. The b10-dhcp4 is
	affected by this change such that it uses new class to parse the
	DHCPv4 V-I Vendor Class option.
	(Trac #3316, git 1e61d7db5b8dc76682aa568cd62bfae0eeff46e3)

1296
1297
1298
1299
755.	[func]		muks
	Add support for the CAA RR type (RFC 6844).
	(Trac #2512, git 39162608985e5c904448f308951c73bb9c32da8f)

1300
1301
1302
1303
754.	[func]		muks
	Add support for the TLSA RR type (RFC 6698).
	(Trac #2185, git a168170430f6927f28597b2a6debebe31cf39b13)

1304
1305
1306
1307
1308
753.	[func]		muks
	libdns++: the unknown/generic (RFC 3597) RDATA class now uses the
	generic lexer in constructors from text.
	(Trac #2426, git 0770d2df84e5608371db3a47e0456eb2a340b5f4)

1309
1310
1311
1312
1313
752.	[func]		tmark
	If configured to do so, b10-dhcp4 will now create DHCP-DDNS update
	requests and send them to b10-dhcp-ddns for processing.
	(Trac# 3329, git 4546dd186782eec5cfcb4ddb61b0a3aa5c700751)