]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/filed/fd_plugins.h
Add missing db_unlock to bvfs_update_cache.
[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 } bVariable;
155
156 /* Events that are passed to plugin */
157 typedef enum {
158   bEventJobStart        = 1,
159   bEventJobEnd          = 2,
160   bEventStartBackupJob  = 3,
161   bEventEndBackupJob    = 4,
162   bEventStartRestoreJob = 5,
163   bEventEndRestoreJob   = 6,
164   bEventStartVerifyJob  = 7,
165   bEventEndVerifyJob    = 8,
166   bEventBackupCommand   = 9,
167   bEventRestoreCommand  = 10,
168   bEventLevel           = 11,
169   bEventSince           = 12,
170   bEventCancelCommand   = 13,
171   bEventInitializeVSS   = 14
172 } bEventType;
173
174 typedef struct s_bEvent {
175    uint32_t eventType;
176 } bEvent;
177
178 typedef struct s_baculaInfo {
179    uint32_t size;
180    uint32_t version;
181 } bInfo;
182
183 /* Bacula Core Routines -- not used within a plugin */
184 #ifdef FILE_DAEMON
185 struct BFILE;                   /* forward referenced */
186 struct FF_PKT;
187 void load_fd_plugins(const char *plugin_dir);
188 void new_plugins(JCR *jcr);
189 void free_plugins(JCR *jcr);
190 void generate_plugin_event(JCR *jcr, bEventType event, void *value=NULL);
191 bool send_plugin_name(JCR *jcr, BSOCK *sd, bool start);
192 bool plugin_name_stream(JCR *jcr, char *name);    
193 int plugin_create_file(JCR *jcr, ATTR *attr, BFILE *bfd, int replace);
194 bool plugin_set_attributes(JCR *jcr, ATTR *attr, BFILE *ofd);
195 int plugin_save(JCR *jcr, FF_PKT *ff_pkt, bool top_level);
196 bool plugin_check_file(JCR *jcr, char *fname);
197 #endif
198
199 #ifdef __cplusplus
200 extern "C" {
201 #endif
202
203 /* 
204  * Bacula interface version and function pointers -- 
205  *  i.e. callbacks from the plugin to Bacula
206  */
207 typedef struct s_baculaFuncs {  
208    uint32_t size;
209    uint32_t version;
210    bRC (*registerBaculaEvents)(bpContext *ctx, ...);
211    bRC (*getBaculaValue)(bpContext *ctx, bVariable var, void *value);
212    bRC (*setBaculaValue)(bpContext *ctx, bVariable var, void *value);
213    bRC (*JobMessage)(bpContext *ctx, const char *file, int line, 
214        int type, utime_t mtime, const char *fmt, ...);     
215    bRC (*DebugMessage)(bpContext *ctx, const char *file, int line,
216        int level, const char *fmt, ...);
217    void *(*baculaMalloc)(bpContext *ctx, const char *file, int line, 
218        size_t size);
219    void (*baculaFree)(bpContext *ctx, const char *file, int line, void *mem);
220    bRC (*AddExclude)(bpContext *ctx, const char *file);
221 } bFuncs;
222
223
224
225
226 /****************************************************************************
227  *                                                                          *
228  *                Plugin definitions                                        *
229  *                                                                          *
230  ****************************************************************************/
231
232 typedef enum {
233   pVarName = 1,
234   pVarDescription = 2
235 } pVariable;
236
237
238 #define FD_PLUGIN_MAGIC     "*FDPluginData*" 
239 #define FD_PLUGIN_INTERFACE_VERSION  4
240
241 typedef struct s_pluginInfo {
242    uint32_t size;
243    uint32_t version;
244    const char *plugin_magic;
245    const char *plugin_license;
246    const char *plugin_author;
247    const char *plugin_date;
248    const char *plugin_version;
249    const char *plugin_description;
250 } pInfo;
251
252 /*
253  * This is a set of function pointers that Bacula can call
254  *  within the plugin.
255  */
256 typedef struct s_pluginFuncs {  
257    uint32_t size;
258    uint32_t version;
259    bRC (*newPlugin)(bpContext *ctx);
260    bRC (*freePlugin)(bpContext *ctx);
261    bRC (*getPluginValue)(bpContext *ctx, pVariable var, void *value);
262    bRC (*setPluginValue)(bpContext *ctx, pVariable var, void *value);
263    bRC (*handlePluginEvent)(bpContext *ctx, bEvent *event, void *value);
264    bRC (*startBackupFile)(bpContext *ctx, struct save_pkt *sp);
265    bRC (*endBackupFile)(bpContext *ctx);
266    bRC (*startRestoreFile)(bpContext *ctx, const char *cmd);
267    bRC (*endRestoreFile)(bpContext *ctx);
268    bRC (*pluginIO)(bpContext *ctx, struct io_pkt *io);
269    bRC (*createFile)(bpContext *ctx, struct restore_pkt *rp);
270    bRC (*setFileAttributes)(bpContext *ctx, struct restore_pkt *rp);
271    bRC (*checkFile)(bpContext *ctx, char *fname);
272 } pFuncs;
273
274 #define plug_func(plugin) ((pFuncs *)(plugin->pfuncs))
275 #define plug_info(plugin) ((pInfo *)(plugin->pinfo))
276
277 #ifdef __cplusplus
278 }
279 #endif
280
281 #endif /* __FD_PLUGINS_H */