]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/filed/fd_plugins.h
Apply James' plugin patch
[bacula/bacula] / bacula / src / filed / fd_plugins.h
1 /*
2    Bacula® - The Network Backup Solution
3
4    Copyright (C) 2007-2010 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, which is 
11    listed 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 Kern Sibbald.
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  * Application Programming Interface (API) definition for Bacula Plugins
30  *
31  * Kern Sibbald, October 2007
32  *
33  */
34  
35 #ifndef __FD_PLUGINS_H 
36 #define __FD_PLUGINS_H
37
38 #ifndef _BACULA_H
39 #ifdef __cplusplus
40 /* Workaround for SGI IRIX 6.5 */
41 #define _LANGUAGE_C_PLUS_PLUS 1
42 #endif
43 #define _REENTRANT    1
44 #define _THREAD_SAFE  1
45 #define _POSIX_PTHREAD_SEMANTICS 1
46 #define _FILE_OFFSET_BITS 64
47 #define _LARGEFILE_SOURCE 1
48 #define _LARGE_FILES 1
49 #endif  /* ! _BACULA_H */
50
51 #include <sys/types.h>
52
53 #if defined(HAVE_WIN32)
54 #if defined(HAVE_MINGW)
55 #include "mingwconfig.h"
56 #else
57 #include "winconfig.h"
58 #endif
59 #else  /* !HAVE_WIN32 */
60 #ifndef __CONFIG_H
61 #include "config.h"
62 #define __CONFIG_H
63 #endif
64 #endif
65
66 #include "bc_types.h"
67 #include "lib/plugins.h"
68 #include <sys/stat.h>
69 #ifdef HAVE_WIN32
70 #include "../win32/filed/vss.h"
71 #endif
72
73 /*
74  * This packet is used for file save info transfer.
75 */
76 struct save_pkt {
77    int32_t pkt_size;                  /* size of this packet */
78    char *fname;                       /* Full path and filename */
79    char *link;                        /* Link name if any */
80    struct stat statp;                 /* System stat() packet for file */
81    int32_t type;                      /* FT_xx for this file */             
82    uint32_t flags;                    /* Bacula internal flags */
83    bool portable;                     /* set if data format is portable */
84    char *cmd;                         /* command */
85    int32_t pkt_end;                   /* end packet sentinel */
86 };
87
88 /*
89  * This packet is used for file restore info transfer.
90 */
91 struct restore_pkt {
92    int32_t pkt_size;                  /* size of this packet */
93    int32_t stream;                    /* attribute stream id */
94    int32_t data_stream;               /* id of data stream to follow */
95    int32_t type;                      /* file type FT */
96    int32_t file_index;                /* file index */
97    int32_t LinkFI;                    /* file index to data if hard link */
98    uid_t uid;                         /* userid */
99    struct stat statp;                 /* decoded stat packet */
100    const char *attrEx;                /* extended attributes if any */
101    const char *ofname;                /* output filename */
102    const char *olname;                /* output link name */
103    const char *where;                 /* where */
104    const char *RegexWhere;            /* regex where */
105    int replace;                       /* replace flag */
106    int create_status;                 /* status from createFile() */
107    int32_t pkt_end;                   /* end packet sentinel */
108 };
109
110 enum {
111    IO_OPEN = 1,
112    IO_READ = 2,
113    IO_WRITE = 3,
114    IO_CLOSE = 4,
115    IO_SEEK = 5
116 };
117
118 struct io_pkt {
119    int32_t pkt_size;                  /* Size of this packet */
120    int32_t func;                      /* Function code */
121    int32_t count;                     /* read/write count */
122    int32_t flags;                     /* Open flags */
123    mode_t mode;                       /* permissions for created files */
124    char *buf;                         /* read/write buffer */
125    const char *fname;                 /* open filename */
126    int32_t status;                    /* return status */
127    int32_t io_errno;                  /* errno code */  
128    int32_t lerror;                    /* Win32 error code */
129    int32_t whence;                    /* lseek argument */
130    boffset_t offset;                  /* lseek argument */
131    bool win32;                        /* Win32 GetLastError returned */
132    int32_t pkt_end;                   /* end packet sentinel */
133 };
134
135 /****************************************************************************
136  *                                                                          *
137  *                Bacula definitions                                        *
138  *                                                                          *
139  ****************************************************************************/
140
141 /* Bacula Variable Ids */
142 typedef enum {
143   bVarJobId     = 1,
144   bVarFDName    = 2,
145   bVarLevel     = 3,
146   bVarType      = 4,
147   bVarClient    = 5,
148   bVarJobName   = 6,
149   bVarJobStatus = 7,
150   bVarSinceTime = 8,
151   bVarAccurate  = 9,
152   bVarFileSeen  = 10,
153   bVarVssObject = 11,
154   bVarVssDllHandle = 12
155 } bVariable;
156
157 /* Events that are passed to plugin */
158 typedef enum {
159   bEventJobStart        = 1,
160   bEventJobEnd          = 2,
161   bEventStartBackupJob  = 3,
162   bEventEndBackupJob    = 4,
163   bEventStartRestoreJob = 5,
164   bEventEndRestoreJob   = 6,
165   bEventStartVerifyJob  = 7,
166   bEventEndVerifyJob    = 8,
167   bEventBackupCommand   = 9,
168   bEventRestoreCommand  = 10,
169   bEventLevel           = 11,
170   bEventSince           = 12,
171   bEventCancelCommand   = 13,
172   bEventInitializeVSS   = 14,
173   bEventPrepareVSS      = 15,
174 } bEventType;
175
176 typedef struct s_bEvent {
177    uint32_t eventType;
178 } bEvent;
179
180 typedef struct s_baculaInfo {
181    uint32_t size;
182    uint32_t version;
183 } bInfo;
184
185 /* Bacula Core Routines -- not used within a plugin */
186 #ifdef FILE_DAEMON
187 struct BFILE;                   /* forward referenced */
188 struct FF_PKT;
189 void load_fd_plugins(const char *plugin_dir);
190 void new_plugins(JCR *jcr);
191 void free_plugins(JCR *jcr);
192 void generate_plugin_event(JCR *jcr, bEventType event, void *value=NULL);
193 bool send_plugin_name(JCR *jcr, BSOCK *sd, bool start);
194 bool plugin_name_stream(JCR *jcr, char *name);    
195 int plugin_create_file(JCR *jcr, ATTR *attr, BFILE *bfd, int replace);
196 bool plugin_set_attributes(JCR *jcr, ATTR *attr, BFILE *ofd);
197 int plugin_save(JCR *jcr, FF_PKT *ff_pkt, bool top_level);
198 bool plugin_check_file(JCR *jcr, char *fname);
199 #endif
200
201 #ifdef __cplusplus
202 extern "C" {
203 #endif
204
205 /* 
206  * Bacula interface version and function pointers -- 
207  *  i.e. callbacks from the plugin to Bacula
208  */
209 typedef struct s_baculaFuncs {  
210    uint32_t size;
211    uint32_t version;
212    bRC (*registerBaculaEvents)(bpContext *ctx, ...);
213    bRC (*getBaculaValue)(bpContext *ctx, bVariable var, void *value);
214    bRC (*setBaculaValue)(bpContext *ctx, bVariable var, void *value);
215    bRC (*JobMessage)(bpContext *ctx, const char *file, int line, 
216        int type, utime_t mtime, const char *fmt, ...);     
217    bRC (*DebugMessage)(bpContext *ctx, const char *file, int line,
218        int level, const char *fmt, ...);
219    void *(*baculaMalloc)(bpContext *ctx, const char *file, int line, 
220        size_t size);
221    void (*baculaFree)(bpContext *ctx, const char *file, int line, void *mem);
222    bRC (*AddExclude)(bpContext *ctx, const char *file);
223 } bFuncs;
224
225
226
227
228 /****************************************************************************
229  *                                                                          *
230  *                Plugin definitions                                        *
231  *                                                                          *
232  ****************************************************************************/
233
234 typedef enum {
235   pVarName = 1,
236   pVarDescription = 2
237 } pVariable;
238
239
240 #define FD_PLUGIN_MAGIC     "*FDPluginData*" 
241 #define FD_PLUGIN_INTERFACE_VERSION  4
242
243 typedef struct s_pluginInfo {
244    uint32_t size;
245    uint32_t version;
246    const char *plugin_magic;
247    const char *plugin_license;
248    const char *plugin_author;
249    const char *plugin_date;
250    const char *plugin_version;
251    const char *plugin_description;
252 } pInfo;
253
254 /*
255  * This is a set of function pointers that Bacula can call
256  *  within the plugin.
257  */
258 typedef struct s_pluginFuncs {  
259    uint32_t size;
260    uint32_t version;
261    bRC (*newPlugin)(bpContext *ctx);
262    bRC (*freePlugin)(bpContext *ctx);
263    bRC (*getPluginValue)(bpContext *ctx, pVariable var, void *value);
264    bRC (*setPluginValue)(bpContext *ctx, pVariable var, void *value);
265    bRC (*handlePluginEvent)(bpContext *ctx, bEvent *event, void *value);
266    bRC (*startBackupFile)(bpContext *ctx, struct save_pkt *sp);
267    bRC (*endBackupFile)(bpContext *ctx);
268    bRC (*startRestoreFile)(bpContext *ctx, const char *cmd);
269    bRC (*endRestoreFile)(bpContext *ctx);
270    bRC (*pluginIO)(bpContext *ctx, struct io_pkt *io);
271    bRC (*createFile)(bpContext *ctx, struct restore_pkt *rp);
272    bRC (*setFileAttributes)(bpContext *ctx, struct restore_pkt *rp);
273    bRC (*checkFile)(bpContext *ctx, char *fname);
274 } pFuncs;
275
276 #define plug_func(plugin) ((pFuncs *)(plugin->pfuncs))
277 #define plug_info(plugin) ((pInfo *)(plugin->pinfo))
278
279 #ifdef __cplusplus
280 }
281 #endif
282
283 #endif /* __FD_PLUGINS_H */