]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/qt-console/console/console.h
Add a feature to have a menu item to allow a user to repopulate the lists
[bacula/bacula] / bacula / src / qt-console / console / console.h
1 #ifndef _CONSOLE_H_
2 #define _CONSOLE_H_
3 /*
4    Bacula® - The Network Backup Solution
5
6    Copyright (C) 2007-2008 Free Software Foundation Europe e.V.
7
8    The main author of Bacula is Kern Sibbald, with contributions from
9    many others, a complete list can be found in the file AUTHORS.
10    This program is Free Software; you can redistribute it and/or
11    modify it under the terms of version two of the GNU General Public
12    License as published by the Free Software Foundation and included
13    in the file LICENSE.
14
15    This program is distributed in the hope that it will be useful, but
16    WITHOUT ANY WARRANTY; without even the implied warranty of
17    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18    General Public License for more details.
19
20    You should have received a copy of the GNU General Public License
21    along with this program; if not, write to the Free Software
22    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
23    02110-1301, USA.
24
25    Bacula® is a registered trademark of Kern Sibbald.
26    The licensor of Bacula is the Free Software Foundation Europe
27    (FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
28    Switzerland, email:ftf@fsfeurope.org.
29 */
30 /*
31  *   Version $Id$
32  *
33  *   Kern Sibbald, January 2007
34  */
35
36 #include <QtGui>
37 #include "pages.h"
38 #include "ui_console.h"
39 #include "bcomm/dircomm.h"
40
41 #ifndef MAX_NAME_LENGTH
42 #define MAX_NAME_LENGTH 128
43 #endif
44
45 /*
46  * Structure for obtaining the defaults for a job
47  */
48 struct job_defaults {
49    QString job_name;
50    QString pool_name;
51    QString messages_name;
52    QString client_name;
53    QString store_name;
54    QString where;
55    QString level;
56    QString type;
57    QString fileset_name;
58    QString catalog_name;
59    bool enabled;
60 };
61
62 //class DIRRES;
63 //class BSOCK;
64 //class JCR;
65 //class CONRES;
66
67 class Console : public Pages, public Ui::ConsoleForm
68 {
69    Q_OBJECT 
70    friend class DirComm;
71
72 public:
73    Console(QStackedWidget *parent);
74    ~Console();
75    int read(int conn);
76    char *msg(int conn);
77    void discardToPrompt(int conn);
78    int write(int conn, const char *msg);
79    int write(int conn, QString msg);
80    int notifyOff(); // enables/disables socket notification - returns the previous state
81    bool notify(int conn, bool enable); // enables/disables socket notification - returns the previous state
82    bool is_notify_enabled(int conn) const;
83    bool availableDirComm(int &conn);
84    void displayToPrompt(int conn);
85
86    bool dir_cmd(int conn, const char *cmd, QStringList &results);
87    bool dir_cmd(const char *cmd, QStringList &results);
88    bool dir_cmd(QString &cmd, QStringList &results);
89    bool sql_cmd(const char *cmd, QStringList &results);
90    bool sql_cmd(QString &cmd, QStringList &results);
91    bool sql_cmd(int &conn, QString &cmd, QStringList &results);
92    bool sql_cmd(int &conn, const char *cmd, QStringList &results, bool donotify);
93    int write_dir(const char *buf);
94    void write_dir(int conn, const char *buf);
95    void getDirResName(QString &);
96    void setDirRes(DIRRES *dir);
97    void writeSettings();
98    void readSettings();
99    void setDirectorTreeItem(QTreeWidgetItem *);
100    void terminate();
101    bool is_messagesPending() { return m_messages_pending; };
102    bool is_connected();
103    bool is_connected(int conn);
104    QTreeWidgetItem *directorTreeItem() { return m_directorTreeItem; };
105    void startTimer();
106    void display_text(const char *buf);
107    void display_text(const QString buf);
108    void display_textf(const char *fmt, ...);
109    void display_html(const QString buf);
110    bool get_job_defaults(struct job_defaults &);
111    bool get_job_defaults(int &conn, struct job_defaults &);
112    const QFont get_font();
113    void beginNewCommand(int conn);
114    void populateLists(bool forcenew);
115
116 private:
117    bool get_job_defaults(int &conn, struct job_defaults &, bool donotify);
118    void update_cursor(void);
119    void stopTimer();
120    bool is_connectedGui();
121    bool newDirComm(int &conn);
122    void populateLists(int conn);
123
124 public:
125    QStringList job_list;
126    QStringList client_list;
127    QStringList fileset_list;
128    QStringList messages_list;
129    QStringList pool_list;
130    QStringList storage_list;
131    QStringList type_list;
132    QStringList level_list;
133
134 public slots:
135    void connect_dir();                     
136    void status_dir(void);
137    void messages(void);
138    void set_font(void);
139    void poll_messages(void);
140    void consoleHelp();
141    void consoleReload();
142
143 public:
144    DIRRES *m_dir;                  /* so various pages can reference it */
145
146 private:
147    QTextEdit *m_textEdit;
148    QTextCursor *m_cursor;
149    QTreeWidgetItem *m_directorTreeItem;
150    bool m_messages_pending;
151    QTimer *m_timer;
152    bool messagesPending(bool pend);
153    bool hasFocus();
154    QHash<int, DirComm*> m_dircommHash;
155    int m_dircommCounter;
156 };
157
158 #endif /* _CONSOLE_H_ */