]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/lib/protos.h
Add support for arbitrary client-to-server certificate CN matching (TLS Allowed CN...
[bacula/bacula] / bacula / src / lib / protos.h
1 /*
2  * Prototypes for lib directory of Bacula
3  *
4  *   Version $Id$
5  */
6 /*
7    Bacula® - The Network Backup Solution
8
9    Copyright (C) 2000-2006 Free Software Foundation Europe e.V.
10
11    The main author of Bacula is Kern Sibbald, with contributions from
12    many others, a complete list can be found in the file AUTHORS.
13    This program is Free Software; you can redistribute it and/or
14    modify it under the terms of version two of the GNU General Public
15    License as published by the Free Software Foundation plus additions
16    that are listed in the file LICENSE.
17
18    This program is distributed in the hope that it will be useful, but
19    WITHOUT ANY WARRANTY; without even the implied warranty of
20    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21    General Public License for more details.
22
23    You should have received a copy of the GNU General Public License
24    along with this program; if not, write to the Free Software
25    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26    02110-1301, USA.
27
28    Bacula® is a registered trademark of John Walker.
29    The licensor of Bacula is the Free Software Foundation Europe
30    (FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
31    Switzerland, email:ftf@fsfeurope.org.
32 */
33
34 class JCR;
35
36 /* attr.c */
37 ATTR     *new_attr();
38 void      free_attr(ATTR *attr);
39 int       unpack_attributes_record(JCR *jcr, int32_t stream, char *rec, ATTR *attr);
40 void      build_attr_output_fnames(JCR *jcr, ATTR *attr);
41 void      print_ls_output(JCR *jcr, ATTR *attr);
42
43 /* base64.c */
44 void      base64_init            (void);
45 int       to_base64              (intmax_t value, char *where);
46 int       from_base64            (intmax_t *value, char *where);
47 int       bin_to_base64          (char *buf, int buflen, char *bin, int binlen, 
48                                   int compatible);
49
50 /* bsys.c */
51 char     *bstrncpy               (char *dest, const char *src, int maxlen);
52 char     *bstrncpy               (char *dest, POOL_MEM &src, int maxlen);
53 char     *bstrncat               (char *dest, const char *src, int maxlen);
54 char     *bstrncat               (char *dest, POOL_MEM &src, int maxlen);
55 bool      bstrcmp                (const char *s1, const char *s2);
56 int       cstrlen                (const char *str);
57 void     *b_malloc               (const char *file, int line, size_t size);
58 #ifndef bmalloc
59 void     *bmalloc                (size_t size);
60 #endif
61 void      bfree                  (void *buf);
62 void     *brealloc               (void *buf, size_t size);
63 void     *bcalloc                (size_t size1, size_t size2);
64 int       bsnprintf              (char *str, int32_t size, const char *format, ...);
65 int       bvsnprintf             (char *str, int32_t size, const char *format, va_list ap);
66 int       pool_sprintf           (char *pool_buf, const char *fmt, ...);
67 void      create_pid_file        (char *dir, const char *progname, int port);
68 int       delete_pid_file        (char *dir, const char *progname, int port);
69 void      drop                   (char *uid, char *gid);
70 int       bmicrosleep            (time_t sec, long usec);
71 char     *bfgets                 (char *s, int size, FILE *fd);
72 void      make_unique_filename   (POOLMEM **name, int Id, char *what);
73 #ifndef HAVE_STRTOLL
74 long long int strtoll            (const char *ptr, char **endptr, int base);
75 #endif
76 void      read_state_file(char *dir, const char *progname, int port);
77 int       bstrerror(int errnum, char *buf, size_t bufsiz);
78 char     *escape_filename(const char *file_path);
79
80 /* bnet.c */
81 int32_t    bnet_recv             (BSOCK *bsock);
82 bool       bnet_send             (BSOCK *bsock);
83 bool       bnet_fsend            (BSOCK *bs, const char *fmt, ...);
84 bool       bnet_set_buffer_size  (BSOCK *bs, uint32_t size, int rw);
85 bool       bnet_sig              (BSOCK *bs, int sig);
86 bool       bnet_tls_server       (TLS_CONTEXT *ctx, BSOCK *bsock,
87                                   alist *verify_list);
88 bool       bnet_tls_client       (TLS_CONTEXT *ctx, BSOCK *bsock,
89                                   alist *verify_list);
90 BSOCK *    bnet_connect          (JCR *jcr, int retry_interval,
91                utime_t max_retry_time, const char *name, char *host, char *service,
92                int port, int verbose);
93 void       bnet_close            (BSOCK *bsock);
94 BSOCK *    init_bsock            (JCR *jcr, int sockfd, const char *who, const char *ip,
95                                   int port, struct sockaddr *client_addr);
96 #ifdef HAVE_WIN32
97 #ifndef socklen_t
98 #define socklen_t int
99 #endif
100 #endif
101 int        bnet_get_peer           (BSOCK *bs, char *buf, socklen_t buflen);
102 BSOCK *    dup_bsock             (BSOCK *bsock);
103 void       term_bsock            (BSOCK *bsock);
104 const char *bnet_strerror         (BSOCK *bsock);
105 const char *bnet_sig_to_ascii     (BSOCK *bsock);
106 int        bnet_wait_data        (BSOCK *bsock, int sec);
107 int        bnet_wait_data_intr   (BSOCK *bsock, int sec);
108 int        bnet_despool_to_bsock (BSOCK *bsock, void update(ssize_t size), ssize_t size);
109 bool       is_bnet_stop          (BSOCK *bsock);
110 int        is_bnet_error         (BSOCK *bsock);
111 void       bnet_suppress_error_messages(BSOCK *bsock, bool flag);
112 dlist *bnet_host2ipaddrs(const char *host, int family, const char **errstr);
113 int        bnet_set_blocking     (BSOCK *sock);
114 int        bnet_set_nonblocking  (BSOCK *sock);
115 void       bnet_restore_blocking (BSOCK *sock, int flags);
116
117 /* bget_msg.c */
118 int      bget_msg(BSOCK *sock);
119
120 /* bpipe.c */
121 BPIPE *          open_bpipe(char *prog, int wait, const char *mode);
122 int              close_wpipe(BPIPE *bpipe);
123 int              close_bpipe(BPIPE *bpipe);
124
125 /* cram-md5.c */
126 bool cram_md5_respond(BSOCK *bs, char *password, int *tls_remote_need, int *compatible);
127 bool cram_md5_challenge(BSOCK *bs, char *password, int tls_local_need, int compatible);
128 void hmac_md5(uint8_t* text, int text_len, uint8_t* key, int key_len, uint8_t *hmac);
129
130 /* crc32.c */
131
132 uint32_t bcrc32(uint8_t *buf, int len);
133
134 /* crypto.c */
135 int                init_crypto                 (void);
136 int                cleanup_crypto              (void);
137 DIGEST *           crypto_digest_new           (crypto_digest_t type);
138 bool               crypto_digest_update        (DIGEST *digest, const uint8_t *data, uint32_t length);
139 bool               crypto_digest_finalize      (DIGEST *digest, uint8_t *dest, uint32_t *length);
140 void               crypto_digest_free          (DIGEST *digest);
141 SIGNATURE *        crypto_sign_new             (void);
142 crypto_error_t     crypto_sign_get_digest      (SIGNATURE *sig, X509_KEYPAIR *keypair, DIGEST **digest);
143 crypto_error_t     crypto_sign_verify          (SIGNATURE *sig, X509_KEYPAIR *keypair, DIGEST *digest);
144 int                crypto_sign_add_signer      (SIGNATURE *sig, DIGEST *digest, X509_KEYPAIR *keypair);
145 int                crypto_sign_encode          (SIGNATURE *sig, uint8_t *dest, uint32_t *length);
146 SIGNATURE *        crypto_sign_decode          (const uint8_t *sigData, uint32_t length);
147 void               crypto_sign_free            (SIGNATURE *sig);
148 CRYPTO_SESSION *   crypto_session_new          (crypto_cipher_t cipher, alist *pubkeys);
149 void               crypto_session_free         (CRYPTO_SESSION *cs);
150 bool               crypto_session_encode       (CRYPTO_SESSION *cs, uint8_t *dest, uint32_t *length);
151 crypto_error_t     crypto_session_decode       (const uint8_t *data, uint32_t length, alist *keypairs, CRYPTO_SESSION **session); 
152 CRYPTO_SESSION *   crypto_session_decode       (const uint8_t *data, uint32_t length);
153 CIPHER_CONTEXT *   crypto_cipher_new           (CRYPTO_SESSION *cs, bool encrypt, uint32_t *blocksize);
154 bool               crypto_cipher_update        (CIPHER_CONTEXT *cipher_ctx, const uint8_t *data, uint32_t length, const uint8_t *dest, uint32_t *written);
155 bool               crypto_cipher_finalize      (CIPHER_CONTEXT *cipher_ctx, uint8_t *dest, uint32_t *written);
156 void               crypto_cipher_free          (CIPHER_CONTEXT *cipher_ctx);
157 X509_KEYPAIR *     crypto_keypair_new          (void);
158 X509_KEYPAIR *     crypto_keypair_dup          (X509_KEYPAIR *keypair);
159 int                crypto_keypair_load_cert    (X509_KEYPAIR *keypair, const char *file);
160 bool               crypto_keypair_has_key      (const char *file);
161 int                crypto_keypair_load_key     (X509_KEYPAIR *keypair, const char *file, CRYPTO_PEM_PASSWD_CB *pem_callback, const void *pem_userdata);
162 void               crypto_keypair_free         (X509_KEYPAIR *keypair);
163 int                crypto_default_pem_callback (char *buf, int size, const void *userdata);
164 const char *       crypto_digest_name          (DIGEST *digest);
165 crypto_digest_t    crypto_digest_stream_type   (int stream);
166 const char *       crypto_strerror             (crypto_error_t error);
167
168 /* daemon.c */
169 void     daemon_start            ();
170
171 /* edit.c */
172 uint64_t         str_to_uint64(char *str);
173 int64_t          str_to_int64(char *str);
174 #define str_to_int32(str) ((int32_t)str_to_int64(str))
175 char *           edit_uint64_with_commas   (uint64_t val, char *buf);
176 char *           edit_uint64_with_suffix   (uint64_t val, char *buf);
177 char *           add_commas              (char *val, char *buf);
178 char *           edit_uint64             (uint64_t val, char *buf);
179 char *           edit_int64              (int64_t val, char *buf);
180 bool             duration_to_utime       (char *str, utime_t *value);
181 bool             size_to_uint64(char *str, int str_len, uint64_t *rtn_value);
182 char             *edit_utime             (utime_t val, char *buf, int buf_len);
183 bool             is_a_number             (const char *num);
184 bool             is_an_integer           (const char *n);
185 bool             is_name_valid           (char *name, POOLMEM **msg);
186
187 /* jcr.c (most definitions are in src/jcr.h) */
188 void init_last_jobs_list();
189 void term_last_jobs_list();
190 void lock_last_jobs_list();
191 void unlock_last_jobs_list();
192 bool read_last_jobs_list(int fd, uint64_t addr);
193 uint64_t write_last_jobs_list(int fd, uint64_t addr);
194 void write_state_file(char *dir, const char *progname, int port);
195 void job_end_push(JCR *jcr, void job_end_cb(JCR *jcr,void *), void *ctx);
196 void lock_jobs();
197 void unlock_jobs();
198 JCR *jcr_walk_start();
199 JCR *jcr_walk_next(JCR *prev_jcr);
200 void jcr_walk_end(JCR *jcr);
201
202
203 /* lex.c */
204 LEX *     lex_close_file         (LEX *lf);
205 LEX *     lex_open_file          (LEX *lf, const char *fname, LEX_ERROR_HANDLER *scan_error);
206 int       lex_get_char           (LEX *lf);
207 void      lex_unget_char         (LEX *lf);
208 const char *  lex_tok_to_str     (int token);
209 int       lex_get_token          (LEX *lf, int expect);
210 void      lex_set_default_error_handler (LEX *lf);
211 int       lex_set_error_handler_error_type (LEX *lf, int err_type);
212
213 /* message.c */
214 void       my_name_is            (int argc, char *argv[], const char *name);
215 void       init_msg              (JCR *jcr, MSGS *msg);
216 void       term_msg              (void);
217 void       close_msg             (JCR *jcr);
218 void       add_msg_dest          (MSGS *msg, int dest, int type, char *where, char *dest_code);
219 void       rem_msg_dest          (MSGS *msg, int dest, int type, char *where);
220 void       Jmsg                  (JCR *jcr, int type, time_t mtime, const char *fmt, ...);
221 void       dispatch_message      (JCR *jcr, int type, time_t mtime, char *buf);
222 void       init_console_msg      (const char *wd);
223 void       free_msgs_res         (MSGS *msgs);
224 void       dequeue_messages      (JCR *jcr);
225 void       set_trace             (int trace_flag);
226
227 /* bnet_server.c */
228 void       bnet_thread_server(dlist *addr, int max_clients, workq_t *client_wq,
229                    void *handle_client_request(void *bsock));
230 void       bnet_stop_thread_server(pthread_t tid);
231 void             bnet_server             (int port, void handle_client_request(BSOCK *bsock));
232 int              net_connect             (int port);
233 BSOCK *          bnet_bind               (int port);
234 BSOCK *          bnet_accept             (BSOCK *bsock, char *who);
235
236 /* idcache.c */
237 char *getuser(uid_t uid);
238 void free_getuser_cache();
239 char *getgroup (gid_t gid);
240 void free_getgroup_cache();
241
242 /* python.c */
243 typedef int (EVENT_HANDLER)(JCR *jcr, const char *event);
244 void init_python_interpreter(const char *progname, const char *scripts,
245                              const char *module);
246 void term_python_interpreter();
247 //extern EVENT_HANDLER *generate_daemon_event;
248 int generate_daemon_event(JCR *jcr, const char *event);
249 void lock_python();
250 void unlock_python();
251
252 /* signal.c */
253 void             init_signals             (void terminate(int sig));
254 void             init_stack_dump          (void);
255
256 /* scan.c */
257 void             strip_leading_space     (char *str);
258 void             strip_trailing_junk     (char *str);
259 void             strip_trailing_newline  (char *str);
260
261 void             strip_trailing_slashes  (char *dir);
262 bool             skip_spaces             (char **msg);
263 bool             skip_nonspaces          (char **msg);
264 int              fstrsch                 (const char *a, const char *b);
265 char            *next_arg(char **s);
266 int              parse_args(POOLMEM *cmd, POOLMEM **args, int *argc,
267                         char **argk, char **argv, int max_args);
268 int              parse_args_only(POOLMEM *cmd, POOLMEM **args, int *argc,
269                         char **argk, char **argv, int max_args);
270 void            split_path_and_filename(const char *fname, POOLMEM **path,
271                         int *pnl, POOLMEM **file, int *fnl);
272 int             bsscanf(const char *buf, const char *fmt, ...);
273
274
275 /* tls.c */
276 TLS_CONTEXT      *new_tls_context        (const char *ca_certfile,
277                                           const char *ca_certdir,
278                                           const char *certfile,
279                                           const char *keyfile,
280                                           CRYPTO_PEM_PASSWD_CB *pem_callback,
281                                           const void *pem_userdata,
282                                           const char *dhfile,
283                                           bool verify_peer);
284 void             free_tls_context        (TLS_CONTEXT *ctx);
285 #ifdef HAVE_TLS
286 bool             tls_postconnect_verify_host  (TLS_CONNECTION *tls,
287                                                const char *host);
288 bool             tls_postconnect_verify_cn    (TLS_CONNECTION *tls,
289                                                alist *verify_list);
290 TLS_CONNECTION   *new_tls_connection     (TLS_CONTEXT *ctx, int fd);
291 void             free_tls_connection     (TLS_CONNECTION *tls);
292 bool             tls_bsock_connect       (BSOCK *bsock);
293 bool             tls_bsock_accept        (BSOCK *bsock);
294 void             tls_bsock_shutdown      (BSOCK *bsock);
295 int              tls_bsock_writen        (BSOCK *bsock, char *ptr, int32_t nbytes);
296 int              tls_bsock_readn         (BSOCK *bsock, char *ptr, int32_t nbytes);
297 #endif /* HAVE_TLS */
298
299
300 /* util.c */
301 bool             is_buf_zero             (char *buf, int len);
302 void             lcase                   (char *str);
303 void             bash_spaces             (char *str);
304 void             bash_spaces             (POOL_MEM &pm);
305 void             unbash_spaces           (char *str);
306 void             unbash_spaces           (POOL_MEM &pm);
307 char *           encode_time             (time_t time, char *buf);
308 char *           encode_mode             (mode_t mode, char *buf);
309 int              do_shell_expansion      (char *name, int name_len);
310 void             jobstatus_to_ascii      (int JobStatus, char *msg, int maxlen);
311 int              run_program             (char *prog, int wait, POOLMEM *results);
312 int              run_program_full_output (char *prog, int wait, POOLMEM *results);
313 const char *     job_type_to_str         (int type);
314 const char *     job_status_to_str       (int stat);
315 const char *     job_level_to_str        (int level);
316 void             make_session_key        (char *key, char *seed, int mode);
317 POOLMEM *        edit_job_codes          (JCR *jcr, char *omsg, char *imsg, const char *to);
318 void             set_working_directory   (char *wd);
319 const char *     last_path_separator     (const char *str);
320
321
322 /* watchdog.c */
323 int start_watchdog(void);
324 int stop_watchdog(void);
325 watchdog_t *new_watchdog(void);
326 bool register_watchdog(watchdog_t *wd);
327 bool unregister_watchdog(watchdog_t *wd);
328
329 /* timers.c */
330 btimer_t *start_child_timer(pid_t pid, uint32_t wait);
331 void stop_child_timer(btimer_t *wid);
332 btimer_t *start_thread_timer(pthread_t tid, uint32_t wait);
333 void stop_thread_timer(btimer_t *wid);
334 btimer_t *start_bsock_timer(BSOCK *bs, uint32_t wait);
335 void stop_bsock_timer(btimer_t *wid);