2 Bacula® - The Network Backup Solution
4 Copyright (C) 2000-2009 Free Software Foundation Europe e.V.
6 The main author of Bacula is Kern Sibbald, with contributions from
7 many others, a complete list can be found in the file AUTHORS.
8 This program is Free Software; you can redistribute it and/or
9 modify it under the terms of version three of the GNU Affero General Public
10 License as published by the Free Software Foundation and included
13 This program is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 General Public License for more details.
18 You should have received a copy of the GNU Affero General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
23 Bacula® is a registered trademark of Kern Sibbald.
24 The licensor of Bacula is the Free Software Foundation Europe
25 (FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
26 Switzerland, email:ftf@fsfeurope.org.
30 * Database routines that are exported by the cats library for
31 * use elsewhere in Bacula (mainly the Director).
36 #ifndef __SQL_PROTOS_H
37 #define __SQL_PROTOS_H
41 /* Database prototypes */
44 bool db_open_batch_connexion(JCR *jcr, B_DB *mdb);
45 char *db_strerror(B_DB *mdb);
46 int db_int64_handler(void *ctx, int num_fields, char **row);
47 int db_strtime_handler(void *ctx, int num_fields, char **row);
48 int db_list_handler(void *ctx, int num_fields, char **row);
49 void db_debug_print(JCR *jcr, FILE *fp);
50 int db_int_handler(void *ctx, int num_fields, char **row);
51 void db_check_backend_thread_safe();
54 int db_create_path_record(JCR *jcr, B_DB *mdb, ATTR_DBR *ar);
55 bool db_create_file_attributes_record(JCR *jcr, B_DB *mdb, ATTR_DBR *ar);
56 bool db_create_job_record(JCR *jcr, B_DB *db, JOB_DBR *jr);
57 int db_create_media_record(JCR *jcr, B_DB *db, MEDIA_DBR *media_dbr);
58 int db_create_client_record(JCR *jcr, B_DB *db, CLIENT_DBR *cr);
59 bool db_create_fileset_record(JCR *jcr, B_DB *db, FILESET_DBR *fsr);
60 bool db_create_pool_record(JCR *jcr, B_DB *db, POOL_DBR *pool_dbr);
61 bool db_create_jobmedia_record(JCR *jcr, B_DB *mdb, JOBMEDIA_DBR *jr);
62 int db_create_counter_record(JCR *jcr, B_DB *mdb, COUNTER_DBR *cr);
63 bool db_create_device_record(JCR *jcr, B_DB *mdb, DEVICE_DBR *dr);
64 bool db_create_storage_record(JCR *jcr, B_DB *mdb, STORAGE_DBR *sr);
65 bool db_create_mediatype_record(JCR *jcr, B_DB *mdb, MEDIATYPE_DBR *mr);
66 bool db_write_batch_file_records(JCR *jcr);
67 bool db_create_attributes_record(JCR *jcr, B_DB *mdb, ATTR_DBR *ar);
68 bool db_create_restore_object_record(JCR *jcr, B_DB *mdb, ROBJECT_DBR *ar);
69 bool db_create_base_file_attributes_record(JCR *jcr, B_DB *mdb, ATTR_DBR *ar);
70 bool db_commit_base_file_attributes_record(JCR *jcr, B_DB *mdb);
71 bool db_create_base_file_list(JCR *jcr, B_DB *mdb, char *jobids);
74 int db_delete_pool_record(JCR *jcr, B_DB *db, POOL_DBR *pool_dbr);
75 int db_delete_media_record(JCR *jcr, B_DB *mdb, MEDIA_DBR *mr);
78 bool db_find_last_job_start_time(JCR *jcr, B_DB *mdb, JOB_DBR *jr, POOLMEM **stime, int JobLevel);
79 bool db_find_job_start_time(JCR *jcr, B_DB *mdb, JOB_DBR *jr, POOLMEM **stime);
80 bool db_find_last_jobid(JCR *jcr, B_DB *mdb, const char *Name, JOB_DBR *jr);
81 int db_find_next_volume(JCR *jcr, B_DB *mdb, int index, bool InChanger, MEDIA_DBR *mr);
82 bool db_find_failed_job_since(JCR *jcr, B_DB *mdb, JOB_DBR *jr, POOLMEM *stime, int &JobLevel);
85 bool db_get_volume_jobids(JCR *jcr, B_DB *mdb,
86 MEDIA_DBR *mr, db_list_ctx *lst);
87 bool db_get_base_file_list(JCR *jcr, B_DB *mdb, bool use_md5,
88 DB_RESULT_HANDLER *result_handler,void *ctx);
89 int db_get_path_record(JCR *jcr, B_DB *mdb);
90 bool db_get_pool_record(JCR *jcr, B_DB *db, POOL_DBR *pdbr);
91 int db_get_client_record(JCR *jcr, B_DB *mdb, CLIENT_DBR *cr);
92 bool db_get_job_record(JCR *jcr, B_DB *mdb, JOB_DBR *jr);
93 int db_get_job_volume_names(JCR *jcr, B_DB *mdb, JobId_t JobId, POOLMEM **VolumeNames);
94 int db_get_file_attributes_record(JCR *jcr, B_DB *mdb, char *fname, JOB_DBR *jr, FILE_DBR *fdbr);
95 int db_get_fileset_record(JCR *jcr, B_DB *mdb, FILESET_DBR *fsr);
96 bool db_get_media_record(JCR *jcr, B_DB *mdb, MEDIA_DBR *mr);
97 int db_get_num_media_records(JCR *jcr, B_DB *mdb);
98 int db_get_num_pool_records(JCR *jcr, B_DB *mdb);
99 int db_get_pool_ids(JCR *jcr, B_DB *mdb, int *num_ids, DBId_t **ids);
100 int db_get_client_ids(JCR *jcr, B_DB *mdb, int *num_ids, DBId_t **ids);
101 bool db_get_media_ids(JCR *jcr, B_DB *mdb, MEDIA_DBR *mr, int *num_ids, uint32_t **ids);
102 int db_get_job_volume_parameters(JCR *jcr, B_DB *mdb, JobId_t JobId, VOL_PARAMS **VolParams);
103 int db_get_client_record(JCR *jcr, B_DB *mdb, CLIENT_DBR *cdbr);
104 int db_get_counter_record(JCR *jcr, B_DB *mdb, COUNTER_DBR *cr);
105 bool db_get_query_dbids(JCR *jcr, B_DB *mdb, POOL_MEM &query, dbid_list &ids);
106 bool db_get_file_list(JCR *jcr, B_DB *mdb, char *jobids,
107 bool use_md5, bool use_delta,
108 DB_RESULT_HANDLER *result_handler, void *ctx);
109 bool db_get_base_jobid(JCR *jcr, B_DB *mdb, JOB_DBR *jr, JobId_t *jobid);
110 bool db_accurate_get_jobids(JCR *jcr, B_DB *mdb, JOB_DBR *jr, db_list_ctx *jobids);
111 bool db_get_used_base_jobids(JCR *jcr, B_DB *mdb, POOLMEM *jobids, db_list_ctx *result);
118 void db_list_pool_records(JCR *jcr, B_DB *db, POOL_DBR *pr, DB_LIST_HANDLER sendit, void *ctx, e_list_type type);
119 void db_list_job_records(JCR *jcr, B_DB *db, JOB_DBR *jr, DB_LIST_HANDLER sendit, void *ctx, e_list_type type);
120 void db_list_job_totals(JCR *jcr, B_DB *db, JOB_DBR *jr, DB_LIST_HANDLER sendit, void *ctx);
121 void db_list_files_for_job(JCR *jcr, B_DB *db, uint32_t jobid, DB_LIST_HANDLER sendit, void *ctx);
122 void db_list_media_records(JCR *jcr, B_DB *mdb, MEDIA_DBR *mdbr, DB_LIST_HANDLER *sendit, void *ctx, e_list_type type);
123 void db_list_jobmedia_records(JCR *jcr, B_DB *mdb, JobId_t JobId, DB_LIST_HANDLER *sendit, void *ctx, e_list_type type);
124 void db_list_joblog_records(JCR *jcr, B_DB *mdb, JobId_t JobId, DB_LIST_HANDLER *sendit, void *ctx, e_list_type type);
125 int db_list_sql_query(JCR *jcr, B_DB *mdb, const char *query, DB_LIST_HANDLER *sendit, void *ctx, int verbose, e_list_type type);
126 void db_list_client_records(JCR *jcr, B_DB *mdb, DB_LIST_HANDLER *sendit, void *ctx, e_list_type type);
127 void db_list_copies_records(JCR *jcr, B_DB *mdb, uint32_t limit, char *jobids, DB_LIST_HANDLER *sendit, void *ctx, e_list_type type);
129 db_list_base_files_for_job(JCR *jcr, B_DB *mdb, JobId_t jobid, DB_LIST_HANDLER *sendit, void *ctx);
133 bool db_update_job_start_record(JCR *jcr, B_DB *db, JOB_DBR *jr);
134 int db_update_job_end_record(JCR *jcr, B_DB *db, JOB_DBR *jr);
135 int db_update_client_record(JCR *jcr, B_DB *mdb, CLIENT_DBR *cr);
136 int db_update_pool_record(JCR *jcr, B_DB *db, POOL_DBR *pr);
137 bool db_update_storage_record(JCR *jcr, B_DB *mdb, STORAGE_DBR *sr);
138 int db_update_media_record(JCR *jcr, B_DB *db, MEDIA_DBR *mr);
139 int db_update_media_defaults(JCR *jcr, B_DB *mdb, MEDIA_DBR *mr);
140 int db_update_counter_record(JCR *jcr, B_DB *mdb, COUNTER_DBR *cr);
141 int db_add_digest_to_file_record(JCR *jcr, B_DB *mdb, FileId_t FileId, char *digest, int type);
142 int db_mark_file_record(JCR *jcr, B_DB *mdb, FileId_t FileId, JobId_t JobId);
143 void db_make_inchanger_unique(JCR *jcr, B_DB *mdb, MEDIA_DBR *mr);
144 int db_update_stats(JCR *jcr, B_DB *mdb, utime_t age);
146 #endif /* __SQL_PROTOS_H */