2 * Bacula Catalog Database Update record interface routines
4 * Kern Sibbald, March 2000
10 Copyright (C) 2000, 2001, 2002 Kern Sibbald and John Walker
12 This program is free software; you can redistribute it and/or
13 modify it under the terms of the GNU General Public License as
14 published by the Free Software Foundation; either version 2 of
15 the License, or (at your option) any later version.
17 This program is distributed in the hope that it will be useful,
18 but WITHOUT ANY WARRANTY; without even the implied warranty of
19 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 General Public License for more details.
22 You should have received a copy of the GNU General Public
23 License along with this program; if not, write to the Free
24 Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
29 /* *****FIXME**** fix fixed length of select_cmd[] and insert_cmd[] */
31 /* The following is necessary so that we do not include
32 * the dummy external definition of DB.
34 #define __SQL_C /* indicate that this is sql.c */
39 #if HAVE_MYSQL || HAVE_SQLITE
41 /* -----------------------------------------------------------------------
43 * Generic Routines (or almost generic)
45 * -----------------------------------------------------------------------
48 /* Imported subroutines */
49 extern void print_result(B_DB *mdb);
50 extern int UpdateDB(char *file, int line, B_DB *db, char *update_cmd);
52 static int do_update(B_DB *mdb, char *cmd)
56 stat = UPDATE_DB(mdb, cmd);
60 /* -----------------------------------------------------------------------
62 * Generic Routines (or almost generic)
64 * -----------------------------------------------------------------------
66 /* Update the attributes record by adding the MD5 signature */
68 db_add_MD5_to_file_record(B_DB *mdb, FileId_t FileId, char *MD5)
73 Mmsg(&mdb->cmd, "UPDATE File SET MD5=\"%s\" WHERE FileId=%d", MD5, FileId);
74 stat = UPDATE_DB(mdb, mdb->cmd);
79 /* Mark the file record as being visited during database
80 * verify compare. Stuff JobId into FileIndex field
82 int db_mark_file_record(B_DB *mdb, FileId_t FileId, int JobId)
87 Mmsg(&mdb->cmd, "UPDATE File SET FileIndex=%d WHERE FileId=%d", JobId, FileId);
88 stat = UPDATE_DB(mdb, mdb->cmd);
94 * Update the Job record at end of Job
96 * Returns: 0 on failure
100 db_update_job_start_record(B_DB *mdb, JOB_DBR *jr)
102 char dt[MAX_TIME_LENGTH];
109 stime = jr->StartTime;
110 localtime_r(&stime, &tm);
111 strftime(dt, sizeof(dt), "%Y-%m-%d %T", &tm);
112 JobTDate = (btime_t)stime;
115 Mmsg(&mdb->cmd, "UPDATE Job SET Level='%c', StartTime=\"%s\", \
116 ClientId=%d, JobTDate=%s WHERE JobId=%d",
117 (char)(jr->Level), dt, jr->ClientId, edit_uint64(JobTDate, ed1), jr->JobId);
118 stat = UPDATE_DB(mdb, mdb->cmd);
126 * Update the Job record at end of Job
128 * Returns: 0 on failure
132 db_update_job_end_record(B_DB *mdb, JOB_DBR *jr)
134 char dt[MAX_TIME_LENGTH];
138 char ed1[30], ed2[30];
142 localtime_r(&ttime, &tm);
143 strftime(dt, sizeof(dt), "%Y-%m-%d %T", &tm);
148 "UPDATE Job SET JobStatus='%c', EndTime='%s', \
149 ClientId=%d, JobBytes=%s, JobFiles=%d, JobErrors=%d, VolSessionId=%d, \
150 VolSessionTime=%d, PoolId=%d, FileSetId=%d, JobTDate=%s WHERE JobId=%d",
151 (char)(jr->JobStatus), dt, jr->ClientId, edit_uint64(jr->JobBytes, ed1),
152 jr->JobFiles, jr->JobErrors, jr->VolSessionId, jr->VolSessionTime,
153 jr->PoolId, jr->FileSetId, edit_uint64(JobTDate, ed2), jr->JobId);
155 stat = UPDATE_DB(mdb, mdb->cmd);
162 db_update_pool_record(B_DB *mdb, POOL_DBR *pr)
168 "UPDATE Pool SET NumVols=%d, MaxVols=%d, UseOnce=%d, UseCatalog=%d, \
169 AcceptAnyVolume=%d, LabelFormat=\"%s\" WHERE PoolId=%d",
170 pr->NumVols, pr->MaxVols, pr->UseOnce, pr->UseCatalog,
171 pr->AcceptAnyVolume, pr->LabelFormat, pr->PoolId);
173 stat = UPDATE_DB(mdb, mdb->cmd);
179 * Update the Media Record at end of Session
181 * Returns: 0 on failure
185 db_update_media_record(B_DB *mdb, MEDIA_DBR *mr)
187 char dt[MAX_TIME_LENGTH];
191 char ed1[30], ed2[30];
193 ttime = mr->LastWritten;
194 localtime_r(&ttime, &tm);
195 strftime(dt, sizeof(dt), "%Y-%m-%d %T", &tm);
197 Dmsg1(100, "update_media: FirstWritten=%d\n", mr->FirstWritten);
199 if (mr->VolMounts == 1) {
200 Mmsg(&mdb->cmd, "UPDATE Media SET FirstWritten=\"%s\"\
201 WHERE VolumeName=\"%s\"", dt, mr->VolumeName);
202 if (do_update(mdb, mdb->cmd) == 0) {
208 Mmsg(&mdb->cmd, "UPDATE Media SET VolJobs=%d,\
209 VolFiles=%d, VolBlocks=%d, VolBytes=%s, VolMounts=%d, VolErrors=%d,\
210 VolWrites=%d, VolMaxBytes=%s, LastWritten=\"%s\", VolStatus=\"%s\" \
211 WHERE VolumeName=\"%s\"",
212 mr->VolJobs, mr->VolFiles, mr->VolBlocks, edit_uint64(mr->VolBytes, ed1),
213 mr->VolMounts, mr->VolErrors, mr->VolWrites,
214 edit_uint64(mr->VolMaxBytes, ed2), dt,
215 mr->VolStatus, mr->VolumeName);
217 stat = UPDATE_DB(mdb, mdb->cmd);
222 #endif /* HAVE_MYSQL || HAVE_SQLITE */