2 Copyright (C) 2000, 2001, 2002 Kern Sibbald and John Walker
4 This program is free software; you can redistribute it and/or
5 modify it under the terms of the GNU General Public License as
6 published by the Free Software Foundation; either version 2 of
7 the License, or (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 General Public License for more details.
14 You should have received a copy of the GNU General Public
15 License along with this program; if not, write to the Free
16 Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
21 #ifndef __SQL_PROTOS_H
22 #define __SQL_PROTOS_H
26 /* Database prototypes */
29 B_DB *db_init_database(char *db_name, char *db_user, char *db_password);
30 int db_open_database(B_DB *db);
31 void db_close_database(B_DB *db);
32 void db_escape_string(char *snew, char *old, int len);
33 char *db_strerror(B_DB *mdb);
34 int get_sql_record_max(B_DB *mdb);
35 char *db_next_index(B_DB *mdb, char *table);
36 int db_sql_query(B_DB *mdb, char *cmd, DB_RESULT_HANDLER *result_handler, void *ctx);
39 int db_create_file_attributes_record(B_DB *mdb, ATTR_DBR *ar);
40 int db_create_job_record(B_DB *db, JOB_DBR *jr);
41 int db_create_media_record(B_DB *db, MEDIA_DBR *media_dbr);
42 int db_create_client_record(B_DB *db, CLIENT_DBR *cr);
43 int db_create_fileset_record(B_DB *db, FILESET_DBR *fsr);
44 int db_create_pool_record(B_DB *db, POOL_DBR *pool_dbr);
45 int db_create_jobmedia_record(B_DB *mdb, JOBMEDIA_DBR *jr);
48 int db_delete_pool_record(B_DB *db, POOL_DBR *pool_dbr);
49 int db_delete_media_record(B_DB *mdb, MEDIA_DBR *mr);
52 int db_find_job_start_time(B_DB *mdb, JOB_DBR *jr, char *stime);
53 int db_find_last_full_verify(B_DB *mdb, JOB_DBR *jr);
54 int db_find_next_volume(B_DB *mdb, int index, MEDIA_DBR *mr);
57 int db_get_pool_record(B_DB *db, POOL_DBR *pdbr);
58 int db_get_client_record(B_DB *mdb, CLIENT_DBR *cr);
59 int db_get_job_record(B_DB *mdb, JOB_DBR *jr);
60 int db_get_job_volume_names(B_DB *mdb, uint32_t JobId, char *VolumeNames);
61 int db_get_file_attributes_record(B_DB *mdb, char *fname, FILE_DBR *fdbr);
62 int db_get_fileset_record(B_DB *mdb, FILESET_DBR *fsr);
63 int db_get_media_record(B_DB *mdb, MEDIA_DBR *mr);
64 int db_get_num_media_records(B_DB *mdb);
65 int db_get_num_pool_records(B_DB *mdb);
66 int db_get_pool_ids(B_DB *mdb, int *num_ids, uint32_t **ids);
67 int db_get_media_ids(B_DB *mdb, int *num_ids, uint32_t **ids);
71 void db_list_pool_records(B_DB *db, DB_LIST_HANDLER sendit, void *ctx);
72 void db_list_job_records(B_DB *db, JOB_DBR *jr, DB_LIST_HANDLER sendit, void *ctx);
73 void db_list_job_totals(B_DB *db, JOB_DBR *jr, DB_LIST_HANDLER sendit, void *ctx);
74 void db_list_files_for_job(B_DB *db, uint32_t jobid, DB_LIST_HANDLER sendit, void *ctx);
75 void db_list_media_records(B_DB *mdb, MEDIA_DBR *mdbr, DB_LIST_HANDLER *sendit, void *ctx);
76 void db_list_jobmedia_records(B_DB *mdb, uint32_t JobId, DB_LIST_HANDLER *sendit, void *ctx);
77 int db_list_sql_query(B_DB *mdb, char *query, DB_LIST_HANDLER *sendit, void *ctx);
80 int db_update_job_start_record(B_DB *db, JOB_DBR *jr);
81 int db_update_job_end_record(B_DB *db, JOB_DBR *jr);
82 int db_update_pool_record(B_DB *db, POOL_DBR *pr);
83 int db_update_media_record(B_DB *db, MEDIA_DBR *mr);
84 int db_add_MD5_to_file_record(B_DB *mdb, FileId_t FileId, char *MD5);
85 int db_mark_file_record(B_DB *mdb, FileId_t FileId, int JobId);
87 #endif /* __SQL_PROTOS_H */