]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/qt-console/TODO
Addressed issue of long compiles. Simplify with Pages::setCurrent
[bacula/bacula] / bacula / src / qt-console / TODO
1 dhb
2 ====================================================
3 Resolve issue of connection during restore selection.  Could go with preempt
4
5 Add option to LIMIT the number of jobs shown in all jobs page for users with
6 multiple hundreds to thousands of jobs.
7
8 Where and bootstrap are confused in runjobs of restore.
9
10 User preferences.  With log to stdout options.
11
12 Test restore and get anything not working, working.
13   partially done.
14
15 Get restore into stack.
16   Should the jobs dialog be turned into a page as well??
17
18 Update README  describe bat.conf.example to bat.conf
19
20 Create list of what does not work.
21 From what I can tell, just the restore window on the left.
22
23 Add numerous are you sure dialog boxes.  Like are you sure you want to
24 delete/purge that volume.  Show a little of the documentation about what
25 the consequences of delete or purging are.
26
27 Add context sensitive options for most commands
28 status dir on page select director item
29 All items with jobid= that I thought could work from joblist are done.
30 As well as many more
31 update slots scan
32 see COMMANDS file
33
34 preempt all connections to console with 
35 if (!is_connectedGui())
36 or some other mechanism.  Partially done.
37
38 Create documentation for any other developers interested in creating
39 new classes to add more pages.  Explain how to use the pages class
40 and about not populating until the tree widget is clicked etc...
41
42 LOW priority items:
43
44 User configuration dialog.  Include options for debugging output to stdout.
45
46 Is there a way to query the director/database for whether a storage is currently
47 mounted so I am not presenting both mount and unmount to the user??
48
49 Is there a way to identify a slot as having a cleaning tape???
50 (Kern says more work needs to be done in bacula with autochangers)
51
52 Get rid of "Warning: name layoutWidget is already used" when make uic's restore.ui
53
54 move behavior of:
55   MainWin::setContextMenuDockText
56   MainWin::setTreeWidgetItemDockColor
57 to the pages class
58
59 Think about good ways to clean up the Console creation part of the
60 loop creating pages.
61 ========================================================
62 This release or next:
63
64 A window showing a list of jobs and defaults.  Defaults can be gotten in manner
65 similar to what the first restore window does.
66
67 A window showing a list of schedule resources. 
68
69 Kern discussed windows showing statistics like web based interfaces.
70 ========================================================
71 Future Releases :
72
73 The ablility to modify configuration files to create jobs, schedules, filesets
74 and any other director resources.
75
76 The ablility to modify configuration files to create storage resources.
77
78 Add a status dir graphical interface.  It would auto update every ?? seconds
79 and have a list of scheduled jobs, and in the que to run jobs that could be
80 cancelled graphically.
81
82 Add a status client window.  Keep updating showing what file is being
83 processed.
84
85 A Tree widget context sensitive menu option and class to jump from known job
86 to surf the filestructure on the job.
87
88 bRestore add code to get working.
89
90 ===========================================================
91 NOT SURE
92 ===========================================================
93
94 I'm not sure about this one??  Things seem to work and I did not do a
95 thing to make it happen:  the "dir" is a member of Console
96
97 - We also must somehow make the low level I/O routines know which
98 director/console to use.  Currently they always use the single
99 global one defined in the mainWin class (if I remember right).
100
101
102 ============================================================
103 DONE:
104 ============================================================
105 Play with includes to Make these compiles shorter.
106   moved includes of of includes and into files only console.h should be long
107
108
109 relabel storage=DDS3 oldvolume=ddsvol003 volume=dds3vol003 slot=3 pool=dds3_hope
110 in label slot spinner, limit the upper to the value of slots for that storage.
111
112 Fix bug in myth box not working with .sql query="" command.
113 This was a fix in mysql
114
115 Figure out how to get tables like Joblist to do the equivalent of double clicking
116 on the separating lines between each of the headings.
117 Tried the hard way first.  Oops.
118
119 If the console command line entry docked widget gets the focus, make 
120 m_currentConsole the top widget by setting the treewidgetitem selected.
121 Did this in MainWin::input_line almost better to let the person see
122 whatever they want until they hit enter.
123
124 Set Window titles to reflect what director it is.
125
126 Must:: get page selector to follow undocked windows.  Otherwise
127 current console won't be current.
128
129 Re-add class for storage, I accidentally reverted because I left
130 it on my laptop.  This is why I like committing often.
131
132 Add class for FileSets
133
134 Another idea for what you have implemented:
135 - I think that the dynamic pages that you create on the fly
136 should be nested under the item that creates them more like a
137 directory tree.
138
139 For example: Jobs on Volume xxx, probably should be shown under
140 "All Jobs" (or Media if that is what created it) and "Jobs of
141 Client Rufus" probably should be shown under "Clients".  I base
142 this on looking at the Select page list after I have brought up 3
143 or 4 dynamic pages.  Once there are a good number, I get a bit
144 confused where they came from.  This would also permit selecting
145 multipe Volumes then displaying multiple pages, one for each
146 Volume selected.  If they are nested, then that nested level can
147 be expanded or collapsed, which would be pretty cool at keeping
148 information, but getting it out of the way, sort of like what
149 happens for a directory tree.
150
151 dhb: ref above
152 My original concept was to put these in a tabbed widget.  Your Idea may
153 make for a cleaner user experience.  I like it.  It could save the
154 effort of getting a tabbed widget to work.
155
156
157 - I think we need to make the current Director more explicit, by
158 perhaps highlighting it in the page selector when it is current
159 and unhighlighting it when it is not (we could use color as we do
160 for the console, though some color blind people may have
161 problems.
162
163 - When any director is clicked, we need to set it as the current
164 director and set the current console as well.
165
166 Remove DoubleClicking, From pages class not needed any more.
167
168 Broken with multiple directors:
169 - If you click on the second director, it will probably open, but
170 none of the pages that are defined below it will be able to talk
171 to it.  They will most likely talk to the first director.
172
173 - When any console is clicked we need to set it as the current
174 console (m_console) and also set its director as the current
175 director (m_topItem).  These are in the mainwin class.
176
177 - When any page is selected, we must set both the current
178 director (m_topItem) and current console (m_console) that this
179 page is connected to.
180
181 dhb:
182 m_topItem has been changed to Console::directorTreeItem()
183 m_currentConsole->directorTreeItem(); returns disired treeWidgetItem
184
185 - We also need a concept of a "local" director/console for each
186 page, so the page knows who it is talking to -- this doesn't
187 currently exist, so I think we must pass the director and console
188 to each page widget constructor.
189  
190 dhb:
191 m_currentConsole is saved in each page subclass's m_console.  This value
192 is set by all but the console class calling Pages::pgInitialie() in it's
193 constructor
194
195
196 In short, there is a lot of work to be done to make multiple
197 simultaneous directors work.
198
199 dhb:
200 this may be moot:
201
202 If the above prooves to be too much, we might consider to only
203 have a single director at a time, and simply let the user select
204 which director he wants to connect to (one at a time, but
205 dynamically).  In the end, this may be the best thing to do, so
206 any user who wishes to connect to multiple directors would run
207 two instances of bat.  I am a bit unsure now, but the above list
208 of things to do is much bigger than I thought it was going to be.