3 * Bacula interface to Python for the Storage Daemon
5 * Kern Sibbald, January MMV
12 Copyright (C) 2005 Kern Sibbald
14 This program is free software; you can redistribute it and/or
15 modify it under the terms of the GNU General Public License as
16 published by the Free Software Foundation; either version 2 of
17 the License, or (at your option) any later version.
19 This program is distributed in the hope that it will be useful,
20 but WITHOUT ANY WARRANTY; without even the implied warranty of
21 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
22 General Public License for more details.
24 You should have received a copy of the GNU General Public
25 License along with this program; if not, write to the Free
26 Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
35 #undef _POSIX_C_SOURCE
38 extern JCR *get_jcr_from_PyObject(PyObject *self);
40 PyObject *bacula_get(PyObject *self, PyObject *args);
41 PyObject *bacula_set(PyObject *self, PyObject *args, PyObject *keyw);
43 /* Define Bacula entry points */
44 PyMethodDef BaculaMethods[] = {
45 {"get", bacula_get, METH_VARARGS, "Get Bacula variables."},
46 {"set", (PyCFunction)bacula_set, METH_VARARGS|METH_KEYWORDS,
47 "Set Bacula variables."},
48 {NULL, NULL, 0, NULL} /* last item */
57 static struct s_vars vars[] = {
58 { N_("Job"), "s"}, /* 0 */
59 { N_("SDName"), "s"}, /* 1 */
60 { N_("Level"), "s"}, /* 2 */
61 { N_("Type"), "s"}, /* 3 */
62 { N_("JobId"), "i"}, /* 4 */
63 { N_("Client"), "s"}, /* 5 */
64 { N_("Pool"), "s"}, /* 6 */
65 { N_("MediaType"), "s"}, /* 7 */
66 { N_("JobName"), "s"}, /* 8 */
67 { N_("JobStatus"), "s"}, /* 9 */
68 { N_("VolumeName"), "s"}, /* 10 */
69 { N_("Device"), "s"}, /* 11 */
74 /* Return Bacula variables */
75 PyObject *bacula_get(PyObject *self, PyObject *args)
83 if (!PyArg_ParseTuple(args, "s:get", &item)) {
86 jcr = get_jcr_from_PyObject(self);
88 for (i=0; vars[i].name; i++) {
89 if (strcmp(vars[i].name, item) == 0) {
99 return Py_BuildValue(vars[i].fmt, jcr->job_name); /* Non-unique name */
100 case 1: /* SD's name */
101 return Py_BuildValue(vars[i].fmt, my_name);
103 return Py_BuildValue(vars[i].fmt, job_level_to_str(jcr->JobLevel));
105 return Py_BuildValue(vars[i].fmt, job_type_to_str(jcr->JobType));
107 return Py_BuildValue(vars[i].fmt, jcr->JobId);
109 return Py_BuildValue(vars[i].fmt, jcr->client_name);
111 return Py_BuildValue(vars[i].fmt, jcr->dcr->pool_name);
112 case 7: /* MediaType */
113 return Py_BuildValue(vars[i].fmt, jcr->dcr->media_type);
114 case 8: /* JobName */
115 return Py_BuildValue(vars[i].fmt, jcr->Job);
116 case 9: /* JobStatus */
118 buf[0] = jcr->JobStatus;
119 return Py_BuildValue(vars[i].fmt, buf);
121 return Py_BuildValue(vars[i].fmt, jcr->dcr->VolumeName);
123 return Py_BuildValue(vars[i].fmt, jcr->dcr->dev_name);
128 /* Set Bacula variables */
129 PyObject *bacula_set(PyObject *self, PyObject *args, PyObject *keyw)
133 static char *kwlist[] = {"JobReport", NULL};
135 if (!PyArg_ParseTupleAndKeywords(args, keyw, "|s:set", kwlist,
139 jcr = get_jcr_from_PyObject(self);
142 Jmsg(jcr, M_INFO, 0, "%s", msg);
144 return Py_BuildValue("i", 1);
147 #endif /* HAVE_PYTHON */