annotate getan/controller.py @ 194:cf98dc7f9354

Move mainloop related code to GetanController
author Björn Ricks <bjoern.ricks@intevation.de>
date Wed, 23 Jan 2013 15:04:43 +0100
parents 5e069074b1c9
children 9f85ffa0a2f6
rev   line source
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
1 # -*- coding: utf-8 -*-
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
2 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
3 # (c) 2010 by Ingo Weinzierl <ingo.weinzierl@intevation.de>
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
4 # (c) 2011 by Björn Ricks <bjoern.ricks@intevation.de>
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
5 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
6 # A python worklog-alike to log what you have 'getan' (done).
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
7 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
8 # This is Free Software licensed under the terms of GPLv3 or later.
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
9 # For details see LICENSE coming with the source of 'getan'.
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
10 #
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
11
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
12 import logging
194
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
13 import urwid
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
14
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
15 from datetime import datetime
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
16
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
17 from getan.view import GetanView
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
18 from getan.states import PausedProjectsState
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
19 from getan.utils import format_time
149
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
20 from getan.config import Config
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
21
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
22 logger = logging.getLogger()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
23
136
92b7582b8f44 Use new style classes
Björn Ricks <bjoern.ricks@intevation.de>
parents: 135
diff changeset
24 class GetanController(object):
92b7582b8f44 Use new style classes
Björn Ricks <bjoern.ricks@intevation.de>
parents: 135
diff changeset
25
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
26 def __init__(self, backend, pv_class, ev_class):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
27 self.ev_class = ev_class
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
28 self.pv_class = pv_class
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
29
149
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
30 self.config = Config()
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
31
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
32 self.backend = backend
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
33 projects, entries = self.load_projects()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
34 self.projects = projects
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
35 self.running = []
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
36
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
37 self.project_view = pv_class(self, self.projects)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
38 self.entries_view = ev_class(entries)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
39
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
40 self.view = GetanView(self, self.project_view, self.entries_view)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
41 self.state = PausedProjectsState(self, self.project_view)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
42
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
43 def main(self):
194
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
44 self.loop = urwid.MainLoop(self.view.get_frame(),
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
45 self.view.get_palette(),
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
46 screen=urwid.raw_display.Screen(),
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
47 unhandled_input=self.unhandled_keypress,
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
48 input_filter=self.input_filter)
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
49 self.loop.run()
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
50
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
51 def unhandled_keypress(self, key):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
52 self.state = self.state.keypress(key)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
53
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
54 def input_filter(self, input, raw_input):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
55 if 'window resize' in input:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
56 self.view.loop.screen_size = None
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
57 self.view.loop.draw_screen()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
58 else:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
59 self.state = self.state.keypress(input)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
60
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
61 def load_projects(self):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
62 projects = self.backend.load_projects()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
63 if projects:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
64 entries = self.backend.load_entries(projects[0].id)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
65 else:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
66 entries = []
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
67 return (projects, entries)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
68
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
69 def update_entries(self, project):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
70 logger.debug("GetanController: update entries.")
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
71 if project:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
72 entries = self.backend.load_entries(project.id)
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
73 else:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
74 entries = []
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
75 self.entries_view.set_rows(entries)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
76 self.view.update_view()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
77
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
78 def move_selected_entries(self, project):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
79 old_project = None
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
80 entries = []
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
81 try:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
82 while self.entries_view.selection:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
83 node = self.entries_view.selection.pop()
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
84 if node.selected:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
85 node.select()
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
86 entries.append(node.item)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
87 logger.info("GetanController: move entry '%s' (id = %d, "\
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
88 "project id = %d) to project '%s'"
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
89 % (node.item.desc, node.item.id,
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
90 node.item.project_id, project.desc))
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
91
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
92 if not old_project:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
93 old_project = self.project_by_id(node.item.project_id)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
94 finally:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
95 self.backend.move_entries(entries, project.id)
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
96 if not old_project:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
97 return
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
98 project.entries = self.backend.load_entries(project.id)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
99 old_project.entries = self.backend.load_entries(old_project.id)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
100 self.update_entries(old_project)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
101 self.project_view.update_all()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
102
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
103 def delete_entries(self, entry_nodes):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
104 if not entry_nodes:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
105 return
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
106 proj = self.project_by_id(entry_nodes[0].project_id)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
107 entries = entry_nodes
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
108 self.backend.delete_entries(entries)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
109 proj.entries = self.backend.load_entries(proj.id)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
110 self.update_entries(proj)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
111 self.project_view.update()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
113 def update_project_list(self):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
114 self.project_view.update()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
115 self.view.update_view()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
116
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
117 def project_by_key(self, key):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
118 for proj in self.projects:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
119 if proj.key == key:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
120 return proj
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
121 return None
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
122
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
123 def project_by_id(self, id):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
124 for proj in self.projects:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
125 if proj.id == id:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
126 return proj
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
127 return None
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
128
154
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
129 def find_projects_by_key(self, key):
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
130 projects = []
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
131 for proj in self.projects:
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
132 if proj.key.startswith(key):
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
133 projects.append(proj)
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
134 return projects
a620eb6e1fb0 Add controller method to find projects by key
Björn Ricks <bjoern.ricks@intevation.de>
parents: 149
diff changeset
135
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
136 def start_project(self, project):
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
137 if not project:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
138 return
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
139 self.running.append(project)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
140 project.start = datetime.now()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
141 logger.info("Start project '%s' at %s."
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
142 % (project.desc, format_time(datetime.now())))
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
143 self.view.set_footer_text(" Running on '%s'" % project.desc, 'running')
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
144 logger.debug('All running projects: %r' % self.running)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
145
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
146 def stop_project(self, desc='-no description-', display=True):
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
147 if not self.running:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
148 return
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
149 project = self.running.pop()
135
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
150 if not project:
ce707fbb9666 Change coding style of if clauses
Björn Ricks <bjoern.ricks@intevation.de>
parents: 112
diff changeset
151 return
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
152 logger.info("Stop project '%s' at %s."
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
153 % (project.desc, format_time(datetime.now())))
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
154 project.stop = datetime.now()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
155 self.backend.insert_project_entry(project, datetime.now(), desc)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
156 if display:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
157 self.update_entries(project)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
158 self.update_project_list()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
159 logger.debug('Still running projects: %r' % self.running)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
160
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
161 def add_project(self, key, description):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
162 if not key or not description:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
163 return
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
164 self.backend.insert_project(key, description)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
165 self.update_projects()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
166 self.update_project_list()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
167
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
168 def update_entry(self, entry):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
169 self.backend.update_entry(entry)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
170
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
171 def shutdown(self):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
172 for project in self.running:
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
173 self.stop_project(display=False)
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
174
175
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
175 def update_project(self, project):
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
176 self.backend.update_project(project)
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
177 self.update_projects()
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
178 self.update_project_list()
5e069074b1c9 Add Controller method to update a project
Björn Ricks <bjoern.ricks@intevation.de>
parents: 154
diff changeset
179
112
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
180 def update_projects(self):
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
181 projects, entries = self.load_projects()
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
182 self.projects = projects
d85b2a25797c Move GetanController to it's own module
Björn Ricks <bjoern.ricks@intevation.de>
parents:
diff changeset
183 self.project_view.load_rows(projects)
149
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
184
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
185 def get_config(self):
ac7c6594fc0e Add the getan config to the controller
Björn Ricks <bjoern.ricks@intevation.de>
parents: 136
diff changeset
186 return self.config
194
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
187
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
188 def exit(self):
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
189 logger.info("GetanController: exit.")
cf98dc7f9354 Move mainloop related code to GetanController
Björn Ricks <bjoern.ricks@intevation.de>
parents: 175
diff changeset
190 raise urwid.ExitMainLoop()
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)