]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/dird/protos.h
Implement Plugin Directory and plugin events.
[bacula/bacula] / bacula / src / dird / protos.h
1 /*
2    Bacula® - The Network Backup Solution
3
4    Copyright (C) 2000-2007 Free Software Foundation Europe e.V.
5
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 two of the GNU General Public
10    License as published by the Free Software Foundation and included
11    in the file LICENSE.
12
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.
17
18    You should have received a copy of the GNU 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
21    02110-1301, USA.
22
23    Bacula® is a registered trademark of John Walker.
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.
27 */
28 /*
29  * Director external function prototypes
30  *
31  *   Version $Id$
32  */
33
34 /* admin.c */
35 extern bool do_admin_init(JCR *jcr);
36 extern bool do_admin(JCR *jcr);
37 extern void admin_cleanup(JCR *jcr, int TermCode);
38
39
40 /* authenticate.c */
41 extern bool authenticate_storage_daemon(JCR *jcr, STORE *store);
42 extern int authenticate_file_daemon(JCR *jcr);
43 extern int authenticate_user_agent(UAContext *ua);
44
45 /* autoprune.c */
46 extern void do_autoprune(JCR *jcr);
47 extern bool prune_volumes(JCR *jcr, bool InChanger, MEDIA_DBR *mr);
48
49 /* autorecycle.c */
50 extern bool recycle_oldest_purged_volume(JCR *jcr, bool InChanger, MEDIA_DBR *mr);
51 extern int recycle_volume(JCR *jcr, MEDIA_DBR *mr);
52 extern bool find_recycled_volume(JCR *jcr, bool InChanger, MEDIA_DBR *mr);
53
54 /* backup.c */
55 extern int wait_for_job_termination(JCR *jcr);
56 extern bool do_backup_init(JCR *jcr);
57 extern bool do_backup(JCR *jcr);
58 extern void backup_cleanup(JCR *jcr, int TermCode);
59 extern void update_bootstrap_file(JCR *jcr);
60
61 /* bsr.c */
62 RBSR *new_bsr();
63 void free_bsr(RBSR *bsr);
64 bool complete_bsr(UAContext *ua, RBSR *bsr);
65 uint32_t write_bsr_file(UAContext *ua, RESTORE_CTX &rx);
66 void add_findex(RBSR *bsr, uint32_t JobId, int32_t findex);
67 void add_findex_all(RBSR *bsr, uint32_t JobId);
68 RBSR_FINDEX *new_findex();
69 void make_unique_restore_filename(UAContext *ua, POOLMEM **fname);
70
71
72 /* catreq.c */
73 extern void catalog_request(JCR *jcr, BSOCK *bs);
74 extern void catalog_update(JCR *jcr, BSOCK *bs);
75
76 /* dird_conf.c */
77 extern const char *level_to_str(int level);
78
79 /* expand.c */
80 int variable_expansion(JCR *jcr, char *inp, POOLMEM **exp);
81
82
83 /* fd_cmds.c */
84 extern int connect_to_file_daemon(JCR *jcr, int retry_interval,
85                                   int max_retry_time, int verbose);
86 extern bool send_include_list(JCR *jcr);
87 extern bool send_exclude_list(JCR *jcr);
88 extern bool send_bootstrap_file(JCR *jcr, BSOCK *sock);
89 extern bool send_level_command(JCR *jcr);
90 extern int get_attributes_and_put_in_catalog(JCR *jcr);
91 extern int get_attributes_and_compare_to_catalog(JCR *jcr, JobId_t JobId);
92 extern int put_file_into_catalog(JCR *jcr, long file_index, char *fname,
93                           char *link, char *attr, int stream);
94 extern void get_level_since_time(JCR *jcr, char *since, int since_len);
95 extern int send_runscripts_commands(JCR *jcr);
96
97 /* getmsg.c */
98 enum e_prtmsg {
99    DISPLAY_ERROR,
100    NO_DISPLAY
101 };
102 extern bool response(JCR *jcr, BSOCK *fd, char *resp, const char *cmd, e_prtmsg prtmsg);
103
104 /* job.c */
105 extern void set_jcr_defaults(JCR *jcr, JOB *job);
106 extern void create_unique_job_name(JCR *jcr, const char *base_name);
107 extern void update_job_end_record(JCR *jcr);
108 extern bool get_or_create_client_record(JCR *jcr);
109 extern bool get_or_create_fileset_record(JCR *jcr);
110 extern DBId_t get_or_create_pool_record(JCR *jcr, char *pool_name);
111 extern void apply_pool_overrides(JCR *jcr);
112 extern JobId_t run_job(JCR *jcr);
113 extern bool cancel_job(UAContext *ua, JCR *jcr);
114 extern void get_job_storage(USTORE *store, JOB *job, RUN *run);
115 extern void init_jcr_job_record(JCR *jcr);
116 extern void update_job_end(JCR *jcr, int TermCode);
117 extern void copy_rwstorage(JCR *jcr, alist *storage, const char *where);
118 extern void set_rwstorage(JCR *jcr, USTORE *store);
119 extern void free_rwstorage(JCR *jcr);
120 extern void copy_wstorage(JCR *jcr, alist *storage, const char *where);
121 extern void set_wstorage(JCR *jcr, USTORE *store);
122 extern void free_wstorage(JCR *jcr);
123 extern void copy_rstorage(JCR *jcr, alist *storage, const char *where);
124 extern void set_rstorage(JCR *jcr, USTORE *store);
125 extern void free_rstorage(JCR *jcr);
126 extern bool setup_job(JCR *jcr);
127 extern void create_clones(JCR *jcr);
128 extern bool create_restore_bootstrap_file(JCR *jcr);
129 extern void dird_free_jcr(JCR *jcr);
130 extern void dird_free_jcr_pointers(JCR *jcr);
131 extern void cancel_storage_daemon_job(JCR *jcr);
132
133 /* migration.c */
134 extern bool do_migration(JCR *jcr);
135 extern bool do_migration_init(JCR *jcr);
136 extern void migration_cleanup(JCR *jcr, int TermCode);
137 extern bool set_migration_wstorage(JCR *jcr, POOL *pool);
138
139
140 /* mountreq.c */
141 extern void mount_request(JCR *jcr, BSOCK *bs, char *buf);
142
143 /* msgchan.c */
144 extern bool connect_to_storage_daemon(JCR *jcr, int retry_interval,
145                               int max_retry_time, int verbose);
146 extern bool start_storage_daemon_job(JCR *jcr, alist *rstore, alist *wstore);
147 extern bool start_storage_daemon_message_thread(JCR *jcr);
148 extern int bget_dirmsg(BSOCK *bs);
149 extern void wait_for_storage_daemon_termination(JCR *jcr);
150
151 /* next_vol.c */
152 int find_next_volume_for_append(JCR *jcr, MEDIA_DBR *mr, int index,
153                                 bool create, bool purge);
154 bool has_volume_expired(JCR *jcr, MEDIA_DBR *mr);
155 void check_if_volume_valid_or_recyclable(JCR *jcr, MEDIA_DBR *mr, const char **reason);
156 bool get_scratch_volume(JCR *jcr, bool InChanger, MEDIA_DBR *mr);
157
158 /* newvol.c */
159 bool newVolume(JCR *jcr, MEDIA_DBR *mr);
160
161 /* python.c */
162 int generate_job_event(JCR *jcr, const char *event);
163
164
165 /* restore.c */
166 extern bool do_restore(JCR *jcr);
167 extern bool do_restore_init(JCR *jcr);
168 extern void restore_cleanup(JCR *jcr, int TermCode);
169
170
171 /* ua_acl.c */
172 bool acl_access_ok(UAContext *ua, int acl, const char *item);
173 bool acl_access_ok(UAContext *ua, int acl, const char *item, int len);
174
175 /* ua_cmds.c */
176 int do_a_command(UAContext *ua, const char *cmd);
177 int do_a_dot_command(UAContext *ua, const char *cmd);
178 int qmessagescmd(UAContext *ua, const char *cmd);
179 bool open_client_db(UAContext *ua);
180 bool open_db(UAContext *ua);
181 void close_db(UAContext *ua);
182 enum e_pool_op {
183    POOL_OP_UPDATE,
184    POOL_OP_CREATE
185 };
186 int create_pool(JCR *jcr, B_DB *db, POOL *pool, e_pool_op op);
187 void set_pool_dbr_defaults_in_media_dbr(MEDIA_DBR *mr, POOL_DBR *pr);
188 bool set_pooldbr_recyclepoolid(JCR *jcr, B_DB *db, POOL_DBR *pr, POOL *pool);
189 void set_pooldbr_from_poolres(POOL_DBR *pr, POOL *pool, e_pool_op op);
190 int update_pool_recyclepool(JCR *jcr, B_DB *db, POOL *pool);
191
192 /* ua_input.c */
193 int get_cmd(UAContext *ua, const char *prompt);
194 bool get_pint(UAContext *ua, const char *prompt);
195 bool get_yesno(UAContext *ua, const char *prompt);
196 bool is_yesno(char *val, int *ret);
197 int get_enabled(UAContext *ua, const char *val);
198 void parse_ua_args(UAContext *ua);
199
200 /* ua_label.c */
201 bool is_volume_name_legal(UAContext *ua, const char *name);
202 int get_num_drives_from_SD(UAContext *ua);
203 void update_slots(UAContext *ua);
204
205 /* ua_update.c */
206 void update_vol_pool(UAContext *ua, char *val, MEDIA_DBR *mr, POOL_DBR *opr);
207
208 /* ua_output.c */
209 void prtit(void *ctx, const char *msg);
210 bool complete_jcr_for_job(JCR *jcr, JOB *job, POOL *pool);
211 RUN *find_next_run(RUN *run, JOB *job, time_t &runtime, int ndays);
212
213 /* ua_restore.c */
214 int get_next_jobid_from_list(char **p, JobId_t *JobId);
215 void find_storage_resource(UAContext *ua, RESTORE_CTX &rx, char *Storage, char *MediaType);
216
217 /* ua_server.c */
218 void bsendmsg(void *ua_ctx, const char *fmt, ...);
219 void berrormsg(void *ua_ctx, const char *fmt, ...);
220 void bwarningmsg(void *ua_ctx, const char *fmt, ...);
221 void binfomsg(void *ua_ctx, const char *fmt, ...);
222 UAContext *new_ua_context(JCR *jcr);
223 JCR *new_control_jcr(const char *base_name, int job_type);
224 void free_ua_context(UAContext *ua);
225
226 /* ua_select.c */
227 STORE   *select_storage_resource(UAContext *ua);
228 JOB     *select_job_resource(UAContext *ua);
229 JOB     *select_restore_job_resource(UAContext *ua);
230 CLIENT  *select_client_resource(UAContext *ua);
231 FILESET *select_fileset_resource(UAContext *ua);
232 int     select_pool_and_media_dbr(UAContext *ua, POOL_DBR *pr, MEDIA_DBR *mr);
233 int     select_media_dbr(UAContext *ua, MEDIA_DBR *mr);
234 bool    select_pool_dbr(UAContext *ua, POOL_DBR *pr, const char *argk="pool");
235 bool    select_client_dbr(UAContext *ua, CLIENT_DBR *cr);
236
237 void    start_prompt(UAContext *ua, const char *msg);
238 void    add_prompt(UAContext *ua, const char *prompt);
239 int     do_prompt(UAContext *ua, const char *automsg, const char *msg, char *prompt, int max_prompt);
240 CAT    *get_catalog_resource(UAContext *ua);
241 STORE  *get_storage_resource(UAContext *ua, bool use_default);
242 int     get_storage_drive(UAContext *ua, STORE *store);
243 int     get_storage_slot(UAContext *ua, STORE *store);
244 int     get_media_type(UAContext *ua, char *MediaType, int max_media);
245 bool    get_pool_dbr(UAContext *ua, POOL_DBR *pr, const char *argk="pool");
246 bool    get_client_dbr(UAContext *ua, CLIENT_DBR *cr);
247 POOL   *get_pool_resource(UAContext *ua);
248 POOL   *select_pool_resource(UAContext *ua);
249 CLIENT *get_client_resource(UAContext *ua);
250 int     get_job_dbr(UAContext *ua, JOB_DBR *jr);
251
252 int find_arg_keyword(UAContext *ua, const char **list);
253 int find_arg(UAContext *ua, const char *keyword);
254 int find_arg_with_value(UAContext *ua, const char *keyword);
255 int do_keyword_prompt(UAContext *ua, const char *msg, const char **list);
256 int confirm_retention(UAContext *ua, utime_t *ret, const char *msg);
257 bool get_level_from_name(JCR *jcr, const char *level_name);
258
259 /* ua_status.c */
260 void list_dir_status_header(UAContext *ua);
261
262 /* ua_tree.c */
263 bool user_select_files_from_tree(TREE_CTX *tree);
264 int insert_tree_handler(void *ctx, int num_fields, char **row);
265
266 /* ua_prune.c */
267 int prune_files(UAContext *ua, CLIENT *client);
268 int prune_jobs(UAContext *ua, CLIENT *client, int JobType);
269 bool prune_volume(UAContext *ua, MEDIA_DBR *mr);
270 int job_delete_handler(void *ctx, int num_fields, char **row);
271 int del_count_handler(void *ctx, int num_fields, char **row);
272 int file_delete_handler(void *ctx, int num_fields, char **row);
273 int get_prune_list_for_volume(UAContext *ua, MEDIA_DBR *mr, del_ctx *del);
274
275 /* ua_purge.c */
276 bool is_volume_purged(UAContext *ua, MEDIA_DBR *mr);
277 bool mark_media_purged(UAContext *ua, MEDIA_DBR *mr);
278 void purge_files_from_volume(UAContext *ua, MEDIA_DBR *mr );
279 bool purge_jobs_from_volume(UAContext *ua, MEDIA_DBR *mr);
280 void purge_files_from_jobs(UAContext *ua, char *jobs);
281 void purge_jobs_from_catalog(UAContext *ua, char *jobs);
282 void purge_job_list_from_catalog(UAContext *ua, del_ctx &del);
283 void purge_files_from_job_list(UAContext *ua, del_ctx &del);
284
285
286 /* ua_run.c */
287 extern int run_cmd(UAContext *ua, const char *cmd);
288
289 /* verify.c */
290 extern bool do_verify(JCR *jcr);
291 extern bool do_verify_init(JCR *jcr);
292 extern void verify_cleanup(JCR *jcr, int TermCode);