Line data Source code
1 : #include "burp.h"
2 : #include "strlist.h"
3 : #include "conf.h"
4 : #include "log.h"
5 : #include "alloc.h"
6 : #include "cntr.h"
7 : #include "prepend.h"
8 : #include "server/dpth.h"
9 :
10 : #include <assert.h>
11 :
12 127 : enum burp_mode str_to_burp_mode(const char *str)
13 : {
14 127 : if(!strcmp(str, "server"))
15 : return BURP_MODE_SERVER;
16 54 : else if(!strcmp(str, "client"))
17 : return BURP_MODE_CLIENT;
18 0 : logp("Unknown mode setting: %s\n", str);
19 0 : return BURP_MODE_UNSET;
20 : }
21 :
22 : static const char *burp_mode_to_str(enum burp_mode bm)
23 : {
24 0 : switch(bm)
25 : {
26 : case BURP_MODE_UNSET: return "unset";
27 : case BURP_MODE_SERVER: return "server";
28 : case BURP_MODE_CLIENT: return "client";
29 : default: return "unknown";
30 : }
31 : }
32 :
33 1 : enum recovery_method str_to_recovery_method(const char *str)
34 : {
35 1 : if(!strcmp(str, "delete"))
36 : return RECOVERY_METHOD_DELETE;
37 1 : else if(!strcmp(str, "resume"))
38 : return RECOVERY_METHOD_RESUME;
39 0 : logp("Unknown working_dir_recovery_method setting: %s\n", str);
40 0 : return RECOVERY_METHOD_UNSET;
41 : }
42 :
43 0 : const char *recovery_method_to_str(enum recovery_method r)
44 : {
45 0 : switch(r)
46 : {
47 : case RECOVERY_METHOD_DELETE: return "delete";
48 0 : case RECOVERY_METHOD_RESUME: return "resume";
49 0 : default: return "unknown";
50 : }
51 : }
52 :
53 0 : const char *rshash_to_str(enum rshash r)
54 : {
55 0 : switch(r)
56 : {
57 : case RSHASH_UNSET: return "unset";
58 0 : case RSHASH_MD4: return "md4";
59 0 : case RSHASH_BLAKE2: return "blake2";
60 0 : default: return "unknown";
61 : }
62 : }
63 :
64 14 : enum protocol str_to_protocol(const char *str)
65 : {
66 14 : if(!strcmp(str, "0"))
67 : return PROTO_AUTO;
68 14 : else if(!strcmp(str, "1"))
69 : return PROTO_1;
70 6 : else if(!strcmp(str, "2"))
71 : return PROTO_2;
72 0 : logp("Unknown protocol setting: %s\n", str);
73 0 : return PROTO_AUTO;
74 : }
75 :
76 6386 : struct strlist *get_strlist(struct conf *conf)
77 : {
78 6386 : assert(conf->conf_type==CT_STRLIST);
79 6386 : return conf->data.sl;
80 : }
81 :
82 4854 : char *get_string(struct conf *conf)
83 : {
84 4854 : assert(conf->conf_type==CT_STRING);
85 4854 : return conf->data.s;
86 : }
87 :
88 3774 : int get_int(struct conf *conf)
89 : {
90 3774 : assert(conf->conf_type==CT_UINT);
91 3774 : return conf->data.i;
92 : }
93 :
94 476 : uint64_t get_uint64_t(struct conf *conf)
95 : {
96 476 : assert(conf->conf_type==CT_SSIZE_T);
97 476 : return conf->data.uint64;
98 : }
99 :
100 1 : float get_float(struct conf *conf)
101 : {
102 1 : assert(conf->conf_type==CT_FLOAT);
103 1 : return conf->data.f;
104 : }
105 :
106 1 : mode_t get_mode_t(struct conf *conf)
107 : {
108 1 : assert(conf->conf_type==CT_MODE_T);
109 1 : return conf->data.mode;
110 : }
111 :
112 300 : enum burp_mode get_e_burp_mode(struct conf *conf)
113 : {
114 300 : assert(conf->conf_type==CT_E_BURP_MODE);
115 300 : return conf->data.burp_mode;
116 : }
117 :
118 75 : enum protocol get_e_protocol(struct conf *conf)
119 : {
120 390 : assert(conf->conf_type==CT_E_PROTOCOL);
121 390 : return conf->data.protocol;
122 : }
123 :
124 315 : enum protocol get_protocol(struct conf **confs)
125 : {
126 630 : return get_e_protocol(confs[OPT_PROTOCOL]);
127 : }
128 :
129 131 : enum recovery_method get_e_recovery_method(struct conf *conf)
130 : {
131 131 : assert(conf->conf_type==CT_E_RECOVERY_METHOD);
132 131 : return conf->data.recovery_method;
133 : }
134 :
135 100 : enum rshash get_e_rshash(struct conf *conf)
136 : {
137 100 : assert(conf->conf_type==CT_E_RSHASH);
138 100 : return conf->data.rshash;
139 : }
140 :
141 498 : struct cntr *get_cntr(struct conf **confs)
142 : {
143 498 : return confs[OPT_CNTR]->data.cntr;
144 : }
145 :
146 28646 : int set_string(struct conf *conf, const char *s)
147 : {
148 28646 : assert(conf->conf_type==CT_STRING);
149 28646 : if(conf->data.s) free_w(&(conf->data.s));
150 28646 : if(s && !(conf->data.s=strdup_w(s, __func__)))
151 : return -1;
152 : return 0;
153 : }
154 :
155 2906 : int set_int(struct conf *conf, unsigned int i)
156 : {
157 2906 : assert(conf->conf_type==CT_UINT);
158 32026 : conf->data.i=i;
159 2906 : return 0;
160 : }
161 :
162 17397 : int set_strlist(struct conf *conf, struct strlist *s)
163 : {
164 17397 : assert(conf->conf_type==CT_STRLIST);
165 17397 : if(conf->data.sl) strlists_free(&conf->data.sl);
166 17397 : conf->data.sl=s;
167 17397 : return 0;
168 : }
169 :
170 0 : int set_float(struct conf *conf, float f)
171 : {
172 0 : assert(conf->conf_type==CT_FLOAT);
173 416 : conf->data.f=f;
174 0 : return 0;
175 : }
176 :
177 127 : int set_e_burp_mode(struct conf *conf, enum burp_mode bm)
178 : {
179 127 : assert(conf->conf_type==CT_E_BURP_MODE);
180 543 : conf->data.burp_mode=bm;
181 127 : return 0;
182 : }
183 :
184 87 : int set_e_protocol(struct conf *conf, enum protocol p)
185 : {
186 224 : assert(conf->conf_type==CT_E_PROTOCOL);
187 640 : conf->data.protocol=p;
188 87 : return 0;
189 : }
190 :
191 137 : int set_protocol(struct conf **confs, enum protocol p)
192 : {
193 274 : return set_e_protocol(confs[OPT_PROTOCOL], p);
194 : }
195 :
196 74 : int set_e_recovery_method(struct conf *conf, enum recovery_method r)
197 : {
198 74 : assert(conf->conf_type==CT_E_RECOVERY_METHOD);
199 490 : conf->data.recovery_method=r;
200 74 : return 0;
201 : }
202 :
203 129 : int set_e_rshash(struct conf *conf, enum rshash r)
204 : {
205 129 : assert(conf->conf_type==CT_E_RSHASH);
206 545 : conf->data.rshash=r;
207 129 : return 0;
208 : }
209 :
210 0 : int set_mode_t(struct conf *conf, mode_t m)
211 : {
212 0 : assert(conf->conf_type==CT_MODE_T);
213 416 : conf->data.mode=m;
214 0 : return 0;
215 : }
216 :
217 368 : int set_uint64_t(struct conf *conf, uint64_t s)
218 : {
219 368 : assert(conf->conf_type==CT_SSIZE_T);
220 3280 : conf->data.uint64=s;
221 368 : return 0;
222 : }
223 :
224 35 : int set_cntr(struct conf *conf, struct cntr *cntr)
225 : {
226 35 : assert(conf->conf_type==CT_CNTR);
227 451 : conf->data.cntr=cntr;
228 35 : return 0;
229 : }
230 :
231 710 : int add_to_strlist(struct conf *conf, const char *value, int include)
232 : {
233 710 : assert(conf->conf_type==CT_STRLIST);
234 710 : if(conf->flags & CONF_FLAG_STRLIST_SORTED)
235 195 : return strlist_add_sorted(&(conf->data.sl), value, include);
236 : else
237 515 : return strlist_add(&(conf->data.sl), value, include);
238 : }
239 :
240 3 : int add_to_strlist_include_uniq(struct conf *conf, const char *value)
241 : {
242 3 : return strlist_add_sorted_uniq(&(conf->data.sl), value, 1);
243 : }
244 :
245 73009 : void conf_free_content(struct conf *c)
246 : {
247 73009 : if(!c) return;
248 70777 : switch(c->conf_type)
249 : {
250 : case CT_STRING:
251 23326 : free_w(&c->data.s);
252 23326 : break;
253 : case CT_STRLIST:
254 15750 : strlists_free(&c->data.sl);
255 15750 : break;
256 : case CT_CNTR:
257 376 : cntr_free(&c->data.cntr);
258 376 : break;
259 : case CT_FLOAT:
260 : case CT_E_BURP_MODE:
261 : case CT_E_PROTOCOL:
262 : case CT_E_RECOVERY_METHOD:
263 : case CT_E_RSHASH:
264 : case CT_UINT:
265 : case CT_MODE_T:
266 : case CT_SSIZE_T:
267 31325 : memset(&c->data, 0, sizeof(c->data));
268 31325 : break;
269 : }
270 : }
271 :
272 12 : void confs_memcpy(struct conf **dst, struct conf **src)
273 : {
274 12 : int i=0;
275 2244 : for(i=0; i<OPT_MAX; i++)
276 : {
277 2232 : free_v((void **)&(dst[i]));
278 2232 : dst[i]=src[i];
279 : }
280 12 : }
281 :
282 12 : void confs_null(struct conf **confs)
283 : {
284 12 : int i=0;
285 12 : if(!confs) return;
286 2232 : for(i=0; i<OPT_MAX; i++) confs[i]=NULL;
287 : }
288 :
289 390 : void confs_free_content(struct conf **confs)
290 : {
291 390 : int i=0;
292 390 : if(!confs) return;
293 72540 : for(i=0; i<OPT_MAX; i++) conf_free_content(confs[i]);
294 : }
295 :
296 : /* Free only stuff related to includes/excludes.
297 : This is so that the server can override them all on the client. */
298 9 : void free_incexcs(struct conf **confs)
299 : {
300 9 : int i=0;
301 9 : if(!confs) return;
302 1674 : for(i=0; i<OPT_MAX; i++)
303 1674 : if(confs[i]->flags & CONF_FLAG_INCEXC)
304 279 : conf_free_content(confs[i]);
305 : }
306 :
307 : static void sc(struct conf *conf, uint8_t flags,
308 : enum conf_type conf_type, const char *field)
309 : {
310 77376 : conf->conf_type=conf_type;
311 77376 : conf->field=field;
312 77376 : conf->flags=flags;
313 74048 : memset(&conf->data, 0, sizeof(conf->data));
314 : }
315 :
316 : static int sc_str(struct conf *conf, const char *def,
317 : uint8_t flags, const char *field)
318 : {
319 50752 : sc(conf, flags, CT_STRING, field);
320 25376 : return set_string(conf, def);
321 : }
322 :
323 : static int sc_int(struct conf *conf, unsigned int def,
324 : uint8_t flags, const char *field)
325 : {
326 58240 : sc(conf, flags, CT_UINT, field);
327 29120 : return set_int(conf, def);
328 : }
329 :
330 : static int sc_lst(struct conf *conf, struct strlist *def,
331 : uint8_t flags, const char *field)
332 : {
333 34112 : sc(conf, flags, CT_STRLIST, field);
334 17056 : return set_strlist(conf, def);
335 : }
336 :
337 : static int sc_flt(struct conf *conf, float def,
338 : uint8_t flags, const char *field)
339 : {
340 832 : sc(conf, flags, CT_FLOAT, field);
341 416 : return set_float(conf, def);
342 : }
343 :
344 : static int sc_ebm(struct conf *conf, enum burp_mode def,
345 : uint8_t flags, const char *field)
346 : {
347 832 : sc(conf, flags, CT_E_BURP_MODE, field);
348 416 : return set_e_burp_mode(conf, def);
349 : }
350 :
351 : static int sc_epr(struct conf *conf, enum protocol def,
352 : uint8_t flags, const char *field)
353 : {
354 832 : sc(conf, flags, CT_E_PROTOCOL, field);
355 416 : return set_e_protocol(conf, def);
356 : }
357 :
358 : static int sc_rec(struct conf *conf, enum recovery_method def,
359 : uint8_t flags, const char *field)
360 : {
361 832 : sc(conf, flags, CT_E_RECOVERY_METHOD, field);
362 416 : return set_e_recovery_method(conf, def);
363 : }
364 :
365 : static int sc_rsh(struct conf *conf, enum rshash def,
366 : uint8_t flags, const char *field)
367 : {
368 832 : sc(conf, flags, CT_E_RSHASH, field);
369 416 : return set_e_rshash(conf, def);
370 : }
371 :
372 : static int sc_mod(struct conf *conf, mode_t def,
373 : uint8_t flags, const char *field)
374 : {
375 832 : sc(conf, flags, CT_MODE_T, field);
376 416 : return set_mode_t(conf, def);
377 : }
378 :
379 : static int sc_u64(struct conf *conf, uint64_t def,
380 : uint8_t flags, const char *field)
381 : {
382 5824 : sc(conf, flags, CT_SSIZE_T, field);
383 2912 : return set_uint64_t(conf, def);
384 : }
385 :
386 : static int sc_cntr(struct conf *conf, struct cntr *def,
387 : uint8_t flags, const char *field)
388 : {
389 832 : sc(conf, flags, CT_CNTR, field);
390 416 : return set_cntr(conf, def);
391 : }
392 :
393 77376 : static int reset_conf(struct conf **c, enum conf_opt o)
394 : {
395 : // Do this with a switch statement, so that we get compiler warnings
396 : // if anything is missed.
397 77376 : switch(o)
398 : {
399 : case OPT_BURP_MODE:
400 832 : return sc_ebm(c[o], BURP_MODE_UNSET, 0, "mode");
401 : case OPT_LOCKFILE:
402 832 : return sc_str(c[o], 0, 0, "lockfile");
403 : case OPT_PIDFILE:
404 832 : return sc_str(c[o], 0, 0, "pidfile");
405 : case OPT_SSL_CERT_CA:
406 832 : return sc_str(c[o], 0, 0, "ssl_cert_ca");
407 : case OPT_SSL_CERT:
408 832 : return sc_str(c[o], 0, 0, "ssl_cert");
409 : case OPT_SSL_KEY:
410 832 : return sc_str(c[o], 0, 0, "ssl_key");
411 : case OPT_SSL_KEY_PASSWORD:
412 : // FIX THIS: synonym: ssl_cert_password
413 832 : return sc_str(c[o], 0, 0, "ssl_key_password");
414 : case OPT_SSL_PEER_CN:
415 832 : return sc_str(c[o], 0, 0, "ssl_peer_cn");
416 : case OPT_SSL_CIPHERS:
417 832 : return sc_str(c[o], 0, 0, "ssl_ciphers");
418 : case OPT_SSL_COMPRESSION:
419 832 : return sc_int(c[o], 5, 0, "ssl_compression");
420 : case OPT_SSL_VERIFY_PEER_EARLY:
421 832 : return sc_int(c[o], 0, 0, "ssl_verify_peer_early");
422 : case OPT_RATELIMIT:
423 832 : return sc_flt(c[o], 0, 0, "ratelimit");
424 : case OPT_NETWORK_TIMEOUT:
425 832 : return sc_int(c[o], 60*60*2, 0, "network_timeout");
426 : case OPT_CLIENT_IS_WINDOWS:
427 832 : return sc_int(c[o], 0, 0, "client_is_windows");
428 : case OPT_PEER_VERSION:
429 832 : return sc_str(c[o], 0, 0, "peer_version");
430 : case OPT_PORT:
431 832 : return sc_lst(c[o], 0, 0, "port");
432 : case OPT_STATUS_PORT:
433 832 : return sc_lst(c[o], 0, 0, "status_port");
434 : case OPT_LISTEN:
435 832 : return sc_lst(c[o], 0, 0, "listen");
436 : case OPT_LISTEN_STATUS:
437 832 : return sc_lst(c[o], 0, 0, "listen_status");
438 : case OPT_PORT_BACKUP:
439 832 : return sc_int(c[o], 0, 0, "port_backup");
440 : case OPT_PORT_RESTORE:
441 832 : return sc_int(c[o], 0, 0, "port_restore");
442 : case OPT_PORT_VERIFY:
443 832 : return sc_int(c[o], 0, 0, "port_verify");
444 : case OPT_PORT_LIST:
445 832 : return sc_int(c[o], 0, 0, "port_list");
446 : case OPT_PORT_DELETE:
447 832 : return sc_int(c[o], 0, 0, "port_delete");
448 : case OPT_SSL_DHFILE:
449 832 : return sc_str(c[o], 0, 0, "ssl_dhfile");
450 : case OPT_MAX_CHILDREN:
451 832 : return sc_lst(c[o], 0, 0, "max_children");
452 : case OPT_MAX_STATUS_CHILDREN:
453 832 : return sc_lst(c[o], 0, 0, "max_status_children");
454 : case OPT_CLIENT_LOCKDIR:
455 832 : return sc_str(c[o], 0, CONF_FLAG_CC_OVERRIDE, "client_lockdir");
456 : case OPT_UMASK:
457 832 : return sc_mod(c[o], 0022, 0, "umask");
458 : case OPT_MAX_HARDLINKS:
459 832 : return sc_int(c[o], 10000, 0, "max_hardlinks");
460 : case OPT_MAX_STORAGE_SUBDIRS:
461 832 : return sc_int(c[o], MAX_STORAGE_SUBDIRS, 0, "max_storage_subdirs");
462 : case OPT_DAEMON:
463 832 : return sc_int(c[o], 1, 0, "daemon");
464 : case OPT_CA_CONF:
465 832 : return sc_str(c[o], 0, 0, "ca_conf");
466 : case OPT_CA_NAME:
467 832 : return sc_str(c[o], 0, 0, "ca_name");
468 : case OPT_CA_SERVER_NAME:
469 832 : return sc_str(c[o], 0, 0, "ca_server_name");
470 : case OPT_CA_BURP_CA:
471 832 : return sc_str(c[o], 0, 0, "ca_" PACKAGE_TARNAME "_ca");
472 : case OPT_CA_CRL:
473 832 : return sc_str(c[o], 0, 0, "ca_crl");
474 : case OPT_CA_CRL_CHECK:
475 832 : return sc_int(c[o], 0, 0, "ca_crl_check");
476 : case OPT_RBLK_MEMORY_MAX:
477 832 : return sc_u64(c[o], 256*1024*1024, // 256 Mb.
478 : CONF_FLAG_CC_OVERRIDE, "rblk_memory_max");
479 : case OPT_SPARSE_SIZE_MAX:
480 832 : return sc_u64(c[o], 256*1024*1024, // 256 Mb.
481 : CONF_FLAG_CC_OVERRIDE, "sparse_size_max");
482 : case OPT_MONITOR_LOGFILE:
483 832 : return sc_str(c[o], 0, 0, "monitor_logfile");
484 : case OPT_MONITOR_EXE:
485 832 : return sc_str(c[o], 0, 0, "monitor_exe");
486 : case OPT_BACKUP_FAILOVERS_LEFT:
487 832 : return sc_int(c[o], 0, 0, "");
488 : case OPT_CNAME:
489 832 : return sc_str(c[o], 0, 0, "cname");
490 : case OPT_CNAME_LOWERCASE:
491 832 : return sc_int(c[o], 0, 0, "cname_lowercase");
492 : case OPT_CNAME_FQDN:
493 832 : return sc_int(c[o], 1, 0, "cname_fqdn");
494 : case OPT_PASSWORD:
495 832 : return sc_str(c[o], 0, 0, "password");
496 : case OPT_PASSWD:
497 832 : return sc_str(c[o], 0, 0, "passwd");
498 : case OPT_SERVER:
499 832 : return sc_str(c[o], 0, 0, "server");
500 : case OPT_SERVER_FAILOVER:
501 832 : return sc_lst(c[o], 0, 0, "server_failover");
502 : case OPT_FAILOVER_ON_BACKUP_ERROR:
503 832 : return sc_int(c[o], 0, 0, "failover_on_backup_error");
504 : case OPT_ENCRYPTION_PASSWORD:
505 832 : return sc_str(c[o], 0, 0, "encryption_password");
506 : case OPT_AUTOUPGRADE_OS:
507 832 : return sc_str(c[o], 0, 0, "autoupgrade_os");
508 : case OPT_AUTOUPGRADE_DIR:
509 832 : return sc_str(c[o], 0, 0, "autoupgrade_dir");
510 : case OPT_CA_CSR_DIR:
511 832 : return sc_str(c[o], 0, 0, "ca_csr_dir");
512 : case OPT_RANDOMISE:
513 832 : return sc_int(c[o], 0, 0, "randomise");
514 : case OPT_RESTORE_LIST:
515 832 : return sc_str(c[o], 0, 0, "restore_list");
516 : case OPT_ENABLED:
517 832 : return sc_int(c[o], 1, CONF_FLAG_CC_OVERRIDE, "enabled");
518 : case OPT_SERVER_CAN_OVERRIDE_INCLUDES:
519 832 : return sc_int(c[o], 1, 0, "server_can_override_includes");
520 : case OPT_BACKUP:
521 832 : return sc_str(c[o], 0, CONF_FLAG_INCEXC_RESTORE, "backup");
522 : case OPT_BACKUP2:
523 832 : return sc_str(c[o], 0, 0, "backup2");
524 : case OPT_RESTOREPREFIX:
525 832 : return sc_str(c[o], 0, CONF_FLAG_INCEXC_RESTORE, "restoreprefix");
526 : case OPT_STRIP_FROM_PATH:
527 832 : return sc_str(c[o], 0, CONF_FLAG_INCEXC_RESTORE, "stripfrompath");
528 : case OPT_BROWSEFILE:
529 832 : return sc_str(c[o], 0, 0, "browsefile");
530 : case OPT_BROWSEDIR:
531 832 : return sc_str(c[o], 0, 0, "browsedir");
532 : case OPT_GLOB_AFTER_SCRIPT_PRE:
533 832 : return sc_int(c[o], 1, 0, "glob_after_script_pre");
534 : case OPT_B_SCRIPT_PRE:
535 832 : return sc_str(c[o], 0, 0, "backup_script_pre");
536 : case OPT_B_SCRIPT_PRE_ARG:
537 832 : return sc_lst(c[o], 0, 0, "backup_script_pre_arg");
538 : case OPT_B_SCRIPT_POST:
539 832 : return sc_str(c[o], 0, 0, "backup_script_post");
540 : case OPT_B_SCRIPT_POST_ARG:
541 832 : return sc_lst(c[o], 0, 0, "backup_script_post_arg");
542 : case OPT_B_SCRIPT_POST_RUN_ON_FAIL:
543 832 : return sc_int(c[o], 0, 0, "backup_script_post_run_on_fail");
544 : case OPT_B_SCRIPT_RESERVED_ARGS:
545 832 : return sc_int(c[o], 1, 0, "backup_script_reserved_args");
546 : case OPT_R_SCRIPT_PRE:
547 832 : return sc_str(c[o], 0, 0, "restore_script_pre");
548 : case OPT_R_SCRIPT_PRE_ARG:
549 832 : return sc_lst(c[o], 0, 0, "restore_script_pre_arg");
550 : case OPT_R_SCRIPT_POST:
551 832 : return sc_str(c[o], 0, 0, "restore_script_post");
552 : case OPT_R_SCRIPT_POST_ARG:
553 832 : return sc_lst(c[o], 0, 0, "restore_script_post_arg");
554 : case OPT_R_SCRIPT_POST_RUN_ON_FAIL:
555 832 : return sc_int(c[o], 0, 0, "restore_script_post_run_on_fail");
556 : case OPT_B_SCRIPT:
557 832 : return sc_str(c[o], 0, 0, "backup_script");
558 : case OPT_B_SCRIPT_ARG:
559 832 : return sc_lst(c[o], 0, 0, "backup_script_arg");
560 : case OPT_R_SCRIPT:
561 832 : return sc_str(c[o], 0, 0, "restore_script");
562 : case OPT_R_SCRIPT_ARG:
563 832 : return sc_lst(c[o], 0, 0, "restore_script_arg");
564 : case OPT_R_SCRIPT_RESERVED_ARGS:
565 832 : return sc_int(c[o], 1, 0, "restore_script_reserved_args");
566 : case OPT_SEND_CLIENT_CNTR:
567 832 : return sc_int(c[o], 0, 0, "send_client_cntr");
568 : case OPT_SUPER_CLIENT:
569 832 : return sc_str(c[o], 0, 0, "");
570 : case OPT_RESTORE_PATH:
571 832 : return sc_str(c[o], 0, 0, "restore_path");
572 : case OPT_ORIG_CLIENT:
573 832 : return sc_str(c[o], 0, CONF_FLAG_INCEXC_RESTORE, "orig_client");
574 : case OPT_CONNECT_CLIENT:
575 832 : return sc_str(c[o], 0, 0, "");
576 : case OPT_CNTR:
577 832 : return sc_cntr(c[o], 0, 0, "");
578 : case OPT_VSS_RESTORE:
579 832 : return sc_int(c[o], VSS_RESTORE_ON, 0, "");
580 : case OPT_READALL:
581 832 : return sc_int(c[o], 0, CONF_FLAG_CC_OVERRIDE, "readall");
582 : case OPT_BREAKPOINT:
583 832 : return sc_int(c[o], 0,
584 : CONF_FLAG_CC_OVERRIDE, "breakpoint");
585 : case OPT_CONFFILE:
586 832 : return sc_str(c[o], 0,
587 : CONF_FLAG_CC_OVERRIDE, "conffile");
588 : case OPT_SYSLOG:
589 832 : return sc_int(c[o], 0,
590 : CONF_FLAG_CC_OVERRIDE, "syslog");
591 : case OPT_STDOUT:
592 832 : return sc_int(c[o], 1,
593 : CONF_FLAG_CC_OVERRIDE, "stdout");
594 : case OPT_PROGRESS_COUNTER:
595 832 : return sc_int(c[o], 0,
596 : CONF_FLAG_CC_OVERRIDE, "progress_counter");
597 : case OPT_USER:
598 832 : return sc_str(c[o], 0,
599 : CONF_FLAG_CC_OVERRIDE, "user");
600 : case OPT_GROUP:
601 832 : return sc_str(c[o], 0,
602 : CONF_FLAG_CC_OVERRIDE, "group");
603 : case OPT_PROTOCOL:
604 832 : return sc_epr(c[o], PROTO_AUTO,
605 : CONF_FLAG_CC_OVERRIDE, "protocol");
606 : case OPT_DIRECTORY:
607 832 : return sc_str(c[o], 0,
608 : CONF_FLAG_CC_OVERRIDE, "directory");
609 : case OPT_TIMESTAMP_FORMAT:
610 832 : return sc_str(c[o], 0,
611 : CONF_FLAG_CC_OVERRIDE, "timestamp_format");
612 : case OPT_CLIENTCONFDIR:
613 832 : return sc_str(c[o], 0,
614 : CONF_FLAG_CC_OVERRIDE, "clientconfdir");
615 : case OPT_FORK:
616 832 : return sc_int(c[o], 1, 0, "fork");
617 : case OPT_DIRECTORY_TREE:
618 832 : return sc_int(c[o], 1,
619 : CONF_FLAG_CC_OVERRIDE, "directory_tree");
620 : case OPT_PASSWORD_CHECK:
621 832 : return sc_int(c[o], 1,
622 : CONF_FLAG_CC_OVERRIDE, "password_check");
623 : case OPT_MANUAL_DELETE:
624 832 : return sc_str(c[o], 0,
625 : CONF_FLAG_CC_OVERRIDE, "manual_delete");
626 : case OPT_MONITOR_BROWSE_CACHE:
627 832 : return sc_int(c[o], 0,
628 : CONF_FLAG_CC_OVERRIDE, "monitor_browse_cache");
629 : case OPT_S_SCRIPT_PRE:
630 832 : return sc_str(c[o], 0,
631 : CONF_FLAG_CC_OVERRIDE, "server_script_pre");
632 : case OPT_S_SCRIPT_PRE_ARG:
633 832 : return sc_lst(c[o], 0,
634 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "server_script_pre_arg");
635 : case OPT_S_SCRIPT_PRE_NOTIFY:
636 832 : return sc_int(c[o], 0,
637 : CONF_FLAG_CC_OVERRIDE, "server_script_pre_notify");
638 : case OPT_S_SCRIPT_POST:
639 832 : return sc_str(c[o], 0,
640 : CONF_FLAG_CC_OVERRIDE, "server_script_post");
641 : case OPT_S_SCRIPT_POST_ARG:
642 832 : return sc_lst(c[o], 0,
643 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "server_script_post_arg");
644 : case OPT_S_SCRIPT_POST_RUN_ON_FAIL:
645 832 : return sc_int(c[o], 0,
646 : CONF_FLAG_CC_OVERRIDE, "server_script_post_run_on_fail");
647 : case OPT_S_SCRIPT_POST_NOTIFY:
648 832 : return sc_int(c[o], 0,
649 : CONF_FLAG_CC_OVERRIDE, "server_script_post_notify");
650 : case OPT_S_SCRIPT:
651 832 : return sc_str(c[o], 0,
652 : CONF_FLAG_CC_OVERRIDE, "server_script");
653 : case OPT_S_SCRIPT_ARG:
654 832 : return sc_lst(c[o], 0,
655 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "server_script_arg");
656 : case OPT_S_SCRIPT_NOTIFY:
657 832 : return sc_int(c[o], 0,
658 : CONF_FLAG_CC_OVERRIDE, "server_script_notify");
659 : case OPT_HARDLINKED_ARCHIVE:
660 832 : return sc_int(c[o], 0,
661 : CONF_FLAG_CC_OVERRIDE, "hardlinked_archive");
662 : case OPT_KEEP:
663 832 : return sc_lst(c[o], 0,
664 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "keep");
665 : case OPT_LIBRSYNC:
666 832 : return sc_int(c[o], 1,
667 : CONF_FLAG_CC_OVERRIDE, "librsync");
668 : case OPT_LIBRSYNC_MAX_SIZE:
669 832 : return sc_u64(c[o], 0,
670 : CONF_FLAG_CC_OVERRIDE, "librsync_max_size");
671 : case OPT_COMPRESSION:
672 832 : return sc_int(c[o], 9,
673 : CONF_FLAG_CC_OVERRIDE, "compression");
674 : case OPT_VERSION_WARN:
675 832 : return sc_int(c[o], 1,
676 : CONF_FLAG_CC_OVERRIDE, "version_warn");
677 : case OPT_PATH_LENGTH_WARN:
678 832 : return sc_int(c[o], 1,
679 : CONF_FLAG_CC_OVERRIDE, "path_length_warn");
680 : case OPT_HARD_QUOTA:
681 832 : return sc_u64(c[o], 0,
682 : CONF_FLAG_CC_OVERRIDE, "hard_quota");
683 : case OPT_SOFT_QUOTA:
684 832 : return sc_u64(c[o], 0,
685 : CONF_FLAG_CC_OVERRIDE, "soft_quota");
686 : case OPT_TIMER_SCRIPT:
687 832 : return sc_str(c[o], 0,
688 : CONF_FLAG_CC_OVERRIDE, "timer_script");
689 : case OPT_TIMER_ARG:
690 832 : return sc_lst(c[o], 0,
691 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "timer_arg");
692 : case OPT_LABEL:
693 832 : return sc_lst(c[o], 0,
694 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "label");
695 : case OPT_N_SUCCESS_SCRIPT:
696 832 : return sc_str(c[o], 0,
697 : CONF_FLAG_CC_OVERRIDE, "notify_success_script");
698 : case OPT_N_SUCCESS_ARG:
699 832 : return sc_lst(c[o], 0,
700 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "notify_success_arg");
701 : case OPT_N_SUCCESS_WARNINGS_ONLY:
702 832 : return sc_int(c[o], 0,
703 : CONF_FLAG_CC_OVERRIDE, "notify_success_warnings_only");
704 : case OPT_N_SUCCESS_CHANGES_ONLY:
705 832 : return sc_int(c[o], 0,
706 : CONF_FLAG_CC_OVERRIDE, "notify_success_changes_only");
707 : case OPT_N_FAILURE_SCRIPT:
708 832 : return sc_str(c[o], 0,
709 : CONF_FLAG_CC_OVERRIDE, "notify_failure_script");
710 : case OPT_N_FAILURE_ARG:
711 832 : return sc_lst(c[o], 0,
712 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_REPLACE, "notify_failure_arg");
713 : case OPT_N_FAILURE_BACKUP_FAILOVERS_LEFT:
714 832 : return sc_int(c[o], 1,
715 : CONF_FLAG_CC_OVERRIDE, "notify_failure_on_backup_with_failovers_left");
716 : case OPT_RESTORE_CLIENTS:
717 832 : return sc_lst(c[o], 0,
718 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_SORTED, "restore_client");
719 : case OPT_SUPER_CLIENTS:
720 832 : return sc_lst(c[o], 0,
721 : CONF_FLAG_CC_OVERRIDE|CONF_FLAG_STRLIST_SORTED, "super_client");
722 : case OPT_DEDUP_GROUP:
723 832 : return sc_str(c[o], 0,
724 : CONF_FLAG_CC_OVERRIDE, "dedup_group");
725 : case OPT_CLIENT_CAN_DELETE:
726 832 : return sc_int(c[o], 1,
727 : CONF_FLAG_CC_OVERRIDE, "client_can_delete");
728 : case OPT_CLIENT_CAN_DIFF:
729 832 : return sc_int(c[o], 1,
730 : CONF_FLAG_CC_OVERRIDE, "client_can_diff");
731 : case OPT_CLIENT_CAN_FORCE_BACKUP:
732 832 : return sc_int(c[o], 1,
733 : CONF_FLAG_CC_OVERRIDE, "client_can_force_backup");
734 : case OPT_CLIENT_CAN_LIST:
735 832 : return sc_int(c[o], 1,
736 : CONF_FLAG_CC_OVERRIDE, "client_can_list");
737 : case OPT_CLIENT_CAN_MONITOR:
738 832 : return sc_int(c[o], 1,
739 : CONF_FLAG_CC_OVERRIDE, "client_can_monitor");
740 : case OPT_CLIENT_CAN_RESTORE:
741 832 : return sc_int(c[o], 1,
742 : CONF_FLAG_CC_OVERRIDE, "client_can_restore");
743 : case OPT_CLIENT_CAN_VERIFY:
744 832 : return sc_int(c[o], 1,
745 : CONF_FLAG_CC_OVERRIDE, "client_can_verify");
746 : case OPT_SERVER_CAN_RESTORE:
747 832 : return sc_int(c[o], 1,
748 : CONF_FLAG_CC_OVERRIDE, "server_can_restore");
749 : case OPT_WORKING_DIR_RECOVERY_METHOD:
750 832 : return sc_rec(c[o], RECOVERY_METHOD_DELETE,
751 : CONF_FLAG_CC_OVERRIDE, "working_dir_recovery_method");
752 : case OPT_MAX_RESUME_ATTEMPTS:
753 832 : return sc_int(c[o], 0,
754 : CONF_FLAG_CC_OVERRIDE, "max_resume_attempts");
755 : case OPT_FAIL_ON_WARNING:
756 832 : return sc_int(c[o], 0,
757 : CONF_FLAG_CC_OVERRIDE, "fail_on_warning");
758 : case OPT_RSHASH:
759 832 : return sc_rsh(c[o], RSHASH_UNSET,
760 : CONF_FLAG_CC_OVERRIDE, "");
761 : case OPT_MESSAGE:
762 832 : return sc_int(c[o], 0,
763 : CONF_FLAG_CC_OVERRIDE, "");
764 : case OPT_INCEXCDIR:
765 : // This is a combination of OPT_INCLUDE and OPT_EXCLUDE, so
766 : // no field name set for now.
767 832 : return sc_lst(c[o], 0, CONF_FLAG_STRLIST_SORTED, "incexcdir");
768 : case OPT_STARTDIR:
769 : // This is a combination of OPT_INCLUDE and OPT_EXCLUDE, so
770 : // no field name set for now.
771 : // Deliberately not using CONF_FLAG_STRLIST_SORTED because of the
772 : // way finalise_start_dirs() works.
773 832 : return sc_lst(c[o], 0, 0, "startdir");
774 : case OPT_INCLUDE:
775 : // Combines with OPT_EXCLUDE to make OPT_INCEXCDIR and OPT_STARTDIR.
776 832 : return sc_lst(c[o], 0,
777 : CONF_FLAG_INCEXC|CONF_FLAG_INCEXC_RESTORE|CONF_FLAG_STRLIST_SORTED, "include");
778 : case OPT_EXCLUDE:
779 : // Combines with OPT_INCLUDE to make OPT_INCEXCDIR and OPT_STARTDIR.
780 832 : return sc_lst(c[o], 0,
781 : CONF_FLAG_INCEXC|CONF_FLAG_INCEXC_RESTORE|CONF_FLAG_STRLIST_SORTED, "exclude");
782 : case OPT_FSCHGDIR:
783 832 : return sc_lst(c[o], 0,
784 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "cross_filesystem");
785 : case OPT_NOBACKUP:
786 832 : return sc_lst(c[o], 0,
787 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "nobackup");
788 : case OPT_INCEXT:
789 832 : return sc_lst(c[o], 0,
790 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "include_ext");
791 : case OPT_EXCEXT:
792 832 : return sc_lst(c[o], 0,
793 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "exclude_ext");
794 : case OPT_INCREG:
795 832 : return sc_lst(c[o], 0,
796 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "include_regex");
797 : case OPT_EXCREG:
798 832 : return sc_lst(c[o], 0,
799 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "exclude_regex");
800 : case OPT_INCLOGIC:
801 832 : return sc_lst(c[o], 0,
802 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "include_logic");
803 : case OPT_EXCLOGIC:
804 832 : return sc_lst(c[o], 0,
805 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "exclude_logic");
806 : case OPT_EXCFS:
807 832 : return sc_lst(c[o], 0,
808 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "exclude_fs");
809 : case OPT_INCFS:
810 832 : return sc_lst(c[o], 0,
811 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "include_fs");
812 : case OPT_EXCOM:
813 832 : return sc_lst(c[o], 0,
814 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "exclude_comp");
815 : case OPT_INCGLOB:
816 832 : return sc_lst(c[o], 0,
817 : CONF_FLAG_INCEXC|CONF_FLAG_STRLIST_SORTED, "include_glob");
818 : case OPT_SEED_SRC:
819 832 : return sc_str(c[o], 0, 0, "seed_src");
820 : case OPT_SEED_DST:
821 832 : return sc_str(c[o], 0, 0, "seed_dst");
822 : case OPT_CROSS_ALL_FILESYSTEMS:
823 832 : return sc_int(c[o], 0, CONF_FLAG_INCEXC, "cross_all_filesystems");
824 : case OPT_READ_ALL_FIFOS:
825 832 : return sc_int(c[o], 0, CONF_FLAG_INCEXC, "read_all_fifos");
826 : case OPT_FIFOS:
827 832 : return sc_lst(c[o], 0, CONF_FLAG_INCEXC, "read_fifo");
828 : case OPT_READ_ALL_BLOCKDEVS:
829 832 : return sc_int(c[o], 0, CONF_FLAG_INCEXC, "read_all_blockdevs");
830 : case OPT_BLOCKDEVS:
831 832 : return sc_lst(c[o], 0, CONF_FLAG_INCEXC, "read_blockdev");
832 : case OPT_MIN_FILE_SIZE:
833 832 : return sc_u64(c[o], 0, CONF_FLAG_INCEXC, "min_file_size");
834 : case OPT_MAX_FILE_SIZE:
835 832 : return sc_u64(c[o], 0, CONF_FLAG_INCEXC, "max_file_size");
836 : case OPT_SPLIT_VSS:
837 832 : return sc_int(c[o], 0, CONF_FLAG_INCEXC, "split_vss");
838 : case OPT_STRIP_VSS:
839 832 : return sc_int(c[o], 0, CONF_FLAG_INCEXC, "strip_vss");
840 : case OPT_VSS_DRIVES:
841 832 : return sc_str(c[o], 0, CONF_FLAG_INCEXC, "vss_drives");
842 : case OPT_ACL:
843 832 : return sc_int(c[o], 1, CONF_FLAG_INCEXC, "acl");
844 : case OPT_XATTR:
845 832 : return sc_int(c[o], 1, CONF_FLAG_INCEXC, "xattr");
846 : case OPT_ATIME:
847 832 : return sc_int(c[o], 0, CONF_FLAG_INCEXC, "atime");
848 : case OPT_SCAN_PROBLEM_RAISES_ERROR:
849 832 : return sc_int(c[o], 0, CONF_FLAG_INCEXC, "scan_problem_raises_error");
850 : case OPT_OVERWRITE:
851 832 : return sc_int(c[o], 0,
852 : CONF_FLAG_INCEXC|CONF_FLAG_INCEXC_RESTORE, "overwrite");
853 : case OPT_STRIP:
854 832 : return sc_int(c[o], 0,
855 : CONF_FLAG_INCEXC|CONF_FLAG_INCEXC_RESTORE, "strip");
856 : case OPT_REGEX:
857 832 : return sc_str(c[o], 0,
858 : CONF_FLAG_INCEXC|CONF_FLAG_INCEXC_RESTORE, "regex");
859 : case OPT_MAX:
860 : return 0;
861 : // No default, so we get compiler warnings if something was missed.
862 : }
863 0 : return -1;
864 : }
865 :
866 0 : static int set_conf(struct conf *c, const char *value)
867 : {
868 0 : switch(c->conf_type)
869 : {
870 : case CT_STRING:
871 0 : if(set_string(c, value)) return 1;
872 : break;
873 : case CT_FLOAT:
874 0 : if(set_float(c, atof(value))) return 1;
875 : break;
876 : case CT_E_BURP_MODE:
877 : {
878 : enum burp_mode bm;
879 0 : bm=str_to_burp_mode(value);
880 0 : if(bm==BURP_MODE_UNSET
881 0 : || set_e_burp_mode(c, bm))
882 : return 1;
883 : break;
884 : }
885 : case CT_E_RECOVERY_METHOD:
886 : {
887 : enum recovery_method rm;
888 0 : rm=str_to_recovery_method(value);
889 0 : if(rm==RECOVERY_METHOD_UNSET
890 0 : || set_e_recovery_method(c, rm))
891 : return 1;
892 : break;
893 : }
894 : // FIX THIS
895 : case CT_E_RSHASH:
896 : case CT_UINT:
897 : case CT_MODE_T:
898 : case CT_SSIZE_T:
899 : case CT_E_PROTOCOL:
900 : case CT_STRLIST:
901 : case CT_CNTR:
902 : break;
903 : }
904 : return 0;
905 : }
906 :
907 0 : int conf_set(struct conf **confs, const char *field, const char *value)
908 : {
909 0 : int i=0;
910 0 : int r=0;
911 0 : for(i=0; i<OPT_MAX; i++)
912 : {
913 0 : if(strcmp(confs[i]->field, field)) continue;
914 0 : r+=set_conf(confs[i], value);
915 : }
916 0 : return r;
917 : }
918 :
919 0 : static char *conf_data_to_str(struct conf *conf)
920 : {
921 0 : size_t l=256;
922 0 : char *ret=NULL;
923 0 : if(!conf->field || !*conf->field)
924 : return NULL;
925 0 : if(!(ret=(char *)calloc_w(1, l, __func__))) return ret;
926 0 : *ret='\0';
927 0 : switch(conf->conf_type)
928 : {
929 : case CT_STRING:
930 0 : snprintf(ret, l, "%32s: %s\n", conf->field,
931 0 : get_string(conf)?get_string(conf):"");
932 0 : break;
933 : case CT_FLOAT:
934 0 : snprintf(ret, l, "%32s: %g\n", conf->field,
935 0 : get_float(conf));
936 0 : break;
937 : case CT_E_BURP_MODE:
938 0 : snprintf(ret, l, "%32s: %s\n", conf->field,
939 : burp_mode_to_str(get_e_burp_mode(conf)));
940 0 : break;
941 : case CT_E_PROTOCOL:
942 0 : snprintf(ret, l, "%32s: %d\n", conf->field,
943 0 : get_e_protocol(conf));
944 0 : break;
945 : case CT_E_RECOVERY_METHOD:
946 0 : snprintf(ret, l, "%32s: %s\n", conf->field,
947 : recovery_method_to_str(
948 : get_e_recovery_method(conf)));
949 0 : break;
950 : case CT_E_RSHASH:
951 0 : snprintf(ret, l, "%32s: %s\n", conf->field,
952 : rshash_to_str(get_e_rshash(conf)));
953 0 : break;
954 : case CT_UINT:
955 0 : snprintf(ret, l, "%32s: %u\n", conf->field,
956 : get_int(conf));
957 0 : break;
958 : case CT_STRLIST:
959 : {
960 0 : int count=0;
961 0 : char piece[256]="";
962 : struct strlist *s;
963 0 : for(s=get_strlist(conf); s; s=s->next)
964 : {
965 0 : snprintf(piece, sizeof(piece),
966 : "%32s: %s\n", conf->field, s->path);
967 0 : if(astrcat(&ret, piece, __func__))
968 0 : return ret;
969 0 : count++;
970 : }
971 0 : if(!count)
972 0 : snprintf(ret, l, "%32s:\n", conf->field);
973 0 : break;
974 : }
975 : case CT_MODE_T:
976 0 : snprintf(ret, l, "%32s: %o\n", conf->field,
977 : get_mode_t(conf));
978 0 : break;
979 : case CT_SSIZE_T:
980 0 : snprintf(ret, l, "%32s: %" PRIu64 "\n", conf->field,
981 : get_uint64_t(conf));
982 0 : break;
983 : case CT_CNTR:
984 : break;
985 : }
986 0 : return ret;
987 :
988 : }
989 :
990 362 : struct conf **confs_alloc(void)
991 : {
992 362 : int i=0;
993 362 : struct conf **confs=NULL;
994 362 : if(!(confs=(struct conf **)
995 : calloc_w(OPT_MAX, sizeof(struct conf *), __func__)))
996 : return NULL;
997 67332 : for(i=0; i<OPT_MAX; i++)
998 : {
999 : struct conf *c;
1000 67332 : if(!(c=(struct conf *)
1001 : calloc_w(1, sizeof(struct conf), __func__)))
1002 : return NULL;
1003 67332 : confs[i]=c;
1004 : }
1005 : return confs;
1006 : };
1007 :
1008 396 : void confs_free(struct conf ***confs)
1009 : {
1010 396 : int i=0;
1011 396 : if(!confs || !*confs) return;
1012 362 : confs_free_content(*confs);
1013 67694 : for(i=0; i<OPT_MAX; i++)
1014 67332 : free_v((void **)&((*confs)[i]));
1015 362 : free_v((void **)confs);
1016 362 : *confs=NULL;
1017 : }
1018 :
1019 416 : int confs_init(struct conf **confs)
1020 : {
1021 416 : int i=0;
1022 77792 : for(i=0; i<OPT_MAX; i++)
1023 77376 : if(reset_conf(confs, (enum conf_opt)i))
1024 : return -1;
1025 : return 0;
1026 : }
1027 :
1028 0 : int confs_dump(struct conf **confs, int flags)
1029 : {
1030 0 : int i=0;
1031 0 : char *str=NULL;
1032 0 : for(i=0; i<OPT_MAX; i++)
1033 : {
1034 0 : if(flags && !(flags & confs[i]->flags)) continue;
1035 : // if(!*(confs[i]->field)) continue;
1036 0 : str=conf_data_to_str(confs[i]);
1037 0 : if(str && *str) printf("%s", str);
1038 0 : free_w(&str);
1039 : }
1040 0 : return 0;
1041 : }
|