2 * Bacula Catalog Database Update record interface routines
4 * Bacula Catalog Database routines written specifically
5 * for Bacula. Note, these routines are VERY dumb and
6 * do not provide all the functionality of an SQL database.
7 * The purpose of these routines is to ensure that Bacula
8 * can limp along if no real database is loaded on the
11 * Kern Sibbald, January MMI
15 Copyright (C) 2001, 2002 Kern Sibbald and John Walker
17 This program is free software; you can redistribute it and/or
18 modify it under the terms of the GNU General Public License as
19 published by the Free Software Foundation; either version 2 of
20 the License, or (at your option) any later version.
22 This program is distributed in the hope that it will be useful,
23 but WITHOUT ANY WARRANTY; without even the implied warranty of
24 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
25 General Public License for more details.
27 You should have received a copy of the GNU General Public
28 License along with this program; if not, write to the Free
29 Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
35 /* The following is necessary so that we do not include
36 * the dummy external definition of DB.
38 #define __SQL_C /* indicate that this is sql.c */
46 /* Forward referenced functions */
48 /* -----------------------------------------------------------------------
50 * Bacula specific defines and subroutines
52 * -----------------------------------------------------------------------
57 * This is called at Job start time to add the
58 * most current start fields to the job record.
59 * It is assumed that you did a db_create_job_record() already.
61 int db_update_job_start_record(B_DB *mdb, JOB_DBR *jr)
66 Dmsg0(200, "In db_update_job_start_record\n");
68 memcpy(&ojr, jr, len);
70 if (!db_get_job_record(mdb, &ojr)) {
76 fseek(mdb->jobfd, ojr.rec_addr, SEEK_SET);
77 if (fwrite(jr, len, 1, mdb->jobfd) != 1) {
78 Mmsg1(&mdb->errmsg, _("Error updating DB Job file. ERR=%s\n"), strerror(errno));
88 * This is called at Job termination time to add all the
89 * other fields to the job record.
91 int db_update_job_end_record(B_DB *mdb, JOB_DBR *jr)
96 Dmsg0(200, "In db_update_job_start_record\n");
98 memcpy(&ojr, jr, len);
100 if (!db_get_job_record(mdb, &ojr)) {
106 fseek(mdb->jobfd, ojr.rec_addr, SEEK_SET);
107 if (fwrite(jr, len, 1, mdb->jobfd) != 1) {
108 Mmsg1(&mdb->errmsg, _("Error updating DB Job file. ERR=%s\n"), strerror(errno));
118 int db_update_media_record(B_DB *mdb, MEDIA_DBR *mr)
124 Dmsg0(200, "In db_update_media_record\n");
127 memcpy(&omr, mr, len);
129 if (!db_get_media_record(mdb, &omr)) {
135 /* Don't allow some fields to change by copying from master record */
136 strcpy(mr->VolumeName, omr.VolumeName);
137 strcpy(mr->MediaType, omr.MediaType);
138 mr->MediaId = omr.MediaId;
139 mr->PoolId = omr.PoolId;
140 mr->VolMaxBytes = omr.VolMaxBytes;
141 mr->VolCapacityBytes = omr.VolCapacityBytes;
142 strcpy(mr->Recycle, omr.Recycle);
144 fseek(mdb->mediafd, omr.rec_addr, SEEK_SET);
145 if (fwrite(mr, len, 1, mdb->mediafd) != 1) {
146 Mmsg1(&mdb->errmsg, _("Error updating DB Media file. ERR=%s\n"), strerror(errno));
149 fflush(mdb->mediafd);
155 int db_update_pool_record(B_DB *mdb, POOL_DBR *pr)
161 Dmsg0(200, "In db_update_pool_record\n");
163 memcpy(&opr, pr, len);
165 if (!db_get_pool_record(mdb, &opr)) {
171 /* Update specific fields */
172 opr.NumVols = pr->NumVols;
173 opr.MaxVols = pr->MaxVols;
174 opr.UseOnce = pr->UseOnce;
175 opr.UseCatalog = pr->UseCatalog;
176 opr.AcceptAnyVolume = pr->AcceptAnyVolume;
177 strcpy(opr.LabelFormat, pr->LabelFormat);
179 fseek(mdb->poolfd, opr.rec_addr, SEEK_SET);
180 if (fwrite(&opr, len, 1, mdb->poolfd) != 1) {
181 Mmsg1(&mdb->errmsg, _("Error updating DB Media file. ERR=%s\n"), strerror(errno));
184 memcpy(pr, &opr, len); /* return record written */
192 int db_add_MD5_to_file_record(B_DB *mdb, FileId_t FileId, char *MD5)
197 int db_mark_file_record(B_DB *mdb, FileId_t FileId, int JobId)
203 #endif /* HAVE_BACULA_DB */