/
dird_conf.h
676 lines (626 loc) · 29.7 KB
/
dird_conf.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
/*
BAREOS® - Backup Archiving REcovery Open Sourced
Copyright (C) 2000-2011 Free Software Foundation Europe e.V.
Copyright (C) 2011-2012 Planets Communications B.V.
Copyright (C) 2013-2014 Bareos GmbH & Co. KG
This program is Free Software; you can redistribute it and/or
modify it under the terms of version three of the GNU Affero General Public
License as published by the Free Software Foundation and included
in the file LICENSE.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301, USA.
*/
/*
* Director specific configuration and defines
*
* Kern Sibbald, Feb MM
*/
/* NOTE: #includes at the end of this file */
/*
* Program specific config types (start at 50)
*/
enum {
CFG_TYPE_ACL = 50, /* User Access Control List */
CFG_TYPE_AUDIT = 51, /* Auditing Command List */
CFG_TYPE_AUTHPROTOCOLTYPE = 52, /* Authentication Protocol */
CFG_TYPE_AUTHTYPE = 53, /* Authentication Type */
CFG_TYPE_DEVICE = 54, /* Device resource */
CFG_TYPE_JOBTYPE = 55, /* Type of Job */
CFG_TYPE_PROTOCOLTYPE = 56, /* Protocol */
CFG_TYPE_LEVEL = 57, /* Backup Level */
CFG_TYPE_REPLACE = 58, /* Replace option */
CFG_TYPE_SHRTRUNSCRIPT = 59, /* Short Runscript definition */
CFG_TYPE_RUNSCRIPT = 60, /* Runscript */
CFG_TYPE_RUNSCRIPT_CMD = 61, /* Runscript Command */
CFG_TYPE_RUNSCRIPT_TARGET = 62, /* Runscript Target (Host) */
CFG_TYPE_RUNSCRIPT_BOOL = 63, /* Runscript Boolean */
CFG_TYPE_RUNSCRIPT_WHEN = 64, /* Runscript When expression */
CFG_TYPE_MIGTYPE = 65, /* Migration Type */
CFG_TYPE_INCEXC = 66, /* Include/Exclude item */
CFG_TYPE_RUN = 67, /* Schedule Run Command */
CFG_TYPE_ACTIONONPURGE = 68, /* Action to perform on Purge */
CFG_TYPE_FNAME = 80, /* Filename */
CFG_TYPE_PLUGINNAME = 81, /* Pluginname */
CFG_TYPE_EXCLUDEDIR = 82, /* Exclude directory */
CFG_TYPE_OPTIONS = 83, /* Options block */
CFG_TYPE_OPTION = 84, /* Option of Options block */
CFG_TYPE_REGEX = 85, /* Regular Expression */
CFG_TYPE_BASE = 86, /* Basejob Expression */
CFG_TYPE_WILD = 87, /* Wildcard Expression */
CFG_TYPE_PLUGIN = 88, /* Plugin definition */
CFG_TYPE_FSTYPE = 89, /* FileSytem match criterium (UNIX)*/
CFG_TYPE_DRIVETYPE = 90, /* DriveType match criterium (Windows) */
CFG_TYPE_META = 91 /* Meta tag */
};
/*
* Resource codes -- they must be sequential for indexing
*/
enum {
R_DIRECTOR = 1001,
R_CLIENT,
R_JOBDEFS,
R_JOB,
R_STORAGE,
R_CATALOG,
R_SCHEDULE,
R_FILESET,
R_POOL,
R_MSGS,
R_COUNTER,
R_CONSOLE,
R_DEVICE,
R_FIRST = R_DIRECTOR,
R_LAST = R_DEVICE /* keep this updated */
};
/*
* Some resource attributes
*/
enum {
R_NAME = 1020,
R_ADDRESS,
R_PASSWORD,
R_TYPE,
R_BACKUP
};
/*
* Job Level keyword structure
*/
struct s_jl {
const char *level_name; /* level keyword */
uint32_t level; /* level */
int32_t job_type; /* JobType permitting this level */
};
/*
* Job Type keyword structure
*/
struct s_jt {
const char *type_name;
int32_t job_type;
};
/*
* Definition of the contents of each Resource
* Needed for forward references
*/
class SCHEDRES;
class CLIENTRES;
class FILESETRES;
class POOLRES;
class RUNRES;
class DEVICERES;
class RUNSCRIPTRES;
/*
* Director Resource
*
*/
class DIRRES: public BRSRES {
public:
dlist *DIRaddrs;
dlist *DIRsrc_addr; /* Address to source connections from */
s_password password; /* Password for UA access */
char *query_file; /* SQL query file */
char *working_directory; /* WorkingDirectory */
char *scripts_directory; /* ScriptsDirectory */
char *plugin_directory; /* Plugin Directory */
char *plugin_names; /* Plugin names to load */
char *pid_directory; /* PidDirectory */
char *subsys_directory; /* SubsysDirectory */
alist *backend_directories; /* Backend Directories */
MSGSRES *messages; /* Daemon message handler */
uint32_t MaxConcurrentJobs; /* Max concurrent jobs for whole director */
uint32_t MaxConsoleConnect; /* Max concurrent console session */
utime_t FDConnectTimeout; /* timeout for connect in seconds */
utime_t SDConnectTimeout; /* timeout in seconds */
utime_t heartbeat_interval; /* Interval to send heartbeats */
char *tls_ca_certfile; /* TLS CA Certificate File */
char *tls_ca_certdir; /* TLS CA Certificate Directory */
char *tls_crlfile; /* TLS CA Certificate Revocation List File */
char *tls_certfile; /* TLS Server Certificate File */
char *tls_keyfile; /* TLS Server Key File */
char *tls_dhfile; /* TLS Diffie-Hellman Parameters */
alist *tls_allowed_cns; /* TLS Allowed Clients */
TLS_CONTEXT *tls_ctx; /* Shared TLS Context */
utime_t stats_retention; /* Statistics retention period in seconds */
bool tls_authenticate; /* Authenticated with TLS */
bool tls_enable; /* Enable TLS */
bool tls_require; /* Require TLS */
bool tls_verify_peer; /* TLS Verify Peer Certificate */
bool optimize_for_size; /* Optimize daemon for minimum memory size */
bool optimize_for_speed; /* Optimize daemon for speed which may need more memory */
bool nokeepalive; /* Don't use SO_KEEPALIVE on sockets */
bool omit_defaults; /* Omit config variables with default values when dumping the config */
bool ndmp_snooping; /* NDMP Protocol specific snooping enabled */
bool auditing; /* Auditing enabled */
alist *audit_events; /* Specific audit events to enable */
uint32_t ndmp_loglevel; /* NDMP Protocol specific loglevel to use */
uint32_t subscriptions; /* Number of subscribtions available */
uint32_t subscriptions_used; /* Number of subscribtions used */
uint32_t jcr_watchdog_time; /* Absolute time after which a Job gets terminated regardless of its progress */
uint32_t stats_collect_interval; /* Statistics collect interval in seconds */
char *verid; /* Custom Id to print in version command */
char *keyencrkey; /* Key Encryption Key */
};
/*
* Device Resource
*
* This resource is a bit different from the other resources
* because it is not defined in the Director
* by DEVICE { ... }, but rather by a "reference" such as
* DEVICE = xxx; Then when the Director connects to the
* SD, it requests the information about the device.
*/
class DEVICERES : public BRSRES {
public:
bool found; /* found with SD */
int32_t num_writers; /* number of writers */
int32_t max_writers; /* = 1 for files */
int32_t reserved; /* number of reserves */
int32_t num_drives; /* for autochanger */
bool autochanger; /* set if device is autochanger */
bool open; /* drive open */
bool append; /* in append mode */
bool read; /* in read mode */
bool labeled; /* Volume name valid */
bool offline; /* not available */
bool autoselect; /* can be selected via autochanger */
uint32_t PoolId;
char ChangerName[MAX_NAME_LENGTH];
char VolumeName[MAX_NAME_LENGTH];
char MediaType[MAX_NAME_LENGTH];
};
/*
* Console ACL positions
*/
enum {
Job_ACL = 0,
Client_ACL,
Storage_ACL,
Schedule_ACL,
Run_ACL,
Pool_ACL,
Command_ACL,
FileSet_ACL,
Catalog_ACL,
Where_ACL,
PluginOptions_ACL,
Num_ACL /* keep last */
};
/*
* Console Resource
*/
class CONRES : public BRSRES {
public:
s_password password; /* UA server password */
alist *ACL_lists[Num_ACL]; /* pointers to ACLs */
char *tls_ca_certfile; /* TLS CA Certificate File */
char *tls_ca_certdir; /* TLS CA Certificate Directory */
char *tls_crlfile; /* TLS CA Certificate Revocation List File */
char *tls_certfile; /* TLS Server Certificate File */
char *tls_keyfile; /* TLS Server Key File */
char *tls_dhfile; /* TLS Diffie-Hellman Parameters */
alist *tls_allowed_cns; /* TLS Allowed Clients */
TLS_CONTEXT *tls_ctx; /* Shared TLS Context */
bool tls_authenticate; /* Authenticated with TLS */
bool tls_enable; /* Enable TLS */
bool tls_require; /* Require TLS */
bool tls_verify_peer; /* TLS Verify Peer Certificate */
};
/*
* Catalog Resource
*/
class CATRES : public BRSRES {
public:
uint32_t db_port; /* Port */
char *db_address; /* Hostname for remote access */
char *db_socket; /* Socket for local access */
s_password db_password;
char *db_user;
char *db_name;
char *db_driver; /* Select appropriate driver */
uint32_t mult_db_connections; /* set if multiple connections wanted */
bool disable_batch_insert; /* set if batch inserts should be disabled */
uint32_t pooling_min_connections; /* When using sql pooling start with this number of connections to the database */
uint32_t pooling_max_connections; /* When using sql pooling maximum number of connections to the database */
uint32_t pooling_increment_connections; /* When using sql pooling increment the pool with this amount when its to small */
uint32_t pooling_idle_timeout; /* When using sql pooling set this to the number of seconds to keep an idle connection */
uint32_t pooling_validate_timeout; /* When using sql pooling set this to the number of seconds after a idle connection should be validated */
/* Methods */
char *display(POOLMEM *dst); /* Get catalog information */
};
/*
* Client Resource
*/
class CLIENTRES: public BRSRES {
public:
uint32_t Protocol; /* Protocol to use to connect */
uint32_t AuthType; /* Authentication Type to use for protocol */
uint32_t ndmp_loglevel; /* NDMP Protocol specific loglevel to use */
uint32_t ndmp_blocksize; /* NDMP Protocol specific blocksize to use */
uint32_t FDport; /* Where File daemon listens */
uint64_t SoftQuota; /* Soft Quota permitted in bytes */
uint64_t HardQuota; /* Maximum permitted quota in bytes */
uint64_t GraceTime; /* Time remaining on gracetime */
uint64_t QuotaLimit; /* The total softquota supplied if over grace */
utime_t SoftQuotaGracePeriod; /* Grace time for softquota */
utime_t FileRetention; /* file retention period in seconds */
utime_t JobRetention; /* job retention period in seconds */
utime_t heartbeat_interval; /* Interval to send heartbeats */
char *address; /* Hostname for remote access to Client */
char *username; /* Username to use for authentication if protocol supports it */
s_password password;
CATRES *catalog; /* Catalog resource */
int32_t MaxConcurrentJobs; /* Maximum concurrent jobs */
int32_t NumConcurrentJobs; /* number of concurrent jobs running */
char *tls_ca_certfile; /* TLS CA Certificate File */
char *tls_ca_certdir; /* TLS CA Certificate Directory */
char *tls_crlfile; /* TLS CA Certificate Revocation List File */
char *tls_certfile; /* TLS Client Certificate File */
char *tls_keyfile; /* TLS Client Key File */
alist *tls_allowed_cns; /* TLS Allowed Clients */
TLS_CONTEXT *tls_ctx; /* Shared TLS Context */
bool passive; /* Passive Client */
bool enabled; /* Set if client is enabled */
bool tls_authenticate; /* Authenticated with TLS */
bool tls_enable; /* Enable TLS */
bool tls_require; /* Require TLS */
bool AutoPrune; /* Do automatic pruning? */
bool StrictQuotas; /* Enable strict quotas? */
bool QuotaIncludeFailedJobs; /* Ignore failed jobs when calculating quota */
int64_t max_bandwidth; /* Limit speed on this client */
};
/*
* Store Resource
*/
class STORERES : public BRSRES {
public:
uint32_t Protocol; /* Protocol to use to connect */
uint32_t AuthType; /* Authentication Type to use for protocol */
uint32_t SDport; /* Port where Directors connect */
uint32_t SDDport; /* Data port for File daemon */
char *address; /* Hostname for remote access to Storage */
char *username; /* Username to use for authentication if protocol supports it */
s_password password;
char *media_type; /* Media Type provided by this Storage */
alist *device; /* Alternate devices for this Storage */
int32_t MaxConcurrentJobs; /* Maximum concurrent jobs */
int32_t MaxConcurrentReadJobs; /* Maximum concurrent jobs reading */
int32_t NumConcurrentJobs; /* Number of concurrent jobs running */
int32_t NumConcurrentReadJobs; /* Number of jobs reading */
char *tls_ca_certfile; /* TLS CA Certificate File */
char *tls_ca_certdir; /* TLS CA Certificate Directory */
char *tls_crlfile; /* TLS CA Certificate Revocation List File */
char *tls_certfile; /* TLS Client Certificate File */
char *tls_keyfile; /* TLS Client Key File */
TLS_CONTEXT *tls_ctx; /* Shared TLS Context */
bool tls_authenticate; /* Authenticated with TLS */
bool tls_enable; /* Enable TLS */
bool tls_require; /* Require TLS */
bool enabled; /* Set if device is enabled */
bool autochanger; /* Set if autochanger */
bool collectstats; /* Set if statistics should be collected of this SD */
bool AllowCompress; /* Set if this Storage should allow jobs to enable compression */
int64_t StorageId; /* Set from Storage DB record */
int64_t max_bandwidth; /* Limit speed on this storage daemon for replication */
utime_t heartbeat_interval; /* Interval to send heartbeats */
uint32_t drives; /* Number of drives in autochanger */
STORERES *paired_storage; /* Paired storage configuration item for protocols like NDMP */
/* Methods */
char *dev_name() const;
};
inline char *STORERES::dev_name() const
{
DEVICERES *dev = (DEVICERES *)device->first();
return dev->name();
}
/*
* This is a sort of "unified" store that has both the
* storage pointer and the text of where the pointer was
* found.
*/
class USTORERES {
public:
STORERES *store;
POOLMEM *store_source;
/* Methods */
USTORERES() { store = NULL; store_source = get_pool_memory(PM_MESSAGE);
*store_source = 0; };
~USTORERES() { destroy(); }
void set_source(const char *where);
void destroy();
};
inline void USTORERES::destroy()
{
if (store_source) {
free_pool_memory(store_source);
store_source = NULL;
}
}
inline void USTORERES::set_source(const char *where)
{
if (!store_source) {
store_source = get_pool_memory(PM_MESSAGE);
}
pm_strcpy(store_source, where);
}
/*
* Job Resource
*/
class JOBRES : public BRSRES {
public:
uint32_t Protocol; /* Protocol to use to connect */
uint32_t JobType; /* job type (backup, verify, restore */
uint32_t JobLevel; /* default backup/verify level */
int32_t Priority; /* Job priority */
uint32_t RestoreJobId; /* What -- JobId to restore */
int32_t RescheduleTimes; /* Number of times to reschedule job */
uint32_t replace; /* How (overwrite, ..) */
uint32_t selection_type;
char *RestoreWhere; /* Where on disk to restore -- directory */
char *RegexWhere; /* RegexWhere option */
char *strip_prefix; /* remove prefix from filename */
char *add_prefix; /* add prefix to filename */
char *add_suffix; /* add suffix to filename -- .old */
char *backup_format; /* Format of backup to use for protocols supporting multiple backup formats */
char *RestoreBootstrap; /* Bootstrap file */
char *PluginOptions; /* Options to pass to plugin */
union {
char *WriteBootstrap; /* Where to write bootstrap Job updates */
char *WriteVerifyList; /* List of changed files */
};
utime_t MaxRunTime; /* max run time in seconds */
utime_t MaxWaitTime; /* max blocking time in seconds */
utime_t FullMaxRunTime; /* Max Full job run time */
utime_t DiffMaxRunTime; /* Max Differential job run time */
utime_t IncMaxRunTime; /* Max Incremental job run time */
utime_t MaxStartDelay; /* max start delay in seconds */
utime_t MaxRunSchedTime; /* max run time in seconds from Scheduled time*/
utime_t RescheduleInterval; /* Reschedule interval */
utime_t MaxFullInterval; /* Maximum time interval between Fulls */
utime_t MaxDiffInterval; /* Maximum time interval between Diffs */
utime_t DuplicateJobProximity; /* Permitted time between duplicicates */
int64_t spool_size; /* Size of spool file for this job */
int32_t MaxConcurrentJobs; /* Maximum concurrent jobs */
int32_t NumConcurrentJobs; /* number of concurrent jobs running */
bool allow_mixed_priority; /* Allow jobs with higher priority concurrently with this */
MSGSRES *messages; /* How and where to send messages */
SCHEDRES *schedule; /* When -- Automatic schedule */
CLIENTRES *client; /* Who to backup */
FILESETRES *fileset; /* What to backup -- Fileset */
CATRES *catalog; /* Which Catalog to use */
alist *storage; /* Where is device -- list of Storage to be used */
POOLRES *pool; /* Where is media -- Media Pool */
POOLRES *full_pool; /* Pool for Full backups */
POOLRES *inc_pool; /* Pool for Incremental backups */
POOLRES *diff_pool; /* Pool for Differental backups */
POOLRES *next_pool; /* Next Pool for Copy/Migration Jobs and Virtual backups */
char *selection_pattern;
union {
JOBRES *verify_job; /* Job name to verify */
};
JOBRES *jobdefs; /* Job defaults */
alist *run_cmds; /* Run commands */
alist *RunScripts; /* Run {client} program {after|before} Job */
bool where_use_regexp; /* true if RestoreWhere is a BREGEXP */
bool RescheduleOnError; /* Set to reschedule on error */
bool RescheduleIncompleteJobs; /* Set to reschedule incomplete Jobs */
bool PrefixLinks; /* prefix soft links with Where path */
bool PruneJobs; /* Force pruning of Jobs */
bool PruneFiles; /* Force pruning of Files */
bool PruneVolumes; /* Force pruning of Volumes */
bool SpoolAttributes; /* Set to spool attributes in SD */
bool spool_data; /* Set to spool data in SD */
bool rerun_failed_levels; /* Upgrade to rerun failed levels */
bool PreferMountedVolumes; /* Prefer vols mounted rather than new one */
bool write_part_after_job; /* Set to write part after job in SD */
bool enabled; /* Set if job enabled */
bool accurate; /* Set if it is an accurate backup job */
bool AllowDuplicateJobs; /* Allow duplicate jobs */
bool AllowHigherDuplicates; /* Permit Higher Level */
bool CancelLowerLevelDuplicates; /* Cancel lower level backup jobs */
bool CancelQueuedDuplicates; /* Cancel queued jobs */
bool CancelRunningDuplicates; /* Cancel Running jobs */
bool PurgeMigrateJob; /* Purges source job on completion */
bool IgnoreDuplicateJobChecking; /* Ignore Duplicate Job Checking */
bool SaveFileHist; /* Ability to disable File history saving for certain protocols */
alist *base; /* Base jobs */
int64_t max_bandwidth; /* Speed limit on this job */
/* Methods */
};
#undef MAX_FOPTS
#define MAX_FOPTS 40
/*
* File options structure
*/
struct FOPTS {
char opts[MAX_FOPTS]; /* Options string */
alist regex; /* Regex string(s) */
alist regexdir; /* Regex string(s) for directories */
alist regexfile; /* Regex string(s) for files */
alist wild; /* Wild card strings */
alist wilddir; /* Wild card strings for directories */
alist wildfile; /* Wild card strings for files */
alist wildbase; /* Wild card strings for files without '/' */
alist base; /* List of base names */
alist fstype; /* File system type limitation */
alist drivetype; /* Drive type limitation */
alist meta; /* Backup meta information */
char *reader; /* Reader program */
char *writer; /* Writer program */
char *plugin; /* Plugin program */
};
/*
* This is either an include item or an exclude item
*/
struct INCEXE {
FOPTS *current_opts; /* Points to current options structure */
FOPTS **opts_list; /* Options list */
int32_t num_opts; /* Number of options items */
alist name_list; /* Filename list -- holds char * */
alist plugin_list; /* Filename list for plugins */
alist ignoredir; /* Ignoredir string */
};
/*
* FileSet Resource
*/
class FILESETRES {
public:
RES hdr;
bool new_include; /* Set if new include used */
INCEXE **include_items; /* Array of incexe structures */
int32_t num_includes; /* Number in array */
INCEXE **exclude_items;
int32_t num_excludes;
bool have_MD5; /* Set if MD5 initialized */
struct MD5Context md5c; /* MD5 of include/exclude */
char MD5[30]; /* Base 64 representation of MD5 */
bool ignore_fs_changes; /* Don't force Full if FS changed */
bool enable_vss; /* Enable Volume Shadow Copy */
/* Methods */
char *name() const;
bool print_config(POOL_MEM& buff);
};
inline char *FILESETRES::name() const { return hdr.name; }
/*
* Schedule Resource
*/
class SCHEDRES: public BRSRES {
public:
RUNRES *run;
bool enabled; /* Set if schedule is enabled */
};
/*
* Counter Resource
*/
class COUNTERRES: public BRSRES {
public:
int32_t MinValue; /* Minimum value */
int32_t MaxValue; /* Maximum value */
int32_t CurrentValue ; /* Current value */
COUNTERRES *WrapCounter; /* Wrap counter name */
CATRES *Catalog; /* Where to store */
bool created; /* Created in DB */
};
/*
* Pool Resource
*/
class POOLRES: public BRSRES {
public:
char *pool_type; /* Pool type */
char *label_format; /* Label format string */
char *cleaning_prefix; /* Cleaning label prefix */
int32_t LabelType; /* Bareos/ANSI/IBM label type */
uint32_t max_volumes; /* max number of volumes */
utime_t VolRetention; /* volume retention period in seconds */
utime_t VolUseDuration; /* duration volume can be used */
uint32_t MaxVolJobs; /* Maximum jobs on the Volume */
uint32_t MaxVolFiles; /* Maximum files on the Volume */
uint64_t MaxVolBytes; /* Maximum bytes on the Volume */
utime_t MigrationTime; /* Time to migrate to next pool */
uint64_t MigrationHighBytes; /* When migration starts */
uint64_t MigrationLowBytes; /* When migration stops */
POOLRES *NextPool; /* Next pool for migration */
alist *storage; /* Where is device -- list of Storage to be used */
bool use_catalog; /* maintain catalog for media */
bool catalog_files; /* maintain file entries in catalog */
bool use_volume_once; /* write on volume only once */
bool purge_oldest_volume; /* purge oldest volume */
bool recycle_oldest_volume; /* attempt to recycle oldest volume */
bool recycle_current_volume; /* attempt recycle of current volume */
bool AutoPrune; /* default for pool auto prune */
bool Recycle; /* default for media recycle yes/no */
uint32_t action_on_purge; /* action on purge, e.g. truncate the disk volume */
POOLRES *RecyclePool; /* RecyclePool destination when media is purged */
POOLRES *ScratchPool; /* ScratchPool source when requesting media */
alist *CopyPool; /* List of copy pools */
CATRES *catalog; /* Catalog to be used */
utime_t FileRetention; /* file retention period in seconds */
utime_t JobRetention; /* job retention period in seconds */
uint32_t MinBlocksize; /* Minimum Blocksize */
uint32_t MaxBlocksize; /* Maximum Blocksize */
};
/*
* Define the Union of all the above
* resource structure definitions.
*/
union URES {
DIRRES res_dir;
CONRES res_con;
CLIENTRES res_client;
STORERES res_store;
CATRES res_cat;
JOBRES res_job;
FILESETRES res_fs;
SCHEDRES res_sch;
POOLRES res_pool;
MSGSRES res_msgs;
COUNTERRES res_counter;
DEVICERES res_dev;
RES hdr;
};
/*
* Run structure contained in Schedule Resource
*/
class RUNRES: public BRSRES {
public:
RUNRES *next; /* points to next run record */
uint32_t level; /* level override */
int32_t Priority; /* priority override */
uint32_t job_type;
utime_t MaxRunSchedTime; /* max run time in sec from Sched time */
bool MaxRunSchedTime_set; /* MaxRunSchedTime given */
bool spool_data; /* Data spooling override */
bool spool_data_set; /* Data spooling override given */
bool accurate; /* accurate */
bool accurate_set; /* accurate given */
POOLRES *pool; /* Pool override */
POOLRES *full_pool; /* Full Pool override */
POOLRES *inc_pool; /* Incr Pool override */
POOLRES *diff_pool; /* Diff Pool override */
POOLRES *next_pool; /* Next Pool override */
STORERES *storage; /* Storage override */
MSGSRES *msgs; /* Messages override */
char *since;
uint32_t level_no;
uint32_t minute; /* minute to run job */
time_t last_run; /* last time run */
time_t next_run; /* next time to run */
char hour[nbytes_for_bits(24 + 1)]; /* bit set for each hour */
char mday[nbytes_for_bits(31 + 1)]; /* bit set for each day of month */
char month[nbytes_for_bits(12 + 1)]; /* bit set for each month */
char wday[nbytes_for_bits(7 + 1)]; /* bit set for each day of the week */
char wom[nbytes_for_bits(5 + 1)]; /* week of month */
char woy[nbytes_for_bits(54 + 1)]; /* week of year */
bool last_set; /* last week of month */
};
#define GetPoolResWithName(x) ((POOLRES *)GetResWithName(R_POOL, (x)))
#define GetStoreResWithName(x) ((STORERES *)GetResWithName(R_STORAGE, (x)))
#define GetClientResWithName(x) ((CLIENTRES *)GetResWithName(R_CLIENT, (x)))
#define GetJobResWithName(x) ((JOBRES *)GetResWithName(R_JOB, (x)))
#define GetFileSetResWithName(x) ((FILESETRES *)GetResWithName(R_FILESET, (x)))
#define GetCatalogResWithName(x) ((CATRES *)GetResWithName(R_CATALOG, (x)))
#define GetScheduleResWithName(x) ((SCHEDRES *)GetResWithName(R_SCHEDULE, (x)))