1 Technical notes on version 2.5
9 Multiple command/console per runscript
10 console command in runscript
13 State file updated on job term
16 Duplicate Job directives
17 - Allow Duplicate Jobs
18 - Allow Higher Duplicates
19 - Cancel Queued Duplicates
20 - Cancel Running Duplicates
21 Ensure they work with RerunFailedLevels
25 Improved status commands for Bat
26 Spooling/despooling status
27 Implement ftruncate for NFS devices
28 Add long term statistics job table
31 separator in console (!$%&'()*+,-/:;<>?[]^`{|}~)
36 kes Set MALLOC_CHECK_=0 in environment before starting Bacula to
37 turn off glibc checks that prevent getting good dumps.
38 kes Implement console 'wait mount' command. Doesn't yet work.
39 kes Implement timeout=nn on console 'wait mount timeout=nn' command.
40 kes Break the do_swapping into do_unload, do_swapping, and
41 do_load. It is much more logical that way.
42 kes Implement a set_dcr_from_vol subroutine in acquire.c for
43 reading volumes. This allows the dcr to be refreshed after being
44 zapped when the wrong volume is mounted.
45 This should fix bug #1126 -- During multiple tape restore, bacula
46 does not ask for physical tape change, but rereads same tape
48 kes Apply patch submitted for bug #1107 with a small modification.
49 This fixes a bug where bcopy copied too many records.
50 kes Make some tweaks to bsmtp based on patch submitted in bug #1124.
52 kes Make the default bat restore Pool be Any. This fixes bug #1118.
54 kes Remove debug statement that crashes the SD at the end of
55 a tape during restore. Fixes bug #1125.
57 kes Implement Win32 bat changes made to Branch-2.4
59 kes Tweak separator command in console to start disabled and
60 allow defining no separator character. Also make code a
61 bit more fault tolerant.
62 kes Make btraceback write the traceback to the working directory
63 before attempting to mail it.
64 kes Add a RFC to Projects.
66 kes Attempt to implement a kludge to make Qt work with bat
68 kes Setup rstorage correctly. Virtual backups are working.
70 kes Move setting JobLevel and JobType into a method, which should
71 allow completing Virtual Backups.
72 kes Fix verify jobs to work again.
74 kes Virtual Backup tweaks -- it is close to working.
76 kes Ensure that SD tried to mount a volume not in an autochanger
77 at least once before asking for operator intervention.
78 kes Make SD aware of Virtual Backup jobs.
79 kes Add VirtualFull for bat.
80 kes Changes to get read storage correct for Virtual Backup.
82 kes Remove old code from label.c
83 kes Split display_display_info() out of write_bsr_file()
84 kes do_vbackup_init() working -- i.e. bootstrap file built.
85 kes Change Bacula trademark owner from John Walker to Kern Sibbald
86 kes First non-working cut of vbackup
87 kes Correct FD heartbeat code to use volatile variable accessed by
89 kes Zero thread id with memset if on Win32 in case it is a struct.
90 kes If cannot create JobMedia record, continue to try to write eof
91 and clean up in block.c
93 kes Add code to interface OpenSSL to new Win32 pthreads code which
94 used a structure for thread_t.
96 ebl tweak bat for win32 compilation
98 ebl Remove tokyo cabinet from the source
99 ebl Update configure/autoconf to support berkeley DB
100 ebl Add a sort to db_get_file_list() to improve bsr construction time.
102 kes Add a mtx-changer.conf file that is not overwritten during
103 an upgrade. It fully configures the mtx-changer script.
104 kes Clear in-use bit on vol when unused while swapping.
106 kes Remove sleep at end of ./bacula
107 kes Clear hash packet for hardlinked files correctly. This corrects
108 a long standing bug where hardlinked files selected individually
109 would occasionally not be restored.
111 kes Apply Eric's patch to ensure that autoprune does not return
112 a Volume not in the autochanger unless requested to do so.
113 kes Correct bat restore display of multiple drives. This fixes
115 kes Do find_a_volume() each time an unload is done. This
116 fixes the failure of maxvol2-test.
118 kes Add some SD debug code.
119 kes Do find_a_volume() each time an unload is done.
120 kes Apply Joao's DBI patch that adds easier configuration of DBI drivers,
121 and adds --with-db-port to ./configure.
122 kes Use Qmsg() in job.c watchdog callback.
124 kes Release main control rwlock if ABORTing.
125 kes Make watchdog connect timeout queue messages rather than sending
126 directly to avoid lock conflicts with the real thread.
127 kes Add const char in dbd.c to avoid compiler warnings.
128 kes Fix python compiler string warning. Note, IMO the GNU C++
129 compiler guys have made a *very* bad change to their compiler.
130 They now force all strings to be 'const' unless you explicitly
131 cast them, which is extremely ugly and ruins nice code as well
132 as creates a lot of useless work.
134 kes Fix mtx-changer to detect both versions of Ubuntu (Debian)
135 mt. This fixes bug #1116.
136 kes Add const in python files to reduce compiler warnings.
137 This may have to be backed out because of later compiler
139 kes Fix failure of 2drive-concurrent-test. Always read label;
140 clear_unload() only after drive is defined in acquire_for_read().
142 kes Generally clean up the manual tape loading code. The main
143 conceptual change is that when a volume is marked to be unloaded,
144 its volume name is retained, and it is only marked as unloaded
145 when either the autoloader says it is unloaded or another tape
146 is read on that drive.
148 kes Add debug code and refactor subroutine in stored/mount.c
149 kes Fix format problem in bscan output reported in bug #1105.
150 ebl Fix get_next_volume_for_append logic with autochanger
151 - use pruned volumes if found
152 - don't reset the inchanger flag after getting a recycled volume
154 Fix recycle_oldest_purged_volume to take InChanger flag in account
156 ebl Add mmap/unmmap implementation for tokyodbm under win32
158 kes Make first step toward eliminating globals from config
159 scanning. Also should be a workaround for FORTIFY_SOURCE
160 GNU C bug -- fixes bug #1042.
162 kes Apply duplicate job tests to restarted jobs.
163 kes Copy more data when restarting a job so that run
164 overrides are kept. This should fix bug #1094.
166 kes More word alignment cleanup.
167 kes Fix bug where SD did not ask operator if the device could not
168 be opened. Reported by Eric.
170 kes Add dbuser to DIR conf file (replaces user).
171 kes Add --with-db-password to ./configure
172 kes Fix regress to handle db_password.
173 ebl Add new "status storage slots" that list autochanger
175 ebl Update vtape driver to compile only under Linux.
176 ebl Fix a bug when restoring with a wrong mediatype.
178 kes Eliminate ints from conf files and structures to avoid
179 word alignment problems
181 kes Fix bug reported by Scott Barninger where the bacula script
182 refers to scripts in the wrong directory. Needed to meet the
183 requirements of recent FHS location changes.
184 ebl Disable vtape for FreeBSD.
186 ebl Modify disk-changer to check if slot contains something before
189 ebl Fix vtape on win32 and debian.
190 ebl Fix autoselect patch (cause segfault).
192 ebl Fix autoselect option broken for a while. Fix #1089. Need some
193 work with StorageId to be able to use a particular drive in a
196 ebl Rename vtape to vtape.
197 ebl Update vtape driver.
199 ebl Modify vtape driver to avoid sparse file.
200 kes Add make clean of qt-source directory during ./configure
201 kes Store last block number written to tape in DEVICE and
202 use it for testing for correct last block on EOT.
204 Release Version 2.4.0:
208 kes Make sure to clear JS_WaitMedia when operator mounts a Volume.
209 This fixes bug #1095.
211 kes Add create_postgresql_database.sql to Win32 installer. Should
212 fix problem reported by Juilio Monteiro.
213 kes Get correct slot when auto unloading a device. This fixes bug
216 kes Fix multiple media restore.
217 kes Make DEVICE Slot private and access it via a method.
218 Allows better control over when it is set and cleared.
219 kes Fix possible seg fault if SQL error.
221 kes Add Martin's fixes to argument scanning for the estimate
222 command. This fixes bug #1093.
223 kes Add debug code to SD.
224 kes Fix renaming a Volume, which used the wrong Volume name.
226 kes If operator has rewind tape, print warning, release tape and
227 try once more. If tape is positioned somewhere, something went
228 wrong, so mark the tape in error and try once more. Previously
229 this error was fatal, now it produces an error message.
230 kes Ensure correct volume name displayed during restore
231 kes Ensure that Volume is mounted for restore.
233 kes Fix a few more Coverity reported problems.
235 kes Apply Allan Black's status dir job count patch.
236 ebl Add information about IMPORT/EXPORT slots in mtx-script.
237 kes Enhance a couple of SD debug messages.
238 kes Tweak unload flag setting and ensure it is set during swap.
240 ebl Fix #1091 about bad output in estimate command.
242 kes Modify autochanger locking to attempt to avoid race
244 kes Make sure device not busy before doing label command.
245 kes Display open() errors except when polling. Previously too
246 many were suppressed. This should fix bug #1070.
247 kes Fix Win32 reparse points. Bacula will not recurse into any
248 reparse point directory, including mount points, unless the
249 directory is explicitly mentioned at the top level (same as
250 with Unix). A file that is linked to another file will be
251 backed up -- much as Unix does for hardlinked files.
252 This fixes bug #1041.
254 kes Remove double quotes from ChangeLog and ReleaseNotes
255 kes Remove StorageId test when pruning and recycling (Eric's changes).
256 kes Remove old form of locking when getting volumes -- causes deadlock.
257 kes Change bat dirstat layoutWidget to dirstatlayoutWidget to make
258 the name unique and to eliminate compile time error.
259 kes Add accurate.o to Win32 FD Makefile
261 kes Fix cats dll build on Win32 after db_update_job_end_record
262 calling sequence change.
263 ebl Switch to tokyo dbm instead of htable in accurate code
264 ebl Include tokyo dbm to bacula source tree
266 kes Fix buffer overruns detected by Coverity.
268 kes Tweak joblog display.
270 kes Implement --without-qwt
271 kes Fix layout of restore tree dialog
272 kes Add configure bat QWT libraries, so that bat can be built
273 with or without the QWT libaries.
275 ebl Add dummy tape driver for regression tests.
276 kes Make sure we unload the right slot when swapping.
278 kes Add debug times, reduce size of two-pool-changer test
280 ebl Tweak autoconf scripts for vtape
282 kes Improve SD reserve debug code.
283 kes Testing an improvement to free up volumes no longer in use.
285 kes Rework SD acquire for read to handle autochanger Volume
287 kes Implement regression that explicitly tests swapping a Volume
288 from one drive to another.
289 kes Enhance disk-changer to detect most error conditions.
290 kes Fix SD code so that it properly swaps a Volume between drives.
291 This fixes bug #1083.
293 kes Apply libdbi patch from Joao Freitas for regress and for
294 Bacula trunk. Regress now works with libdbi. Nice.
295 kes Apply .nobackup patch from bug #1077 submitted by
297 kes Apply Bastian Friedrich's patch that adds %p to edit the pool
298 name into jobs cloned via the run directive.
300 kes Prevent a Volume that is being swapped from being freed from
301 the volume list. This will most likely fix, at least partially,
303 kes Fix strippath so that it does not get a buffer overrun and crash FD.
304 This fixes bug #1078.
305 kes Remove 50 millisec wait in SD that broke debugger.
306 ebl Add MaxRunSchedTime option that specifies the maximum allowed time
307 that a job may run, counted from when the job was scheduled.
308 ebl Fix MaxWaitTime option that specifies the maximum allowed time that
309 a job may block waiting for a resource, counted from when the job starts
310 ebl Rename (add) Max(Incr|Diff|Full)WaitTime to Max(Incr|Diff|Full)RunTime
311 kes Apply patch from bug #1076 by Tullio Andreatta <t.andreatta@troppoavanti.it>
312 that implements multiple commands per line in the console when using
313 readline. Modify the default to use a semicolon as the command separator.
315 ebl Fix SQL query in migration code.
316 ebl Make accurate mode with hash disk pass regression tests
318 ebl Implement first cut of accurate backup with hash disk.
320 kes Force unload of volume when wrong volume mounted in SD.
322 kes Fix bat seg fault at termination.
323 kes Add Bacula generated version to bat about box.
326 kes Experiment with allowing multiple read jobs.
327 kes Move final volume swapping code to DCR method and
328 call it from acquire_for_read().
329 kes When wrong volume is mounted during read, unload_autochanger.
331 kes Integrate the libdbi changes from Joao Henrique Freitas
333 kes Stop searching for Volumes in SD askdir if DIR returns the
334 same volume name twice in a row.
335 kes Close bat console windows first to eliminate error message
338 kes Tweak the swap Volume from one drive to another code so that
339 it now seems to work.
340 kes Resolve several problems with recycling that broke the new
341 code (these problems are in 2.2.9 as well).
342 kes Remove the volume lock when calling the sysop code.
343 kes Don't mark a reserved volume with no writers as unused otherwise
346 kes Rework class structures for VOLRES, DCR, and DEVICE to make
347 the method names a bit more logical, and for more logically
348 handling the responsibilities.
350 kes Remove redundant code in terminating the scheduler that just
351 causes a seg fault in many cases.
352 kes Cleanup releasing a volume and make it a DCR method.
353 kes Improve algorithm for detecting pre-reserved volume and
356 kes Tweak volume swapping code so it works.
357 kes Correct name overloading in mount.c
358 kes Replace released flag in VOLRES with reserved and add access
359 methods for the VOLRES class.
360 kes Prevent volume from being released while being swapped.
361 kes Apply Bastian Friedrich's edit codes patch for the bpipe-fd
363 kes Apply Bastial Friedrich's edit pool=%p patch for run clone
365 kes Refactor parts of stored/mount.c
367 ebl Add sanity checks for VolWriteTime and VolReadTime
368 ebl Take care of bad clock changes while computing VolWriteTime
369 and VolReadTime. This should fix or limit #1066
370 kes Correct error string numbers in dird/catreq.c
371 kes Restructure reserving, acquiring, and mounting volumes. Calls to
372 autochanger are deferred for mount.c -- simplifes the code.
374 kes Do not prune any running job. It just fails the job.
375 kes Lock the volumes when changing dev->reserved_device and marking
376 the volume unused otherwise the device can get reserved by
377 another job before the volume is released, thus blocking it.
379 kes Correctly detect Ubuntu systems, and add ubuntu platform directory.
380 kes Fix bug #1063, reuse of freed ptr in list nextvol.
381 kes Release regex compile buffer in filed/job.c
382 kes Add proper type of const char in sql_create.c
383 kes Turn off debug in daemon termination routines
384 kes Move free_volume_list() before devices are freed in stored.c
385 kes Fix reference to uninitalized stack variables in bregex.c.
386 This should correct bug #1067.
388 kes Fix possible seg fault in SD when freeing a volume entry.
390 kes Implement unload_dev() before swap device.
391 ebl Add statistics prunning with option and menu
392 kes Separate unload_dev() from unload_other_device() in autochanger.c
394 kes Apply patch from bug #1069 that corrects spurious error messages
395 when ACLs enabled on SGI but no ACL exists.
396 ebl Fix small segfault in bacula-sd when debug level is 500
397 kes Modify run_program() and run_program_full_output() to use
398 call by reference for the results string. This corrects a long
399 standing problem where the address of the string may be changed
400 in the subroutine but not in the calling program.
402 kes Re-enable code to remember last volume mounted on a non-tape
404 kes Add patch supplied in bug #1068 that fixes a SD crash when using
405 a Virtual autochanger.
406 kes Generate correct JobMedia records during spooling/despooling when
407 running concurrent jobs. Thanks to Tom Ivar Helbekkmo
408 <tih@hamartun.priv.no> for excellent analysis and testing.
410 kes Tweak hash algorithm for htable using Martin Simmons idea
411 for doing a circular shift.
412 kes Remember what volume is in VTLs (previously turned off for
414 kes Analysis of JobMedia records by Tom Ivar Helbekkmo <tih@hamartun.priv.no>
415 pointed out some problems in creating JobMedia records during
416 spooling with concurrent jobs. Fix the problem by updating the
417 start file position before despooling and generate a jobmedia
418 record at the end of despooling.
420 kes Fix handling of JobMedia records during spooling and when a
421 Volume is changed without actually writing data to the Volume.
423 kes Rework certain SD locking based on gdb tracebacks of deadlocks
424 sent by Eric. This code now uses only the volume_lock() rather
425 than the reservations lock when at EOM and acquiring a new
427 kes Ensure only one exit point in several subroutines.
429 kes Implement bsock code to permit locking. Use the new code in Verify
430 in the FD to prevent the heartbeat thread from disrupting the Verify
431 data sent to the Dir.
432 kes Modify SD locking to eliminate locking the reservations system from
433 outside the system. Use the volume lock when getting media data
434 and reserving a new volume at end of media.
435 kes Add Eric's volume_unused() fix to stored.c so that Volumes found
436 when SD starts are not locked into place.
438 kes Fix error compiling runscript code on 64 bit machines.
439 kes Tweak Win32 mount point code.
440 kes Fix a couple of bugs in the accurate code (bad sscanf, buffer not
441 cleared giving bad file estimate).
442 kes Implement BIG_MALLOC in htable code. Runs 2.5 times faster for
445 kes Keep Schedule run lists in order as suggested by
448 kes Implement autostart scripts for Debian.
449 ebl Implement upgrade catalog scripts.
451 ebl Apply jobstat patch for long term statistics. Have to implement
452 purge stats command and upgrade scripts.
453 kes Fix mtx-changer.in for broken Debian mt program.
455 kes Fix large number of JobMedia records reported by Eric Bollengier.
457 kes Apply doc fix from bug #1062.
458 kes Resolve crash and improper restore wx-console Win32 restore
459 GUI. Fixes bug #1065.
460 kes Update Win32 wxWidgets to latest version.
461 kes Attempt to do correct handling of Win32 mount points. Should
463 kes Fix Win32 FD backup/restore memory leak due to improper termination
464 of BackupRead/Write. This fixes bug# 1038.
466 ebl Reduce memory usage for accurate backup, working only with ctime
467 and mtime. (not all Lstat field)
468 About 40MB for my Linux system (400.000 files)
470 kes Add dcr->reserved_volume flag that allows us to release a volume
471 even if it is not vol->released. This allows maxvol2 to work when
472 Volumes expire and we are already writing to the device (i.e. a
473 volume is pulled out from under us by another job terminating after
474 we reserve the drive).
476 ebl Permit multiple command/console per runscript definition.
477 RunScript { command = /bin/true ; command = /bin/false ... }
478 ebl Add RunsWhen = AfterVSS to runscript. You can execute a command
479 (restart an application) just after the VSS snapshot on windows.
480 kes Don't zap dcr values during release_volume() as they might
481 have the next Volume to be mounted.
482 kes Fix AIX prototype.
484 kes Second cut of drive switching during backup.
487 kes Update Win32 version of wxWidgets to most recent version.
488 kes Tweak Copy job details.
489 kes Rework dir_find_next_appendable_volume to make a bit more effort
490 to find a suitable volume before giving up.
492 kes Make ask_sysop_to_create... to return if waken from wait.
493 This helps get out of blocked conditions.
494 kes Experimental implementation of switch_device in reservations.
495 kes Implement FD version to allow easier protocol changes.
496 kes Add Plugin Options string -- not yet passed to FD.
497 kes Implement PluginOptions ACL.
499 kes Attempt to correct problems with restores with autochangers and
500 use counts going negative
501 kes Rework SD status command and implement API for bat. Implements
502 header, runing waitreservation, devices, volumes, spooling,
503 and terminated status keywords.
504 .status storage=xxx <keyword>
505 kes Clarify TLS error message by adding double quotes around name.
506 kes Simplify SD/FD status code by putting api flag in STATUS_PKT
507 kes Pass jcr to tls routines so debug messages can be handled better.
508 kes Rework jobq resource allocation code, and possibly fix a bug
509 that caused reference counts to get out of sync.
511 kes Rename fd/dir plugin to use Bacula standard underscore.
512 kes Plugin work -- bring dir up to fd level.
513 kes Start implementation of VTL code
514 kes Fix Win32 build after adding new cats subroutine.
516 kes First cut at Duplicate Job implementation.
518 kes Fix bugs in MaxFullInterval and Implement MaxDiffInterval.
519 kes Start PluginOptions string, and refactor a bit of ua_run.c
520 ebl Apply Allan patch that permit to reset recyclepool.
522 kes Test patch -- possible fix or improvement for bug #1053
523 kes Refactor FD and SD status commands to permit new API code in
524 SD, and to fix Win32 build.
525 kes Win32 build is now working.
527 kes Implement 'MaxFullInterval' and start 'MaxDiffInterval' based on
528 some ideas in patch from Scott Bailey.
529 kes Begin implementation of duplicate Job control.
530 kes Fix some of Win32 build after recent additions.
531 kes Apply patch from Frank Kardel that implements 'honor no dump flag',
532 which causes the FD to detect whether or not the OS has the
533 honor no dump bit (*BSD systems), and if so, to skip backing up
534 any file with this bit set. The feature is enabled by setting
535 'honor no dump flag = yes' in the Options section of a FileSet.
537 kes Correct po warning message with datarootdir
538 kes Implement more code in dird.c to put configuration parsing in
539 a class rather than use globals.
540 kes Restructure SD status command for implementation of bat API
543 kes Suppress incorrect 'Will not descend from x into y' messages.
544 kes Eliminate FORTIFY_CODE=2 bug, and make first cut at removing
545 daemon globals used by parser.
546 kes Apply Joao's patch to separate DB_TYPE and DB_PROG in configure.
548 kes Fix free of plugin_list when none exists.
550 ebl Apply accurate project patch.
552 ebl Fix a segfault when using strip_path option. (Use of pm_strcpy
553 on non-mempool object)
554 kes First cut of converting FD .status to work with bat API.
556 .status client=XXX header
557 .status client=XXX running
558 .status client=XXX terminated
559 kes Implement first cut of Copy Job.
560 kes Implement Catalog in Pool resource. It overrides catalog specified
561 in the Client resource.
563 kes Apply patch (with some difficulties) from Joao Henrique Freitas
564 <joaohf@gmail.com>, which adds support for libdbi as a Bacula
566 kes Add patch from Martin Schmid scm@apsag.com that checks to see if
567 ftruncate() actually works. In the case of some (cheap) NAS devices,
568 it does not, and so recycling NAS Volumes does not work. The code
569 simply unlink()s the file, then recreates it. This fixes bug #1011.
571 kes First incomplete cut of big malloc blocks for htable.
572 kes Tweak plugin code.
574 kes Plugin debug code + tweak a couple bat dialog layouts
576 kes Fix creating first JobMedia record during Migration to include
577 proper index. This caused slow restores of migrated jobs.
578 kes Temp fix to plugin name file_index.
579 kes Bacula backed up and restored a MySQL database.
581 kes Implement plugin restore.
582 kes Implement parsing of db_driver to give db_type index.
584 kes First cut of plugin restore code.
585 kes Fix bug #1047, which had a heap overrun when stripping certain paths,
586 and do not strip paths on symbolic links.
587 kes Set catalog backup database and user name from values specified on
588 the ./configure line.
589 ebl Fix #1031 about wrong pool source information in job report.
592 kes Remove a redundant jcr argument to find_files, match_files, and
594 kes Implement '.status dir header|scheduled|running|terminated' that
595 prints the requested status section. With the exception of the
596 header, the other reports have fields separated by tabs (\t).
598 kes Apply patch from Peter Much <pmc@citylink.dinoex.sub.org> that fixes
599 a resource embedded run command to find a since time if no explicit
600 since time was supplied on the command line.
601 kes Apply state-file.patch sent by Allan Black <Allan.Black@btconnect.com>
602 that updates the state file at job termination time in addition to
603 when the daemon terminates.
605 kes First version where a plugin did a backup.
606 bpipe-fd.so created a backup file, wrote a test
607 string to it, and Bacua could restore this fabricated file.
609 kes Implement DB Driver = string for the DBI driver.
610 kes Remove all old bdb_xxx.c code. Add dummy routines to bdb.c
611 kes First cut of code for loading Win32 plugin dlls. Implement
612 dlopen, dlsym, dlclose, and dlerror in src/win32/compat/compat.cpp
613 and implement a dlfcn.h file based on opengroup's definitions of
616 kes First cut plugin directives.
618 kes Apply patch from bug #1049 to prevent stripping the path on a
620 kes Attempt to fix bug #1047 where stripping a path corrupts the
621 heap. Waiting for feedback.
622 kes Correct the Mount message not to suggest labeling a new tape
623 when doing a restore. Submitted by email by John Stoffel.
624 kes Attempt to work around gcc FORTIFY_SOURCE bug that crashes the
625 FD by using casting. Reported in bug #1042.
627 kes A bit of crypto cleanup. More later.
629 Release Version 2.2.8
631 kes Apply patch from Martin to correct bug #1040, bscan sets existing
633 kes Fixed important spelling error in doc -- bug #1045.
635 ebl Fix bextract to be able to extract non-portable Win32 data to
637 kes Move initialization of read/write res lock earlier in the code.
638 This fixes the crash with a null conf file. This fixes bug
640 kes Redefine CURES in lib/parse_conf to be URES and move it all
641 into lib/parse_conf.c -- this responds to bug #1042, but does
642 not fix it. The fix is not to compile with FORTIFY_SOURCE.
643 kes Backport to 2.2.8 fix de-referencing a NULL pointer in the scanner from
644 the trunk SVN. I don't think this was reported as a bug.
646 ebl Fix a bug during tape initialization with MTSETDRVBUFFER.
648 kes Fix Win32 build with new .def files and DLL_IMP_EXP ...
650 kes Add DataDespooling and DataCommitting status (committing is
651 the last despooling).
652 kes Finish implementation of new reservations code noted below.
654 kes Fix bsnprintf for float point numbers. I broke recently when
655 parameterizing some variables. This fixes bug #1036.
656 kes Undo recent reservations changes ... will apply them later
657 when they work better.
659 ebl Fixes #1034 which cause mysql to hang the connection after 8h
660 ebl Change default statistics target of filename.name and path.path
661 fields for PostgreSQL. This speeds lookup by indexes. Thanks
663 kes A few more tweaks to new reservation code. Make sure to clear
664 vol released flag when retaking volume. When reading label and
665 label is bad mark volume unused. When recycling, mark volume
666 unused so it can be renamed.
668 kes Fix reserve_volume() so it doesn't release a volume in use
669 (i.e. a volume entry not marked released). This should be
670 the last part needed to fix bug #1018.
672 kes Move Heartbeat documentation from Job to Director resource.
673 This fixes bug #1033.
675 kes Fix existing switch drive SD code to call autochanger to release
676 any old volume. This must be done to keep the autochanger from
677 releasing subsequently newly reserved volumes in doing a close().
678 This should fix bug #1018.
679 kes Fail if attempting to get console input in batch mode. This
680 should help fail RunScript console commands that are incomplete.
681 kes First cut implementing switch_drive() in SD (not actually called).
683 kes Implement first cut running console commands in a RunScript.
685 ebl Fixes bug #1028 where 'Selection Type' option was not usable
687 ebl Fixes bug #897 and bug #1005 where bacula doesn't display runscript
690 Release Version 2.2.7
692 kes Add new free_tls() entry point so that Win32 builds.
693 kes Fix compile warning in src/lib/util.c
694 kes Fix entry point for edit_job_codes() so that Win32 builds.
695 kes Fix seg fault Frank Sweetser reports in regression testing
696 on his systems. The problem was that the original author of
697 bsnprintf.c did not take into account the side effects of
698 using ++x in the argument to a #define.
699 kes Make SD protocol backward compatible with version 2.2.x.
701 ebl Fixes bug #1015 where bacula failed to restore acl to a socket
702 because Bacula no longer restores sockets.
703 ebl Always use ignorecase fileset option on win32 FD.
705 kes Apply patch from Michael Stapelberg <michael@stapelberg.de>
706 that implements double quoting include names in conf files,
707 and also allows piping input by having the first character
708 be a vertical bar (|).
709 kes Apply patch from Bastian Friedrich <bastian.friedrich@collax.com>
710 that implement %f in RunScripts to pass the FileSet name.
711 kes Skip leading | when lex input comes from a pipe as suggested
712 by Michael Stapelberg <michael@stapelberg.de>.
714 kes Apply patch for bsmtp Win32 daylight savings time fix supplied by
715 Nerijus Baliunas <nerijus@users.sourceforge.net>
717 kes Implement Plugin Directory and plugin events.
719 kes Implement a security enhancement: TLS authentication but no
720 encryption. Enabled by setting 'TLS Authentication = yes'.
721 Note when this is on, TLS encryption is turned OFF!
723 kes This patch corrects a problem where the maximum concurrent storage
724 jobs counter gets out of sync during restore jobs causing jobs to
725 'wait on max Storage jobs'. This patch fixes bug #1009.
727 kes This patch fixes bcopy so that it produces correct Volumes.
729 kes This patch eliminates spurious output to the console during a VerifyVolume
730 job that contains encrypted data. It fixes bug #1024.
732 kes This patch prevents the 'status dir' command from trying to use a scratch
733 volume and possibly moving it from one pool to another. This patch fixes
736 kes Add new include to postgresql.c suggested by Marc Cousins so
737 that it compiles correctly with pgre version 8.3.
739 kes Fix --archivedir addition to configure. Replace it with
740 --with-archivedir in configure.in This fixes the regression
742 kes This patch fixes bug #1012 where the job is canceled because
743 of Max Run Time exceeded when the job has not yet started.
745 ebl Apply Richard Mortimer patch that fixes #1016 when there are more than
746 one 'part' to write. Instead of each part being stored on disk,
747 written to DVD, then deleted from disk, all parts are written to disk,
748 and only the last is written and deleted from disk.
749 kes This patch fixes the status command to include the formating string for
750 JS_AttrInsterting. It fixes bug #1021.
751 kes This patch should fix the Mac OS X build problem on the latest
752 Darwin, where sys/types.h was not included correctly (apparently
753 due to a change in the Mac headers). The solution was to explicitly
754 ensure that it is defined for the ./configure.
755 This patch also has a rebuild of configure that includes the Debian
756 qt4 patch to check for qmake-qt4. This patch fixes bug #1020.
757 kes This patch should ensure that queued messages to the console are
758 displayed as soon as possible. It should fix bug 1007, but has been
759 reported not to work.
761 kes This patch fixes the infinite loop when trying to increase the
762 maximum number of volumes in a Pool during the add command.
763 This patch fixes bug #1008.
765 Release Version 2.2.6
767 db Remove extra data on estimate command in joblist for bat.
769 kes Cleanup of code in SD that sets the LastWritten date. This doesn't
770 really change anything, but is the beginning of doing it *right*.
771 To do it completely right the LastWritten date must be passed to
772 the SD, but it is not yet done.
773 kes Minor tweaks to some bat restore SQL.
774 kes This patch fixes bug #1003 where putting the message output from
775 a Verify job into the catalog results in a recursive loop. The problem
776 seems to show up only with postgresql (to be verified).
777 kes Correct %x to %p in postgresql debug statement.
779 kes Fix bug #942 where lots of emails where generated when the heartbeat
780 interval was low and Bacula wanted a different tape from the one in
783 ebl Add new SD despooling attributes and Dir inserting attributes
784 job status codes in the catalog (Status table).
786 ebl Use qmake-qt4 instead of qmake when available (debian system).
788 kes Add a security warning to src/cats/make_catalog_backup.in indicating
789 that passing the password via the command line (arg 3) is insecure.
790 This responds to bug #990 (it doesn't fix it).
792 kes Set default debug_level to zero. This corrects bugs #991 and #993.
793 kes Fix a crash in bat when it cannot connect to the Director for example
794 if the Director is not running.
795 kes Remove redundant INDEX (JobId) from File table in the trunk.
797 kes Make explicit exception to GPL in LICENSE to permit linking
798 the Win32 FD with Microsoft VSS code.
799 kes Apply the Solaris package patch from
800 Masopust, Christian <christian.masopust@siemens.com>
801 kes Apply the patch to optionally add a timestamp in the debug output
802 submitted by Mariusz Czulada <manieq@wp.eu>.
804 ebl Use PQerrorMessage instead of PQresultErrorMessage in postgresql
805 backend (sql_strerror). Fixes bug #989
807 kes Apply Michael Short's <mdshort@gmail.com> Win32 regress patch.
808 It applied with no problems.
809 kes Add PATH command to SunOS part of mtx-changer.in so that sed and
811 kes Redirect stderror to stdin on mt status command in mtx-changer.in
812 since the status is returned on stderr on Solaris.
813 kes Activate Close button on tray-monitor window. This fixes
815 kes Check for NULL item in parse_conf.c before calling it. In the
816 case of Device, there is no item and this caused a seg fault when
817 Device appears in the conf file.
818 kes Add a #define __CONFIG_H when including config.h in bacula.h. This
819 avoids pulling in config.h multiple times in some new code.
821 kes Fix spurious warning message printed when creating a volume with
822 a LabelFormat. This fixes bug #976.
824 Release Version 2.2.5
826 kes Add JobId in place of Job name in all the Jmsg() output.
827 kes Correct the APP_DESC for the Win32 storage service (remove an e).
829 kes Make maxvol-test and new more strict maxvol2-test work.
830 kes Print JobId in all Jmsg() job output.
832 kes Add new SD despooling attributes and Dir inserting attributes
833 job status codes. This fixes bug 961.
834 kes Fix Win32 drive display in bat version browser. Fixes bug #962.
836 kes Fix doc issue. This fixes bug #963.
837 kes Fix listing performance problems in bat. Pointed out by
839 kes Remove old debug code.
840 kes Fix bat code that tests for Win32. This should fix bug #968
841 kes Query 5 list wrong Vol after migration. This fixes bug #960
843 ebl Fix #969 where user can't change Replace option in restore menu.
845 kes Save jcr in thread specific data (tsd) for each thread.
846 kes Make Dmsg() print JobId as -%u.
847 kes Make Jmsg, Emsg, and others automatically pickup the jobid
848 for the thread if it exists.
849 kes Remove old reservation debug jid code.
850 kes Remove get_jcr_from_tid() from OpenSSL and tls code.
851 ebl Add an option that permit to specify spool size in job
852 definition. (Applying patches/testing/spoolsize_per_job.patch).
853 You must upgrade SD and DIR at the same time.
854 dvl Add new configuration item --archivedir
855 dvl Adjust regression tests to use tmp not /tmp. This will allow
856 multiple concurrent runs of the regression tests.
858 kes Fix race condition that drops final block written to volume.
859 This happens in rare cases with multiple simultaneous jobs
860 when the Volume fills. This fixes bug #964. May be related
861 to bug #935 and possibly #903.
862 kes Eliminate more strerror() and replace with bstrerror().
863 kes Remove BSD getopt and replace with unrestricted IBM version.
864 kes Fix Win32 build for changed calling sequences.
865 kes More tweaks to the mount volume routines to get everything
866 right. Changed variable name from find to have_vol, which is
867 much easier to understand.
868 kes Enhance btimer debug code.
870 kes Fix FD->SD authorization failure, which was due to spurious
871 wakeups from a pthread_cond_timedwait(). Simply check the
872 predicate before continuing. This fixes bug #953.
873 kes Add const char where needed (more to do). Remove temp debug code.
875 kes Setup SQLite busy handler before doing queries. Fixes bug #967.
876 kes Don't overwrite error message in check_tables_version.
878 kes Unlock batch insert tables with same calls used elsewhere.
879 kes Allow starting 59 jobs a second.
880 kes Make SD session key more random.
881 kes Add retry for SQLite opening db if it fails. Probably helps
883 kes Suppress extra error messages during batch insert failure.
885 kes Add jcr to timer packets so if killed message can be sent to job.
886 kes Add JobId to all Dmsg() output.
887 kes Put some FD auth code on dbglvl rather than fixed.
888 kes Return insert attributes error message in db msg buffer to avoid
889 false error messages. Helps fix bug #966.
890 kes Separate batch init error messages. Probably helps fix bug #966.
891 kes Make SD code that contructs attribute insert check string lengths
893 kes If Dir gets an error during inserting attributes, cancel SD.
894 This reduces unnecessary error messages.
896 kes Correct search boolean for getting Volume info
897 ebl Cleanup batch insert code. Probably fixes bug #965.
898 kes Back out one small change to the reservation system (reserving a volume).
899 kes Rework how a Volume is mounted. It is now much more intelligent and
900 will always attempt to use any mounted volume if possible and reduces
901 calls to the Director asking about volumes.
903 kes Turn off some code when batch insert not enabled.
904 kes Edit FD name in connect error messages.
905 kes Rework the reservation system to take into account that the Director
906 might give us a Volume that is different from the current one being
907 used, and to ensure that we don't exceed Maximum Volume Jobs.
908 This fixes (mostly) bug #947 ' Maximum Volume Jobs = 1 produces
909 fatal error with multiple jobs running'
910 kes Add more debug code in reservation system.
911 kes Implement maxvol-test to check bug #947.
913 kes Add code to handle tray monitor separated from Win32 FD.
914 kes Fix display of Win32 tray monitor after reboot. Fixes bug #952.
916 kes Add missed return in fixing verify bug -- trunk only.
917 ebl Fix a command parser issue causing a director segfault.
918 kes Fix ANSI tape labeling. Fix restoring ANSI labeled Volumes.
920 kes Increase the max block size to 4MB fixes bug #957.
921 kes ERABT if user sets min block size > max block size. Fixes bug #956.
922 kes Apply 2.2.4-poll-mount fix, that resolves bug #908 where a tape
923 is not properly mounted (recognized) during a poll.
924 kes Apply 2.2.4-verify patch that resolves bug #958. A Verify catalog
925 Job that has differences reports Verify OK.
926 ebl Fixes #955 bug seg fault in Dir introduced with regexwhere relocation.
928 ebl Add an option to operate on all pools with update vol parameters.
929 This complete the project 20. Patch from Nigel Stepp.
930 ebl Add history support to bconsole when using readline.
931 Using Ctrl-D to exit doesn't update .bconsole_history
932 kes Modify new volume algorithm to use max MediaId for generating next
933 volume number rather than the count of Volumes. This should essentially
934 eliminate the failure rate if some volumes were deleted. Bug #921.
935 kes Begin implemention of Optimize Job Scheduling.
936 kes Implement restore callback that Dirk and I agreed on for bat
937 restore. This fixes bug #928. Restore of backup of zero files fails.
938 kes Fix SQL Catalog logging which broke with new db_escape_string
941 Release Version 2.2.4
943 kes Fix bacula_cats.def for new db_escape_string().
944 kes Increase size of name string when FD making connection to SD.
945 May fix bug #953. FD->SD connection failure.
947 kes Add code to help Dan debug 2drive-incremental-2disk test.
948 kes Add code to try to fix bug #908.
949 kes Add waits to multiple exit detection code to try to force pid
950 file to always be deleted.
951 kes Restore good dev.tar.gz to rescue set appropriate binary property.
953 kes Fix seg fault in error exit of acquire_for_read after unsuccessfully
954 trying to switch drives by checking for blocking before unblocking.
956 kes Cancel storage daemon in all cases where FD reports error. This
957 should fix virtually all cases of bug #920.
958 kes Fix db_escape_string() for MySQL which did not compile.
960 kes Fix error message that was clobbered when Dir tells SD it does not
961 have write permission on Volume. This should fix a minor point
962 in bug #942, but not the main problem.
963 kes Add code to cancel job in SD if FD connection fails. This should
965 kes Add code in FD exit to prevent loops and a crash on FreeBSD.
966 dvl Pass jcr and db into db_escape_string() to enable better escaping
968 kes Fix migration code to get correct Volume name with multiple volumes
969 by skipping |. Fixes bug #936.
970 kes Implement patch supplied by Landon to fix bug #944 where using
971 TLS with bconsole uses 99+% of the CPU.
972 kes Note, you need GTK >= 2.10 to be able to link the Tray Monitor
974 kes Move patches into patches directory.
976 ebl Fix bug #946 about 'bacula-dir -t' which doesn't works
979 ebl Using 'm' in bconsole will show messages like before,
980 and not memory usage.
981 kes Fix bug #935, and probably also bug #903 where files were not
982 restored. MediaId was not properly set in JobMedia record after
985 kes Suppress chown and chmod error messages if the FD is not running
988 kes Apply Martin Simmons' patch that should turn off the new API usage
989 when batch insert is turned off allowing building on older
991 kes Add ./configure search in qwt-qt4 for qwt package
993 kes Bacula is now free of 3rd party GPL copyrighted code!
995 kes Add guid_to_name.c/h which replace idcache.
996 kes Remove enh_fnmatch.c. Make code that references it use fnmatch.c
998 ebl Detect if new PosgreSQL batch insert API is present.
999 kes Correct incorrect mempool call causing Director crash. Occurs on
1000 systems without va_copy().
1001 sb Update spec files for 2.2.1 release
1003 kes Fix memory pool call in ua_output.c. bug #934.
1004 kes Replace fnmatch.c and fnmatch.h by modified BSD versions.
1005 Add test program to fnmatch.c
1007 kes Integrate patch to README.vc8 from
1008 Hederer Jean-Sébastien <hedererjs@asperience.fr, had to manually
1009 edit it to get it into Unix patch format.
1010 kes Implement mkpath.c to replace old FSF makepath.c
1012 kes Implement savecwd.h and savecwd.c. Remove FSF versions.
1014 Release Version 2.2.1
1016 kes Update POTFILES.in
1017 kes Cleanup a few underquoted AC_DEFUNs in configure
1018 kes Apply patch from Martin Simmons that adds a test for va_copy to
1021 kes Fix bug #921 by increasing the number of tries to create a new volume
1023 kes Rework bmsg in ua_output to use va_copy() so that bvsnprintf()
1024 can be called multiple times. Implement a version for machines
1025 without va_copy() that gets a big buffer.
1027 kes Integrate more portable zone offset code into bsmtp.c
1028 Submitted by Attila Fülöp.
1030 kes Fix bad SD->FD return status reported by
1031 (James Harper) <james.harper@bendigoit.com.au>
1032 ebl Fix a bug in read_close_session which return random status
1033 thanks to James Harper
1035 kes Fix (hopefully) bug #930 by doing a db_escape_string() on file
1036 and directory names during restore of single file/directories.
1037 kes Add sanity checks to .sql command when string is empty. Hopefully
1038 that will resolve Dirks Director crash.
1040 kes Apply patch submitted by Martin Simmons that corrects a seg fault
1041 in the bsmtp chat subroutine when debug is >= 10.
1043 kes Fix Director crash when running bat SQL queries.
1044 kes Add David's notes on Item 8: Copy pools.
1046 kes Rework projects file to be current and ready for a vote.
1047 kes Enhance lex scanner error message.
1049 kes Tweak LICENSE file to mention BSD code.
1050 kes Fix bat.pro.in so that it includes the OpenSSL libraries only
1051 if specified on the ./configure.
1052 kes Add first (not yet tested) cut of bcomm to the qt-console directory.
1053 This class is intended to allow us to open a second bsock to the
1054 Director while in the restore subdialog.
1056 kes Fix configure to create bat Makefile before creating dependencies.
1057 kes Eliminate the egg files from the tray-monitor. Use gtk calls.
1058 kes Add a tooltip to the tray monitor.
1059 dvl Set the Director's PID file before dropping privs. This fixes
1062 kes Update AUTHORs file
1063 kes Increase the default max concurrent jobs to 20 in FD and SD to
1064 correspond with the default .conf files.
1065 kes Rewrite the Win32 service routines. This eliminates the 3 copies
1066 some different, of the same file created by RN when porting the
1068 kes Rearrange some of the Win32 directories and the placement of the files
1070 kes Set DEVELOPER flag in version.h
1072 ========================================================================
1073 Release Version 2.2.0
1075 kes Apply a second doc patch from Marc.
1076 kes Apply a doc patch from Marc Schiffbauer <marc@schiffbauer.net> that
1077 improves the tips section that discusses how to setup multiple
1080 kes Update bat README file.
1081 kes Apply patch from Allan Black <Allan.Black@btconnect.com> that
1082 corrects a typo in the Recycle status check in db_find_next_volume().
1083 This will probably fix a number of annoying problems with multiple
1085 kes Modify most of dird/msgchan.c to use bsock class calls rather than
1086 bnet calls -- no functionality change.
1088 kes Modify the Verify output to specify if files are missing on
1089 the Volume(s) or disk. Fixes confusion in bug #916.
1090 kes When more than one Volume is read in a migration job, the last
1091 Volume bytes reported are from the last read volume rather than
1092 the last written volume. Fixed. This fixes bug #910.
1093 kes Fix display of Recycle flag after update volume=foo recycle=yes.
1094 It previously printed New Recyle flag is: no. This fixes bug
1097 kes Correct seg fault when switching tape drives during restore.
1098 kes Commit uid_gid_name.c (replacement for idcache.c), but will not
1099 be used until after 2.2.0 release.
1101 kes Remove fnmatch() in SD that permitted wild card specifications.
1102 This fixes bug #914.
1104 kes Fix %g in filename returned by SQL for browse tree reported by
1106 kes Fix configure so that it puts config.out in the cwd rather than
1108 kes Attempt to fix the locking problem reported by Eric in bug #906.
1109 kes Make berrno class to leave errno unchanged after constructor call.
1110 kes Make bnet_server use the heap rather than the stack to allocate
1111 its socket fd pointers to avoid a crash at termination. Problem
1112 reported by Ryan Novosielski and bugs pointed out by Martin Simmons.
1114 kes Create new depkgs and depkgs-qt separating the qwt out of depkgs
1115 and putting it in depkgs-qt along with Qt4.3.
1117 kes Rework code in acquire.c that switches drives for reading when
1118 the Media Type does not match. This should fix bug #906
1120 ebl Fix a director segfault during job setup #907
1121 kes Correct seg fault in postgresql when first operation returns no
1122 rows. Fixes Dirks File browser problem seg fault with bat.
1124 kes Apply patch from Felix Schwarz <Felix.Schwarz@web.de> that allows
1125 building wxconsole on Fedora 7 with wxWidgets 2.8 (it works with
1128 kes Implement PopUp YES/NO dialog for bat.
1130 ebl Fix a compilation bug when using #define BACL_WANT_NUMERIC_IDS
1132 kes Correct RunScript to terminate job in FD on failure.
1133 kes Change abort_on_error and AbortJobOnError to fail_on_error
1134 and FailJobOnError in RunScripts.
1135 kes Minor tweaks of code formating in RunScripts, principally to
1136 avoid depassing 80 columns.
1138 kes Eliminate one #ifdef Win32 in bsmtp
1139 kes Implement grow tool to grow a file for testing very large databases.
1140 kes Add big-vol-test to test Bacula seeking with > 5GB.
1143 kes Modify find_next_volume() to return all values in Media record.
1144 kes Ensure that we keep Recycle Pool when moving Scratch volumes.
1148 kes Update Release notes
1150 ebl fix a bug in get_scratch_volume() report by Andreas Helmcke
1151 Warning, in previous beta version, all media get from scratch keep their
1154 kes Tweaked Win32 installer to remove temp conf files at uninstall time.
1155 This should fix bug #842. Made a note to look at removing the temp
1156 files at the end of the install.
1157 kes Add ability to mount and unmount a file device providing it is
1158 marked as being removable and has the appropriate mount and unmount
1159 commands defined in the Device resource. This fixes bug #830.
1160 kes When applying a storage override, release all previous storage
1161 definitions rather than just prepending the new storage.
1162 This should prevent a good deal of confusion.
1164 kes Implement ./configure search for qwt libraries.
1166 kes Disable posting the WM_CLOSE message in KillRunningCopy of the
1167 Win32 FD. This should fix bug #893.
1168 kes Remove an unnecessary beep in Win32 init code.
1169 kes Update copyright dates in Win32 executable about boxes.
1170 kes Replace the FSF copyrighted getopt.c and getopt.h in the Win32
1171 code with a BSD getopt.c and getopt.h.
1172 kes Remove sched.h from the Win32 compat directory -- not used.
1173 kes Remove the Exit menu item from the Win32 tray monitor. If you really
1174 need to shut it down, do it through the services panel or the command
1176 kes Remove some inappropriate Bacula FSFE copyrights.
1177 ebl Tweak status client=xxx to be more easy to parse (more like in 2.0.x)
1178 kes Fix regress config non-portable test as pointed out by
1179 Florian Heigl <florian.heigl@gmail.com>
1180 kes Fix PSCMD for HP-UX in configure.in to have proper syntax.
1181 as pointed out by Florian Heigl <florian.heigl@gmail.com>
1183 kes Fix missing rctx. prefixes on the Darwin code in src/filed/restore.c
1184 Reported by Frank Sweetser.
1188 kes Fix client-only build.
1189 kes Integrate client-only fixes for bsys (initgroups) and conio from
1190 Sergey Svishchev <svs@ropnet.ru> for the AIX platform.
1191 kes Make arguments to get_scratch_volume() in same order as other
1193 kes Rework the prune_volumes() subroutine so that after purging and
1194 no volume found in desired pool, it will check for a scratch
1195 volume. This prevents recycling the whole scratch pool.
1196 kes Add code to status storage to print boffset_t (largefile support).
1198 kes Move qwt (Graphics libarary for Qt4) to depkgs.
1199 kes You now need a --with-qwt=<dir> to be able to build bat.
1200 kes Update src/win32/cats/bacula_cats.def to include the new
1201 db_get_query_dbids() call on Win32.
1203 kes Correct a problem when selecting a scratch volume and moving
1204 it to another pool that lost some columns.
1205 kes Tweak some code in ua_update.c to use POOL_MEM instead of POOLMEM.
1206 kes Enhance Autochanger error messages to include Volume and device name.
1207 kes Rework prune_volumes() code to take account of InChanger flag,
1208 and to handle recycling volumes going to the Scratch pool and
1209 current pool because the RecyclePool directive.
1210 kes Implement a better and more efficient db_get_query_dbids() to
1211 handle creating and passing back a list of DBIds.
1215 kes Start work on new more efficient DBId subroutine. First use
1216 will be for recycling volume to Scratch inchanger.
1217 kes Increase number of JobIds in pruning from 1000 to 10000.
1218 This to be replaced by above routine.
1219 kes Begin implementation of building Qt4 on Win32.
1220 kes Correct typo in fix I added for bad TLS shutdown.
1221 kes Pull 2.0.3 patches into patches directory.
1222 kes Update Release notes. Include qt-console in line count.
1223 kes Update Projects file.
1225 kes Integrate patch from Sergey Svishchev <svs@ropnet.ru> that fixes
1226 bug in migration code where a job that spanned two volumes
1229 kes Implement new BST_DESPOOLING blocked state. Change from locking
1230 during despooling in SD to blocking. This means that other threads
1231 can work with the device structure, in particular the reservations
1232 system while despooling.
1234 kes Fix return in reservation message queue that missed clearing
1235 the jcr lock (implemented 26Jun07 below).
1236 kes Rename a number of dev methods to make locking function names
1238 kes Document locking in lock.c. Move lock structures to new file
1241 kes Move reservations message lock to lock jcr only this
1243 kes Move main SD locking code into lock.c (new file).
1244 kes Update Win32 build to include lock.c
1248 kes Dirk committed the qwt library code for drawing graphs in bat.
1249 kes Tweak install of qwt so that it is integrated with ./configure.
1251 kes Fix HAVE_BATCH_INSERT to be HAVE_BATCH_FILE_INSERT, pointed
1252 out by Eric (my typo).
1253 ebl Fix configure.in to get batch mode enable
1254 kes Return correct string from authenticate.cpp in bat when connecting
1256 kes Apply patch suggested by Frank Sweetser to fix bug #888 --
1257 spurious line drops when using TLS.
1258 kes Do not file reparse points when restoring a file that already
1261 kes Implement Windows reparse points -- similar to directories, but
1262 we do not descend into it. This is a first cut. They seem to
1263 be backed up, but restore is not yet tested.
1264 kes Remove restore_blocking in tls code when shutting a socket to leave
1265 it in blocking mode. Hopefully this will fix the encryption bug
1266 reported by Frank Sweetser.
1267 kes When opening a file for backup, tell the OS that we are going to
1268 read it sequentially -- optimization.
1269 kes Change variable names in authenticate_director() to not conflict
1270 with member names in bat. Caused great confusion with compiler,
1273 kes Queue openssl error messages in case of comm problem.
1274 kes Do shutdown() call if socket terminated.
1275 kes Remove some duplicated code in tls.c
1276 kes Move more of the bsock member variables into private and access
1278 kes Add Frank Sweetser's tls-test to the regression suite.
1280 kes Add Swedish sv.po file
1282 kes Don't print clock skew message in FD if less than 3 seconds diff.
1283 kes Add a bit of VSS info to status client.
1284 kes Implement a first cut of Vista VSS, using Win2003 code.
1286 Release: 2.1.20 beta
1288 kes Fixed bug #886 (multidrive autochanger: SD doesn't use drive with
1289 loaded tape but uses first drive).
1290 kes Fixed bug #807 Restore encrypted backup failed on Windows 2003
1291 This was indeed a Win32 issue.
1293 kes Simplify search of autochanger for in-use Volume.
1294 kes Fix exit condition of check for in-use volume. kes Remove
1295 inappropriate my_postgresql_free_result() in db_close()
1297 kes Fix bad return in FD when encryption signature not found.
1298 Probably caused a crash.
1299 kes Inhibit missing encryption signature error messages for
1300 file types where no signature computed.
1301 kes Correct inverted check on autochanger in reservation system.
1302 kes Tweak debug code in autochanger reservation.
1304 kes Add some additional locking in the cats directory in subroutines
1305 that modify packet variables called from batch insert.
1306 kes Rework how dcrs are allocated. new_dcr() can now be called
1307 with an existing pointer, and it will simply clean it up.
1308 This allows the reservation system to test various different
1309 devices, and will permit easy device changes.
1310 kes A bunch of changes all over to handle new new_dcr() calling
1312 kes Work more on the Volume management in the SD. Remember Volumes
1313 for tape drives and for autochangers (even virtual disk changers).
1314 kes When looking at the Volume list to reserve a drive, handle
1315 autochanger names correctly by interating through the changer
1316 devices. Also call the Director to see if a Volume is suitable
1317 for the current job.
1318 kes Fix some bugs in bscan. Make sure all media records are written.
1319 Make sure that valid JobMedia records are written for disk files.
1320 Previously they were completely wrong.
1321 kes Move source tar files for depkgs-mingw32 to www.bacula.org so
1322 that the URLs don't change and so that the developers will all
1323 work off the same copy. Rebuild from scrach.
1324 kes Upgrade Win32 SQLite3 from 3.3.8 to 3.3.17.
1326 Release: 2.1.18 beta
1328 kes Fix seg fault in FD from incorrect digest size.
1329 kes Fix argument to non-OpenSSL crypto.c subroutine.
1331 Release: 2.1.16 beta
1333 kes Remove a few malloc()s from the encryption code.
1334 kes Use the class calls to bsock in filed/backup.c and restore.c in
1335 place of the old bnet_xxx code.
1336 kes Implement code that does an on the fly calculation of the
1337 signing digest during restore of encrypted files. It makes
1338 a best guess at the algorithm, and if it is not correct, will
1339 then revert to the old code which reads the file after it is
1341 kes Implement at least one missing crypto stream in stream_to_ascii()
1342 kes Apply patch from William <chowmeined@gmail.com> that fixes bug
1343 #877 where a reload with bad syntax causes Dir to exit.
1345 Cut: 2.1.14 beta (not released)
1347 kes Do not free a volume on a tape drive until another volume is
1348 mounted and read, or the autochanger unloads the volume.
1349 This should help the SD re-use volumes that are already mounted,
1350 and should fix bug #886.
1351 kes Apply patch from user brettedgar that allows gnome2-console include
1352 the OpenSSL libraries, and hence work with SSL. Fixes bug #885.
1353 kes Apply patch from Lucien Weller that fixes day of week calculation
1354 because of DST flag problem. Fixes bug #887.
1356 kes Move find_next_appendable_volume() to after acquiring a valid device
1357 in reserve.c. This fixes bug #864 -- confirmed by reporter.
1359 kes Unable to reproduce bug 872. However added additional testing for
1361 kes Bug #874 resolved by documenting SQLite limitations.
1362 kes Bug #882 resolved by documenting mtx-changer script for new drive code.
1363 kes Bug #881 resolved by removing typo in mtx-changer script.
1364 kes Made Frank Sweetser's wiki the official Bacula wiki with his
1365 approval. Added a link to the wiki on the web page, and implemented
1366 a backup from http://paramount.ind.wpi.edu
1368 kes Fix update allfrompool to pass pool name.
1370 kes Convert to pure GPL v2 license.
1371 kes Fix sscanf problems reported by Peter Buschman that caused
1372 a bus error on Solaris.
1373 kes Rework (simplify) the select prompt in bat.
1374 kes Move get_jobid_from_tid() into lib and create a
1376 kes Use get_jcr_from_tid() to conver all tls Emsg() to Jmsg(). This
1377 should definitely fix the problem of lost error messages in the
1379 kes Remove over zellous addition of FSFE copyright in a few eggxxx files.
1380 kes Eliminate tcpd.h from the project. Enclose the #include from the
1381 library with extern C ...
1382 kes Add print of signal name when a signal is trapped.
1384 Release: 2.1.12 beta
1386 kes Fix a seg fault in the PostgreSQL driver dereferencing a NULL pointer.
1388 kes Implement SQLITE3_INIT_QUERY in version.h that can do an initial
1389 query for SQLite3. Use it to set PRAGMA synchronous = OFF. This
1390 makes SQLit3 run 30 times faster, though a bit less safe.
1391 kes Implement --with-batch-insert in configure and detection of thread
1392 safe libraries. It is on by default, but turned off if no thread
1393 safe library (e.g. SQLite 2) is available.
1395 kes Fix Bacula PostgreSQL buffer overruns.
1396 kes Do better checking for NULL results returned from PostgreSQL;
1397 implement retry for failed queries; clear results buffer after
1398 failed query. Hopefully this will correct the PostgreSQL failures.
1400 kes Implement algorithm to handle only one appendable volume with
1401 Prefer Mounted Volumes = no.
1402 kes Fix a Bacula PostgreSQL bug dereferencing a NULL pointer
1403 returned from a query.
1404 kes Make volume lock recursive.
1405 kes Implement an additional volume reservation algorithm that
1406 starts by considering all reserved volumes then uses the
1407 old brute force algorithm of searching the resources to
1408 find a suitable device.
1409 kes Add new reservations debug code and refine the old code.
1410 kes Update the win32/dll/bacula.defs file.
1412 kes Tweak reservations algorithm to permit a few more cases, i.e.
1413 volume reserved, but on different drive, ...
1414 kes Enhance SD status to include Pool and Media Type for drive in a
1415 more readable format (a bit longer).
1416 kes Fix PostgreSQL double free.
1418 kes Minor refactoring of restore decryption code.
1419 kes Add code to smartall.c to detect double free of a buffer.
1421 kes Add < > around %r in from field on mail command of bacula-dir.conf.in
1422 so that bsmtp will create a correct email address (mailbox only).
1423 kes Modify 'memory' command so that the buffers are listed as 'In use'
1424 to avoid confusion with Orphaned buffers.
1425 kes I reworked the OpenSSL include/lib flags to be handled in
1426 the standard Bacula way, which should fix bug #863 concerning
1427 non-standard OpenSSL libraries.
1429 kes Implement Help Browser window for bat.
1430 kes Fix reload bug that reset StorageId to zero.
1432 kes Fix TLS #ifdefing when TLS turned off.
1433 kes Ensure that when labelling a tape with Slot=0 that InChanger
1435 kes Use DISTINCT to make MySQL and PostgreSQL uar_list_temp query
1437 kes Add StartTime to final uar_sel_jobid_temp query so that we can
1438 add DISTINCT (required by PostgreSQL).
1439 kes Implement BSOCK authenticate_director() method. Eventually will
1440 authenicate all daemons.
1441 kes Move several more functions into the BSOCK class.
1443 kes Add code to tell the OS that we no longer need a cached
1444 file that we were reading. In findlib/bfile.c. Also,
1445 only cache files that we are reading. Thanks to
1446 Tobias Oetiker <tobi@oetiker.ch> for the idea.
1447 kes Tweak to bsmtp to eliminate compiler warnings on Win32.
1448 kes Implement script to automatically generate cats and dll .def
1449 files for Win32 dll.
1450 kes Update README.mingw32 to include new .def file generation.
1451 kes Correct typo in UTF-8 error message as reported by:
1452 jhernandez <julianhernandez@gmail.com>
1453 kes Add additional sm_check() code on debug level 1.
1454 kes Set default debug level to 1.
1455 kes Trap SIGABRT in attempt to get traceback.
1457 kes Reduce bat connect timeout from 30 to 15 seconds.
1458 kes More restructuring and implementing BSOCK class in place of
1460 kes Remove a few unnecessary malloc() tests in crypto code.
1461 kes Turn off crypto calls for > 128 bits in crypto.c if HAVE_SHA2
1462 not defined. Bug reported by Allan Black <Allan.Black@btconnect.com>
1463 kes Remove duplicate HAVE_CRYPTO definition in config.h.in
1465 kes Fix Verify InitCatalog mysql_escape_string() trashing memory.
1467 kes Fix Verify InitCatalog. The attributes were not pointing to the
1468 correct saved location.
1469 kes Implement message callback so that GUI is sure to get all
1470 daemon messages. Currently displayed in a dialog in bat.
1471 kes Ignore SIGUSR2 (Bacula timer) in bat.
1472 kes Apply regress patch from bug #859 to allow regress to work
1473 with Solaris compiler.
1475 kes Begin adding TLS support to bat.
1476 kes Apply UTF-8/16 patch from Yves Orton <demerphq@gmail.com> to
1477 clean up lex.c and make it more readable.
1479 kes Move more bnet functions into the BSOCK class.
1480 kes Fix tray-monitor by not requiring a timer interval in bnet_connect()
1481 kes Complete change of berrno strerror() method to bstrerror()
1483 Release: 2.1.10 beta
1485 kes Cleanup incorrect email addresses in bsmtp.
1486 kes Make bat display initial messages rather than discard them.
1488 kes First cut of adding .mod to the run command.
1489 kes Implement auto display of messages in bat.
1490 kes Enhanced preferences to allow all Bacula output to be
1493 kes Try to make bsmtp date routines more generic.
1494 kes Fixed bug #856 autochanger documentation.
1495 kes Rework bsmtp date editing for Win32. This fixes bug #854.
1496 kes Add new cats entry point so Win32 builds.
1498 kes Attempt to fix bsmtp date editing on OSes without %z editing.
1500 kes Do better checking for the MySQL 64 bit libraries looking for both
1501 .a and .so libraries.
1502 kes Add a kludge for Ubuntu's non-standard locations for MySQL -- allow
1503 /usr/include/mysql/mysql.h AND /usr/lib/... rather than /usr/lib/mysql/...
1504 kes Require the thread safe version of MySQL during configure. Thanks
1505 to Andre Noll for pointing this out.
1506 kes Ensure that calls to find_jobids_from_mediaid_list() check count before
1507 continuing in migration code.
1508 kes Apply implementation of tray-monitor font derived from gnome-console
1509 submitted by Andreas Piesk <a.piesk@gmx.net>
1511 kes Eliminate important memory loss in SQLite
1512 kes Fixed the batch insert MySQL thread specific data that was not
1513 being freed. See cats/mysql.c:db_thread_cleanup().
1514 kes Fix restore before command.
1515 kes Convert old hdr.name to name() in a few places.
1516 kes Implement update jobid command.
1517 kes Return all time_t dates in db_get_job_record()
1518 kes Stop watchdog in SD earlier.
1519 kes Put Pool just after Storage in please mount message.
1520 kes Fix pointer usage bugs in Verify InitCatalog pointed out by
1523 kes Update the po files.
1524 kes Fix Verify InitCatalog by making it cache attributes.
1526 kes Change name bacula-bat to bat for man 1 page to correspond to
1528 kes Check for client and store NULL pointers in status command. This
1530 kes Fix non-ssl build so that it works (add JCR *jcr to crypto structures).
1531 kes Fix sign extended editing of %p.
1532 kes Clean out a little old #ifdefing in cats/mysql.c
1534 kes If time diff between DIR and FD is more than 600 seconds convert
1535 INFO message to WARNING.
1536 kes Implement heap size display in status for all daemons.
1537 kes Attempt to fix MySQL db open memory loss (not successfull).
1538 kes Don't set SIGKILL and SIGSTOP neither can be trapped.
1539 kes Eliminate memory loss in MySQL (possibly other SQLs) during
1540 Query. This looks like a MySQL but but by doing extra releases,
1541 the memory goes away. This should fix bug #847.
1543 kes When backup fails, cancel SD before waiting for sd termination.
1544 kes If SD is waiting for FD to connect during cancel, wake up the
1546 kes Fix fsf code so that errno is correctly reported.
1547 kes Apply migration patch (with changes) from Sergey Svishchev <svs@ropnet.ru>
1549 kes Make lack of Pool directive in Job an ERROR_TERM rather than FATAL
1550 so that Bacula doesn't later stumble into a seg fault.
1551 kes Use the term Restore Client in the restore Job report.
1552 kes Merge patch from Sergey Svishchev <svs@ropnet.ru> that preserves
1553 the original job's FileSetId.
1554 kes Merge patch from Sergey Svishchev <svs@ropnet.ru> that implements
1555 spooling in migration jobs. Not yet tested.
1556 kes Merge patch from Jorj Bauer <jorj@seas.upenn.edu> that implements
1557 reading conf file from a pipe. However, do it with open_bpipe()
1558 rather than popen. Not yet tested.
1560 kes Fix an ugly bug where the VolCatBytes were getting updated
1562 kes Implement bconsole memory command that prints current memory
1563 usage, plus smartalloc dump.
1564 kes Clarify some error messages in backup, admin, and migrate.
1565 kes Shrink label dialog to smaller size.
1566 kes Invert Cancel OK buttons on restore to be OK Cancel.
1567 kes More strerror() to bstrerror() conversions.
1569 kes Start implementing bstrerror() in place of strerror().
1570 kes Stripping path -- seems to work.
1572 kes Prevent door and port files from being restored (mostly
1574 kes Free an unreleased buffer in compat code.
1575 kes Change console Job name from *Console* to -Console- to eliminate
1576 Win32 filename problems. Put Win32 path separator when creating
1577 Console file. This fixes bug #846.
1578 kes Change berrno::strerror() to berrno::bstrerror(). Not yet full
1580 kes Pass jcr to crypt_sign_decode because it creates a new SIGNATURE
1582 kes Define b_errno_win32 on Linux to be zero so that it can be or'ed in
1583 to force Win32 error message.
1585 kes First cut strip path. The data should be passed to the FD,
1586 but nothing is done with it yet.
1587 kes Enhance the digest and signature routines in the crypto
1588 library to accept a JCR and to use it to print error messages
1589 so that they will go in the Job report rather than the daemon's
1591 kes Simplify some of the verify signature code.
1592 kes Simplify a few of the alternative returns in the signature
1595 ebl Use only POSIX regex instead of GNU regex in breg.c for
1596 File relocation. It fix broken freebsd compilation.
1597 kes Convert all other Dir files to use new ua class message
1599 kes Tentative fix for missing digest signature in bug 807.
1600 kes Correct handle problem in new win32_ftruncate routine.
1601 kes Convert ua_purge.c and ua_update.c to use new ua class
1602 message routines for bat.
1604 kes Correct incorrect installation of LICENSE in Win32 installer.
1605 kes Display LICENSE at the beginning of the Win32 install.
1606 kes Attempt to correct the need for the png files to be installed
1608 kes Reapply my bat.conf install script in qt-console. I think I
1609 editted bat.pro instead of bat.pro.in and it was lost.
1610 kes Apply CentOS patches someone sent me. Checks for /var/run/subsys,
1611 the /var/lock/subsys for subsysdir. Also corrects typos in the
1614 kes First cut update job.
1615 kes Correct configure to include qmake of src/qt-console directory.
1617 kes Make restore job yes/mod/no print in one command so GUI works.
1618 kes First cut implementing backup and restore client.
1619 kes Correct editing in Verify output that caused a seg fault.
1621 kes Insure that bat.conf is not overwritten during installation.
1622 kes Fix important bug in db_sql_query() in mysql.c. It was introduced
1623 while I was implementing migration in March 2006 !
1625 ebl Cleanup file relocation, using char *RegexWhere instead of
1626 char *where + bool where_use_regexp
1627 kes Update some manpages and add bat manpage.
1628 kes Make a first cut at converting bacula.spec.in for bwx-console
1630 kes Apply patch from John Goerzen to add hostname as fourth argument
1631 to make_catalog_backup script.
1632 kes Fix typos I introduced into bsmtp.c
1633 kes Make pm_strxxx() routines handle input of NULL pointer. This
1634 is to protect from NULL pointers returned from SQL databases.
1635 kes Correct typo in bacula-sd manpage as pointed out by John Goerzen.
1636 kes Add more debug to FIFO code -- fix fifo regression test.
1638 kes Implement posix_fadvise in FD, and for reading spool files in SD.
1639 kes Add thread timer to bnet_connect() to break from OS if wait time
1642 kes Update Win32 build to include new files, new symbols, and
1644 kes Implement socket level heartbeat (tcp_keepidle)
1645 ebl Commit File relocation patch
1646 kes Make bat have 'make install' target.
1647 kes Warn during install if old gnome-console binary found.
1648 kes Warn during install if old wx-console binary found.
1649 kes Add -8 option to bsmtp command line to add content type utf-8.
1650 Fixes bug #809. (Character coding problem in bsmtp).
1651 kes If < is found in target (from, to, cc) then do not enclose the
1652 target in < > in bsmtp. Fixes bug #772 (malformed address).
1653 kes When printing certain items in dbcheck, stop after 300000.
1654 Fixes bug #822. (dbcheck loops).
1655 kes Incorrect status in Dir after waiting for mount with poll set.
1658 kes Extend idea of Prefer Mounted Volumes to mean a volume about
1660 kes Print waiting to reserve a device every 5 mins.
1662 kes Don't call close_part in label.c if tape and relabel.
1663 kes Don't free volume if busy in close() -- should help with
1665 ebl Fix #824 RunScript bug (After script could be execute twice)
1666 Now, Before Script can use RunsOnSuccess and RunsOnFailure options
1667 By default (like before) RunsOnSuccess=true and RunsOnFailure=false
1668 Add a regression script to test RunScript
1670 kes Correct usage of MTIOCLRERR ioctl for clearing persistant errors
1673 kes The bgnome-console (gnome-console) and bwx-console (wx-console) are
1674 deprecated. No additional bugs will be fixed, and they will be dropped
1675 in a future release (probably 2.4.0).
1676 kes Change name of wx-console to bwx-console to make it more Bacula
1678 kes Change the name of gnome-console to bgnome-console to make it
1681 kes Some time in March, a Feature Request with patch from Jorj Bauer
1682 <jorj@seas.upenn.edu> was committed by Landon (with my approval).
1684 The ability for the director to validate a Client (FD) CN against
1685 an arbitrary set of patterns rather than the hostname, with
1686 A new 'TLS Allowed CN' set of directives which are implemented
1687 in the Client resource. Then pattern matching is used in place
1688 of hostname matching against the Certificate's CN. As an example, we
1689 have certificates which (a) use a local CA, and (b) have a CN of the
1691 kes Add new/changed entry points to Win32 build
1692 kes Create unaccepted-projects for projects that are not accepted.
1693 kes Simplify locking in the reservations system.
1694 kes Add more debug code in reservations.
1695 kes Make sure error condition on reserving a volume is handled correctly.
1696 kes Correct handling of volume_in_use.
1697 kes Correct handling of initializing a device.
1698 kes Move handling of broadcasting releasing a device into release_device().
1699 kes Correct attaching dcr to dev so that it is only done if device
1700 is properly initiated.
1702 kes Locking debug level tweaks in SD.
1703 kes Tweak new Volume code.
1705 kes Add exec external-command [wait-seconds] to bconsole. This
1706 executes the external-command. Note! normally external-command
1707 should be enclosed in double quotes.
1708 kes Turn the .die command on only if DEVELOPER is defined -- i.e.
1709 it should normally be off in a production system.
1711 kes Implement die command for SD so that we can force it to dump.
1712 kes Implement SD lock debug code.
1713 kes Implement new algorithm for keeping Volume list in SD. It
1714 is now owned by the device.
1716 kes Implement new code for freeing in use volumes that should
1717 resolve if not all, some of the problems of multiple drive
1718 tape conflicts described in bug 801.
1720 kes Fix gui/bacula-web/images files in svn.
1721 kes Turn on FreeBSD/OpenBSD code to set EOT model on tape.
1723 ebl Fix a bug in batch mode (in string escape)
1724 kes Correct migration prune SQL typo that crept in in a
1725 recent 2.1.x change.
1727 kes Move bnet_despool() into class in bsock.c
1728 kes Modify job report to include director name and Build OS.
1729 kes Move drop root privilege and check_catalog() before fork.
1730 kes Add update database scripts (version 9 to 10) to updatedb directory.
1732 ebl Check size and age of each file after its backup to see if
1733 it has changed during backup, if 'checkfilechanges' is set.
1734 The FD will do an extra check (stat(2)) after
1735 each file backup. mtime, ctime and size are compared with
1736 'before backup' information. If time or size mismatch, an
1737 error message will be generated. You must upgrade FD to use it.
1739 kes Make database name and user configurable
1740 --with-db-name=xxx --with-db-user=xxx
1741 kes Add back database type to message.c for debugging.
1743 kes Implement dir_sql() which issues an SQL query.
1744 kes Modify bat medialist to use dir_sql() and do some minor C++
1745 formatting as well as eliminating a number of pointers, simplifing
1748 kes Fix some of the mtx-changer grep commands for tape label readers.
1749 kes Convert a number of bsendmsg into the appropriate send/warning/error
1750 message class calls.
1751 kes Suppress the using database message in the .sql command.
1752 kes Correct an incorrect bnet_tls_client prototype -- patch from Martin.
1754 kes Add context menu for floating a window.
1755 kes Some minor cleanup and name changes in qt-console
1756 kes Add doing mt setblk 0 in Win32 mtx-changer.
1757 kes Apply Martin's bug fix to move definition of ENODATA for
1759 ebl Add a BUSY handler to sqlite to be able to use multi_db = 1 with
1760 sqlite2 and sqlite3.
1762 kes More pruning cleanup.
1763 kes Turn on wait_for_drive by default in mtx-changer.
1764 kes Turn on Batch insert code by default as it now passes regression.
1765 kes Add ./configure --enable-bat to enable building of Bat.
1766 No install yet though.
1768 kes Implement a new .sql command for bat.
1769 kes Implement code to turn off pruning in obtaining the next volume.
1770 Pruning is turned off for the status dir command, but turned on
1771 for SD requests and for the list nextvolume command.
1773 kes Correct Qmsg() that was not updated correctly when committing a
1774 previous change (probably the recent TLS patch).
1776 kes Write new subroutine is_volume_purged() that explicitly checks
1777 if the Volume is purged, and if so marks it as such. This should
1778 resolve problems reported about needing to mount twice to recycle
1780 kes Rewrite pruning algorithm to do more work in the SQL engine, and
1781 to pass a list of JobIds to be deleted to SQL. Also, minimize the
1782 amount of duplicated code.
1783 kes Do volume pruning only for the Media Type desired (reduces pruning time
1784 if multiple Media Types are in the same pool).
1785 kes Implement more detailed info in the Job report for the Bacula version
1787 kes Switch from POOLMEM to POOL_MEM (a real class) in ua_prune.c and
1789 ebl Add bbatch tool to bench database and insert mode.
1790 Fix sql quote stuff in batch mode
1791 Fix sql stuff for mysql
1793 kes Correct problems with am/pm scheduling. Fixes bug #808.
1794 kes Implement new prunning code that prunes up to 1000 jobs at
1795 the same time. The same technique can be applied to a number
1796 of other prune/purge subroutines.
1797 kes Add an insanity check when starting a new tape job to ensure
1798 that the tape position has not been changed. If so fail the
1800 kes Fix Win32 build for dlls to add the folllowing:
1801 src/lib/bsock.c -- new file with new entry points
1802 src/lib/dlist.c -- new entry points
1803 src/cats/sql_create.c -- new entry point
1804 src/cats/sql_cmds.c -- new DATA item exported
1806 ebl batch mode cleanup bscan-test is ok now.
1807 kes Implement SD code to check length of disk volume before appending.
1809 kes Correct return status on db_batch... routines.
1810 kes Add call to db_write_batch_file_records() to migration code.
1811 ebl Fix AfterJob timing
1812 kes Move the checking of the database in initializion of the Director
1813 to after we drop privileges. This avoids the need for both root
1814 and bacula access to the DB.
1815 kes Correct a misplaced variable definition in src/filed/backup.c
1816 kes Correct how the new batch insert db_create_attributes_record()
1817 uses the arguments. Caused a seg fault in bscan.
1818 kes Implement lock() and unlock() methods in DEVICE class.
1819 Implement block() and set_block(xx) methods in DEVICE class.
1820 kes Modify bnet_connect() so that it uses time() to check for the
1821 wait time expiring (on some OSes, some system calls may not
1822 return immediately).
1823 kes Modify Verify to obtain the previous JobId when it is actually
1824 running rather than at schedule time (as it was in 1.38.x).
1825 kes Fix src/job.c to handle MaxWaitTime correctly. This should
1827 kes When checking pid in pid file, continue running if the pid is
1828 the same as ours. This occurs on IRIX after a system crash.
1831 kes Extend new GUI API.
1832 kes Make the ua structure a class, and implement send_msg(),
1833 error_msg(), warning_msg(), and info_msg().
1835 kes Apply fix from for building wx-console on the Mac from
1837 kes Implement new select mechanism for GUI programs.
1838 kes Reorganize initialization of stackedWidgets in bat.
1840 kes Add updated nagios plugin supplied by Christian Masopust.
1842 kes More bat implementation.
1843 kes File migrate bug with Pool Occupancy using mediaid instead
1844 of jobids. Fixes bug #795.
1845 kes Fix orphaned buffers in filed backup and verify due to
1846 crypto buffers not freed during errors. Fixes bug #789.
1847 kes Extend new GUI api code to tree commands.
1848 kes Ensure that tree and dot commands check console ACLs.
1849 kes Permit marking directory with trailing slash.
1850 kes Allow 20 console connections (instead of only 10).
1852 kes Add smartctl call to bacula-sd.conf as an example of getting
1855 kes Modify jobq.c to let simultaneous restore jobs run. This may
1856 cause them to fail if they cannot get a drive.
1857 kes Add Client Connect Wait to Storage daemon to permit users to
1858 modify the time the SD waits for a FD connection.
1860 kes Correct virtual changer check which was backwards. This caused
1861 volumes to be unloaded into slots already occupied.
1863 kes Apply Command ACL filter to JobId list in restore command.
1864 kes Correct typeo in var.c patch.
1866 kes Don't let Bacula prune File or Job records for the current Job.
1867 kes Fix variable substitution pad + inc bug reported (with patch)
1870 kes Correct SQLite log table index as reported by Luca Berra.
1872 ebl fix fifo stuff, bacula tries to rewind the fifo... Thanks to Andreas
1874 kes Begin implementing new comm signals for API.
1875 kes Fix a few places in lib/message.c where the open fd may
1877 kes Continue implementing lib/bsock.c (real class). Make jcr,
1878 who, host, and port private. There are new methods to access
1879 them for non-class use. This required touching a number of files.
1881 kes Add LANG=C to autoconf/randpass so it works with languages other
1882 than English. Fixes bug #788.
1884 ebl Revert ClientRunBeforeJob to old position as in 1.38.X.
1886 You will not be able to generate Include/Exclude list any more.
1887 It will be fixed soon.
1888 If you want to use this, you can apply
1889 trunk/bacula/patches/testing/clientrunbeforejob_can_generate_include_exclude_list.patch
1891 kes Restore of sockets created false error messages because Bacula
1892 no longer restores sockets, but the code was still trying to
1893 set the attributes on a non-existent file. Reported by a user.
1894 ebl finish RecyclePool feature
1895 Media will takes Pool.RecyclePool
1896 when moving from Scratch to a Pool or when user will do
1897 update volume=xxx frompool
1898 To use it, add RecyclePool = aPool to your Pool resource
1901 RecyclePool = Scratch
1905 kes Expand new BSOCK class adding signal() and new BNET signals.
1906 kes Begin enhancing the dot commands adding a new API function
1907 that returns more information and will make it easier
1908 to interface to the Director from a program.
1910 kes Make DEVICE fd private. Its new name is m_fd, and can be
1911 obtained with dev->fd() outside the class. This is the
1912 first of many DEVICE members to be made private.
1913 kes Implement Michael Renner's idea on having a virtual disk
1914 changer. I made some minor modifications (e.g. I did not
1915 implement the Virtual Changer directive, but simply set
1916 the Changer Command to an empty string.
1918 kes Implement a BSOCK send() method that writes the whole record
1919 in a single write() request rather than in two.
1920 ebl add update volume=xxx recyclepool=yyyy
1921 volume takes recyclepool from pool when using update volume=xxx from pool
1923 kes Fix encryption deblocking bug, which caused some restored files
1924 to be truncated. This fixes bug #763.
1925 kes Add FD event sequence order prepared by Eric -- for RunScripts.
1926 kes Fix 12am/pm bug as reported in bug #782 -- scheduler problem.
1928 kes Apply Eric's ClientRunScriptAfter patch to 2.0 and 2.1.
1929 ebl Use btime_t instead of uint64_t in media patch.
1931 kes Optimize the use of the database a bit in the Status dir command.
1932 Only open it when needed, ensure that if any previous database
1933 was opened, it is closed.
1935 kes Correct VolCatBytes bug from media patch.
1936 kes Apply patch from bug #612 by Rudolf Cejka to speedup pruning
1937 in the case of orphaned records.
1938 kes Modify dbcheck to handle orphaned JobMedia, Path, Filename,
1939 and File records in 300K chunks to be more efficient. This
1940 idea came from Juan Luis Frances (if I remember right).
1941 kes Apply Eric's scratch patch that moves a purged Volume to
1942 the RecyclePool. Question: how is RecyclePool set? what
1943 happens to the ScratchPool?
1944 kes Apply Eric's media patch that collects read/write media
1945 times as well as byte counts. This patch requires a
1946 simultaneous upgrade of the DIR and SD. Note, there
1947 should be some way to turn off timing. I'm not sure
1948 times are in Bacula units.
1949 kes Apply Eric's batch-insert patch.
1951 kes Update projects list.
1953 kes Implement Include/Exclude file lists in FD as dlists using
1954 the new dlistString class. This permits efficiently having
1955 large include/exclude lists and completes project Item 25.
1956 kes Fix dird/ua_cmds.c so that a cancel command checks if the
1957 console is authorized to cancel the job. This fixes bug
1959 kes Modify SD so that the VolCatJobs medium record is updated
1960 at the beginning of a Job rather than the end. This
1961 fixes bug #775 where exceeding MaxVolJobs caused jobs
1963 kes Added a mutex around getting and setting Volume information
1964 so that multiple simultaneous jobs will single thread.
1966 Switch to using Subversion
1967 kes Remove src/pygtk-console/ from configure
1969 kes Delete src/lib/btree.c from win32 build, then add rblist.c
1970 plus the entrypoints.
1971 kes Apply patch supplied that corrects debug print
1972 in canceling jobs for max run time. Supplied as
1973 part of bug #621, which was previously fixed.
1975 kes Test on job_canceled() and sd_msg_thread_done inside
1976 loop starting the message thread to avoid a race condition.
1978 kes Remove rl_catch_signal from console.c as it conflicted
1979 with the header definition. Fixes bug #765.
1980 ebl Fixes bug #766 about RunsOnClient = Yes (case sensitive)
1982 kes Clarify some stored/acquire messages to indicate if the
1983 problem is with read or append.
1985 kes Fix memory leak with storage ids in cats/sql_get.c
1986 kes Terminate watchdog earlier to avoid reference to released
1987 memory -- reported by Jason Austin.
1988 kes Move closing the database from jobq.c to the director daemon
1989 termination routine. This fixes memory leaks for shadow jobs
1990 (i.e. migration jobs).
1991 kes Free up the unique jobid chain items in migrate.c. This fixes
1992 a memory leak problem.
1993 kes Convert some ugly looking for statements to use foreach_alist
1994 in findlib/find.c. This will facilitate converting the structures
1995 to use dlist (for large include/exclude lists).
1996 kes Fix a bug in the btree.c and btree.h routines, then rename them
1997 rblist and add them to be built in src/lib. Include some new
1998 methods written by Rudolf Cejka that make the code more readable
1999 (hides some of the ugly casting).
2000 kes Add set_next() and set_prev() methods which make the code much more
2001 readable. Also add a new dlistString class that facilitates storing
2002 strings in dlists. To be used in the large include/exclude lists.
2003 kes Make some trivial modifications to lib/tree.h that use rblist
2004 rather than dlist for storing the tree links. This was suggested
2005 by Rudolf Cejka. The result of this is that the restore tree now
2006 uses red-black binary trees rather than simple linked lists. This
2007 should give rather dramatic speed improvements for directories
2008 contining large numbers of directories/files (more than 10000).
2010 kes Fix maxruntime bug #621.
2012 ebl Implement the include JobID in spool file name project.
2013 kes Reorder projects file in order determined by Jan 2007 vote.
2014 kes Implement item #12 on project list -- quick release of FD by
2016 kes Fix open of SQLite3 db where user does not have write permission
2017 so that DIR does not crash. Fixes bug #761.
2019 kes Add back missing @ in Win32 Makefile.
2020 kes Change 'Device not configured to autolabel' from INFO
2022 kes Fix jobq.c to restart failed jobs when Reschedule Times = 0
2023 which should restart an indefinite # of times.
2024 kes Fix configure --help to print --with-mysql[=DIR]. Same for
2025 other DIR specifications.
2027 rn Fix msvc build problems. Fix bacula.dll exports for msvc build.
2028 Fix path quoting in SQLite scripts.
2029 Fix problems with SHGetFolderPath.
2031 kes Create patches/2.0.1-restart.patch. Fixes bug #755.
2033 kes Fix Job restart on error bug that promotes an Inc to a Full
2034 backup. This should fix bug #755.
2035 kes Add qt-console and first cut of code.
2039 kes Fix Bacula->Documentation link on Win32 to point to index.html
2040 instead of bacula.html. Fixed bug #750.
2041 kes Return JobId in db_get_job_record() when JobId==0. This should
2043 kes Do not release source pointers when restarting a failed job.
2045 kes Add dynamic dll entry point for SHGetFolderPath to Win32 code.
2046 This *should* fix bug #747.
2047 kes Modify winbacula.nsi to substitute with g bin_dir_cmd. Should fix
2050 kes Modify USTORE constructor to set an empty store_source string,
2051 and don't copy the store_source string in a cancel. Hopefully
2052 this will fix Arno's seg fault, bug #744.
2053 kes Add back code to disable conio in configure. Fixes bug #743.
2054 kes Correct the Options scanner in the FD to correctly handle
2055 SHA1 option, which was eating the next option. Reported by
2057 kes Add code to indicate when the SD is spooling, spool wait, and
2058 despooling as requested by Alan Brown.
2060 Version 2.0.0 released: 4 January 2007