TODO

Version 24 (Etienne Pallier, 08/10/2016 05:05 pm)

1 1 Paul Carensac
h1. TODO
2 1 Paul Carensac
3 1 Paul Carensac
List of tasks by application, and general tasks (organization, tools, ...)
4 1 Paul Carensac
5 1 Paul Carensac
{{>toc}}
6 1 Paul Carensac
7 1 Paul Carensac
---
8 1 Paul Carensac
9 1 Paul Carensac
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}General tasks%
10 1 Paul Carensac
11 3 Etienne Pallier
12 24 Etienne Pallier
* Pyros : doit pouvoir être démarré indifféremment AVANT les devices, ou APRES
13 24 Etienne Pallier
14 24 Etienne Pallier
15 23 Etienne Pallier
* Django : 
16 12 Etienne Pallier
17 11 Etienne Pallier
 * Upgrade to Django 1.10
18 13 Etienne Pallier
 * Remplacer le serveur web de "dev" (manage runserver) par un vrai serveur web pour la "prod" (Apache pour les fichiers statiques + serveur d'application Python pour le code Python, par exemple gunicorn)
19 11 Etienne Pallier
(cf https://projects.irap.omp.eu/projects/pyros/wiki/Project_Development#Serveur-Web)
20 4 Etienne Pallier
21 23 Etienne Pallier
* Comet installation : Include in the install_requirements.sh script (by using stable official version for Python 3 (when available) on Linux (and Mac) and Windows 10
22 3 Etienne Pallier
23 23 Etienne Pallier
* git : Create a "dev" branch (do not write anymore on the "master" branch)
24 7 Etienne Pallier
25 20 Etienne Pallier
* Simulators : on doit se rendre compte qu'ils sont "vivants" (ils seront progressivement remplacés par les vrais devices, mais resteront toujours utilisables à leur place)
26 18 Etienne Pallier
27 18 Etienne Pallier
 * Le Monitoring doit les interroger régulièrement sur leur statut (check_status, DONE)
28 18 Etienne Pallier
 * Il doit stocker les statuts dans la BD (TODO)
29 19 Etienne Pallier
 * Ces statuts doivent être affichés au fur et à mesure sur la page web du "device" correspondant (Devices, Site, Weather) (TODO)
30 18 Etienne Pallier
31 23 Etienne Pallier
* Users: gérer les 3 profils (admin, expert, user)
32 22 Etienne Pallier
33 23 Etienne Pallier
* Doc :
34 14 Etienne Pallier
35 17 Etienne Pallier
 * TEST:
36 14 Etienne Pallier
  
37 14 Etienne Pallier
  * Unit tests
38 14 Etienne Pallier
  * Functional tests (with Celery and simulators)
39 14 Etienne Pallier
40 14 Etienne Pallier
 * LAUNCH:
41 14 Etienne Pallier
42 14 Etienne Pallier
  * Start simulators
43 14 Etienne Pallier
  * Start Celery
44 14 Etienne Pallier
  * Start pyros
45 14 Etienne Pallier
46 14 Etienne Pallier
 * USE:
47 14 Etienne Pallier
48 14 Etienne Pallier
  * Administration of the database: http://localhost:8000/admin
49 15 Etienne Pallier
  * Interacting with Pyros: http://localhost:8000
50 1 Paul Carensac
  
51 15 Etienne Pallier
   * Watch the environment: Devices, Site, Weather
52 15 Etienne Pallier
   * Watch the schedule: Schedule
53 15 Etienne Pallier
   * Watch the data processing (workflow): System (Dashboard)
54 15 Etienne Pallier
   * Submit a Routine Request (and get results): Routines
55 16 Etienne Pallier
   * Watch alerts: Alerts
56 21 Etienne Pallier
   * Simulate an Alert: Alerts (TODO: Un user "admin" doit pouvoir déclencher une alerte type depuis la page web Alerts)
57 15 Etienne Pallier
   * Manual operations on the Telescope : Devices/Telescope (TODO)
58 14 Etienne Pallier
   * Manage users : Users
59 1 Paul Carensac
60 22 Etienne Pallier
61 14 Etienne Pallier
62 1 Paul Carensac
---
63 1 Paul Carensac
64 1 Paul Carensac
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}Applications tasks%
65 2 Paul Carensac
66 2 Paul Carensac
h3. Dashboard
67 2 Paul Carensac
68 2 Paul Carensac
 * Create the backoffice views as the modules are integrated in pyros
69 2 Paul Carensac
 * Think about a system of permissions
70 2 Paul Carensac
71 2 Paul Carensac
h3. Scheduler
72 2 Paul Carensac
73 2 Paul Carensac
 * views
74 2 Paul Carensac
75 2 Paul Carensac
  * Link the main page to the current schedule instead of the simulation page
76 2 Paul Carensac
  * Show user sequences in the schedules (with links)
77 2 Paul Carensac
  * Give accces to old schedules (day / days before / all end-night plannings / all plannings)
78 2 Paul Carensac
  * Give access to the refused sequences of a schedule, and the reasons of rejects
79 2 Paul Carensac
80 2 Paul Carensac
 * scheduler
81 2 Paul Carensac
82 2 Paul Carensac
  * Change the system to determine night start/end (they must be given in parameter, only if first_schedule is True)
83 2 Paul Carensac
  * Store the reasons of rejects (create a new attribute, in shs ?)
84 2 Paul Carensac
  * What is the 'flag' attribute ? (@AK)
85 2 Paul Carensac
  * Do not create the execute_sequence tasks if it's not the night (- 120 seconds)
86 2 Paul Carensac
  * Priority and quota computing
87 2 Paul Carensac
  * Quotas evolution
88 2 Paul Carensac
  * Blank space filling
89 2 Paul Carensac
  * At the end of a scheduling send, it to the IC ?
90 2 Paul Carensac
91 2 Paul Carensac
h3. Alert Manager
92 2 Paul Carensac
93 2 Paul Carensac
 * Web :
94 2 Paul Carensac
95 2 Paul Carensac
  * Print if there is an alert in progress in the main page
96 2 Paul Carensac
  * Link the alerts to their status and results
97 2 Paul Carensac
98 2 Paul Carensac
 * Connect to a real VOEvent broker
99 2 Paul Carensac
100 2 Paul Carensac
 * Determine the communication with FSC for strategy change
101 2 Paul Carensac
102 2 Paul Carensac
 * VOEvents :
103 2 Paul Carensac
104 2 Paul Carensac
  * Extract the good fields (see AK Q&A 07/01/2016)
105 2 Paul Carensac
  * Fill the request & alerts objects
106 2 Paul Carensac
  * Use strategies to build a request
107 2 Paul Carensac
  * Possibility to change the default strategy
108 2 Paul Carensac
  * Handle VOEvent updates
109 2 Paul Carensac
  * Be careful to not create 2 alerts for a same GRB, seen by 2 different satellites 
110 2 Paul Carensac
111 2 Paul Carensac
112 2 Paul Carensac
h3. Analyzer
113 2 Paul Carensac
114 2 Paul Carensac
 * Apply the calibrations in the right function
115 2 Paul Carensac
 * Apply the analyses only if it's a GRB
116 2 Paul Carensac
 * Implement the analyses
117 2 Paul Carensac
 * Send analyses to FSC
118 2 Paul Carensac
119 2 Paul Carensac
120 2 Paul Carensac
h3. Majordome
121 2 Paul Carensac
122 2 Paul Carensac
 * TaskManager
123 2 Paul Carensac
124 2 Paul Carensac
  * When a sequence is cancelled, give back the quota to the user
125 2 Paul Carensac
  * In case of alert, do not stop the ongoing plan, and make the instruments abort
126 2 Paul Carensac
127 2 Paul Carensac
 * execute_sequence
128 2 Paul Carensac
129 2 Paul Carensac
  * Add the PLC checks at start (to see if we do the slew)
130 2 Paul Carensac
  * Use the global telescope (instead of creating one here)
131 2 Paul Carensac
  * Give first_schedule as false when a scheduling is launched
132 2 Paul Carensac
  * Remove the default countdown (1, for tests)
133 2 Paul Carensac
134 2 Paul Carensac
 * system_pause
135 2 Paul Carensac
136 2 Paul Carensac
  * Abort the isntruments
137 2 Paul Carensac
  * Stop the execution tasks
138 2 Paul Carensac
139 2 Paul Carensac
 * system_restart
140 2 Paul Carensac
141 2 Paul Carensac
  * Start a scheduling
142 2 Paul Carensac
143 2 Paul Carensac
 * change_obs_conditions
144 2 Paul Carensac
145 2 Paul Carensac
  * Change sequences status (if  needed)
146 2 Paul Carensac
  * If some status changed, re-launch a scheduling
147 2 Paul Carensac
148 2 Paul Carensac
149 2 Paul Carensac
h3. Monitoring
150 2 Paul Carensac
151 2 Paul Carensac
 * views
152 2 Paul Carensac
153 2 Paul Carensac
  * Move the dashboard here
154 2 Paul Carensac
  * Print the instrument status
155 2 Paul Carensac
  * Print PLC informations (with the evolution)
156 2 Paul Carensac
  * In the dashboard screens, put scroll on each screen to see the old logs
157 2 Paul Carensac
158 2 Paul Carensac
 * Monitoring task
159 2 Paul Carensac
 
160 2 Paul Carensac
  * Uncomment the scheduling at the beginning
161 2 Paul Carensac
  * Implement night start/end computation
162 2 Paul Carensac
  * Initialize communication with the instruments
163 2 Paul Carensac
  * Configure intruments at start
164 2 Paul Carensac
  * Send software versions to the IC
165 2 Paul Carensac
  * Initialize connection with PLC
166 2 Paul Carensac
  * After the starting actions, loop to wait for the instruments configuration to be finished
167 2 Paul Carensac
  * Ask PLC for status
168 2 Paul Carensac
  * Ask filter wheel for status
169 2 Paul Carensac
  * Store the instruments & PLC status
170 2 Paul Carensac
  * Send all status to IC
171 2 Paul Carensac
  * Analyse PLC status (obs conditions, ...)
172 2 Paul Carensac
  * Create tasks of obs condition changes
173 2 Paul Carensac
174 2 Paul Carensac
175 2 Paul Carensac
h3. Observation Manager
176 2 Paul Carensac
177 2 Paul Carensac
 * execute_plan :
178 2 Paul Carensac
179 2 Paul Carensac
  * Use the cameras at a global level instead of creating them here (same for the filter wheels)
180 2 Paul Carensac
  * Uncomment the instruments_ready waiting function
181 2 Paul Carensac
  * Uncomment the observation_ending waiting function
182 2 Paul Carensac
  * Try to remove code duplication
183 2 Paul Carensac
  * Determine what needs to be done at the end of an observation
184 2 Paul Carensac
185 2 Paul Carensac
 * create_calibrations :
186 2 Paul Carensac
187 2 Paul Carensac
  * Make the calibration images
188 2 Paul Carensac
  * Generate super images
189 2 Paul Carensac
  * Send them to the IC
190 2 Paul Carensac
191 2 Paul Carensac
192 2 Paul Carensac
h3. Routine Manager
193 2 Paul Carensac
194 2 Paul Carensac
 * Web
195 2 Paul Carensac
196 2 Paul Carensac
  * Put the goods fields (for coordinates etc)
197 2 Paul Carensac
  * Only propose the objects that matches the conditions (ex: scientific programs of the user only)
198 2 Paul Carensac
  * Do all the needed checks
199 2 Paul Carensac
  * Add automatic computation of JD1/JD2
200 2 Paul Carensac
  * Add checkbox for JD / GD
201 2 Paul Carensac
  * Add options : copy my sequence on x days, and authorise report
202 2 Paul Carensac
  * Add ETC-IS simulation
203 2 Paul Carensac
  * Add help for new users (and for it the first time an account come on the page)
204 2 Paul Carensac
 
205 2 Paul Carensac
 * Do more checks at unserialization
206 2 Paul Carensac
207 2 Paul Carensac
 * views
208 2 Paul Carensac
209 2 Paul Carensac
  * When saving, do more checks on coordinates, jd1/2 etc
210 2 Paul Carensac
  * Uncomment filter for alerts removing
211 2 Paul Carensac
  * When submitting, use the monitoring to determine sequences status
212 2 Paul Carensac
  * When submitting, modify the first_schedule to False, when scheduling
213 2 Paul Carensac
  * When unsubmitting, uncomment the check for EXED and EXING removing
214 2 Paul Carensac
  * When unsubmitting, uncomment the scheduling and change the first_schedule to False
215 2 Paul Carensac
216 2 Paul Carensac
217 2 Paul Carensac
h3. User Manager
218 2 Paul Carensac
219 2 Paul Carensac
 * Password recovery
220 2 Paul Carensac
 * Profile page
221 2 Paul Carensac
 * User validation by administrator / commission
222 2 Paul Carensac
 * Handle permissions and access
223 2 Paul Carensac
224 2 Paul Carensac
225 2 Paul Carensac
h3. Common
226 2 Paul Carensac
227 2 Paul Carensac
 * Network communication for every instrument
228 2 Paul Carensac
 * Change the 'first_schedule' to False at the end of RequestBuilder.validate()