Wiki

Version 243 (Paul Carensac, 03/22/2016 06:05 pm)

1 1 Etienne Pallier
h1. Technical Documentation for the PYROS project (FGFT-CC)
2 1 Etienne Pallier
3 1 Etienne Pallier
4 1 Etienne Pallier
HOWTO Format Redmine Wiki : http://www.redmine.org/projects/redmine/wiki/FrRedmineWikiFormatting
5 1 Etienne Pallier
6 1 Etienne Pallier
{{>toc}}
7 1 Etienne Pallier
8 1 Etienne Pallier
9 121 Etienne Pallier
---
10 1 Etienne Pallier
11 121 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - TODO%
12 121 Etienne Pallier
13 126 Etienne Pallier
 * installation sur windows
14 125 Etienne Pallier
15 126 Etienne Pallier
 * gitlab
16 1 Etienne Pallier
17 126 Etienne Pallier
 * séparation des BD Django et Pyros
18 125 Etienne Pallier
19 126 Etienne Pallier
 * intégration dans Eclipse
20 126 Etienne Pallier
21 174 Etienne Pallier
 * Intégration des modules Django déjà développés
22 125 Etienne Pallier
23 121 Etienne Pallier
24 3 Etienne Pallier
---
25 1 Etienne Pallier
26 140 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - DATABASE SCHEMA (v0.2.1)%
27 116 Etienne Pallier
28 116 Etienne Pallier
29 117 Etienne Pallier
{{thumbnail(PYROS_PDM_v021.png, size=300, title=Pyros data model)}}
30 121 Etienne Pallier
31 121 Etienne Pallier
32 121 Etienne Pallier
---
33 116 Etienne Pallier
34 141 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}II - Get the project (from gitlab)%
35 141 Etienne Pallier
36 169 Etienne Pallier
h3. Get the project from the terminal
37 1 Etienne Pallier
38 1 Etienne Pallier
<pre>
39 1 Etienne Pallier
git clone https://gitlab.irap.omp.eu/epallier/pyros.git PYROS
40 169 Etienne Pallier
41 174 Etienne Pallier
(or also : git clone git@gitlab.irap.omp.eu:epallier/pyros.git)
42 1 Etienne Pallier
</pre>
43 1 Etienne Pallier
44 197 Etienne Pallier
This creates a PYROS/ folder containing the project (with a .git/ subfolder for synchronization with the git repository)
45 1 Etienne Pallier
46 225 Etienne Pallier
_If you just wanted a static copy of the project (without synchronization) just remove the .git/ folder:_
47 1 Etienne Pallier
<pre>
48 1 Etienne Pallier
$ rm -r .git/
49 1 Etienne Pallier
</pre>
50 226 Etienne Pallier
51 226 Etienne Pallier
You should obtain this structure:
52 226 Etienne Pallier
53 226 Etienne Pallier
<pre>
54 226 Etienne Pallier
55 226 Etienne Pallier
PYROS/
56 226 Etienne Pallier
├── REQUIREMENTS.txt
57 226 Etienne Pallier
├── private/
58 226 Etienne Pallier
│   └── venv_py35_pyros/
59 226 Etienne Pallier
├── public/
60 226 Etienne Pallier
│   └── static/
61 226 Etienne Pallier
├── src/
62 226 Etienne Pallier
│   ├── manage.py
63 226 Etienne Pallier
│   ├── pyros/
64 226 Etienne Pallier
│   │   ├── __init__.py
65 226 Etienne Pallier
│   │   ├── __pycache__
66 226 Etienne Pallier
│   │   ├── settings.py
67 226 Etienne Pallier
│   │   ├── urls.py
68 226 Etienne Pallier
│   │   └── wsgi.py
69 226 Etienne Pallier
│   └── pyrosapp/
70 226 Etienne Pallier
│       ├── __init__.py
71 226 Etienne Pallier
│       ├── admin.py
72 226 Etienne Pallier
│       ├── apps.py
73 226 Etienne Pallier
│       ├── migrations
74 226 Etienne Pallier
│       ├── models.py
75 226 Etienne Pallier
│       ├── tests.py
76 226 Etienne Pallier
│       └── views.py
77 226 Etienne Pallier
78 226 Etienne Pallier
79 226 Etienne Pallier
</pre>
80 226 Etienne Pallier
81 174 Etienne Pallier
82 174 Etienne Pallier
h3. Get the project from Eclipse
83 169 Etienne Pallier
84 197 Etienne Pallier
<pre>
85 169 Etienne Pallier
TODO:
86 197 Etienne Pallier
</pre>
87 169 Etienne Pallier
88 141 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}III - INSTALLATION%
89 2 Etienne Pallier
90 120 Etienne Pallier
91 120 Etienne Pallier
---
92 120 Etienne Pallier
93 184 Etienne Pallier
h3. Install MySql (only if necessary)
94 2 Etienne Pallier
95 49 Etienne Pallier
 * Linux Ubuntu
96 49 Etienne Pallier
<pre>
97 107 Paul Carensac
98 107 Paul Carensac
$ sudo apt-get install mysql-server
99 107 Paul Carensac
$ sudo apt-get install mysql-client
100 107 Paul Carensac
101 49 Etienne Pallier
</pre>
102 49 Etienne Pallier
103 49 Etienne Pallier
 * Linux CentOS
104 49 Etienne Pallier
<pre>
105 49 Etienne Pallier
TODO:
106 49 Etienne Pallier
$ sudo yum install mysql
107 49 Etienne Pallier
...
108 49 Etienne Pallier
</pre>
109 49 Etienne Pallier
110 49 Etienne Pallier
 * Mac OS X
111 1 Etienne Pallier
Install XAMPP
112 1 Etienne Pallier
(but you could also use the pre-installed Mac OS MySql)
113 177 Etienne Pallier
<pre>
114 177 Etienne Pallier
TODO:
115 49 Etienne Pallier
</pre>
116 1 Etienne Pallier
117 49 Etienne Pallier
 * Windows
118 243 Paul Carensac
119 1 Etienne Pallier
<pre>
120 243 Paul Carensac
Download and install the newest version on https://dev.mysql.com/downloads/installer/
121 243 Paul Carensac
122 243 Paul Carensac
Once installed, launch MySQL Installer. Clic on 'Add...' on the right.
123 243 Paul Carensac
In MySQLServers section, choose the newest, then clic on next.
124 243 Paul Carensac
Install and configure the server (just follow the installation guide).
125 243 Paul Carensac
126 243 Paul Carensac
Then launch mysql (via the Windows menu).
127 49 Etienne Pallier
</pre>
128 49 Etienne Pallier
129 49 Etienne Pallier
130 49 Etienne Pallier
---
131 1 Etienne Pallier
132 185 Etienne Pallier
h3. Install Python3.5 (only if necessary)
133 1 Etienne Pallier
134 11 Etienne Pallier
135 11 Etienne Pallier
 * Mac OS X :
136 1 Etienne Pallier
<pre>
137 183 Etienne Pallier
138 24 Etienne Pallier
1) Installer MacPort
139 24 Etienne Pallier
(TODO: doc)
140 24 Etienne Pallier
141 24 Etienne Pallier
2) Installer le "port" python35
142 1 Etienne Pallier
$ sudo port install python35
143 183 Etienne Pallier
144 1 Etienne Pallier
</pre>
145 1 Etienne Pallier
146 1 Etienne Pallier
 * Linux (Ubuntu) :
147 1 Etienne Pallier
<pre>
148 107 Paul Carensac
sudo add-apt-repository ppa:fkrull/deadsnakes
149 107 Paul Carensac
sudo apt-get update
150 107 Paul Carensac
sudo apt-get install python3.5
151 107 Paul Carensac
152 107 Paul Carensac
sudo pip install virtualenv
153 23 Etienne Pallier
</pre>
154 1 Etienne Pallier
155 1 Etienne Pallier
156 183 Etienne Pallier
 * Windows 10 :
157 183 Etienne Pallier
<pre>
158 187 Etienne Pallier
TODO:
159 183 Etienne Pallier
</pre>
160 3 Etienne Pallier
161 4 Etienne Pallier
---
162 5 Etienne Pallier
163 192 Etienne Pallier
h3. Create a Python3 virtual environment dedicated to the project (inside the project folder)
164 127 Etienne Pallier
165 131 Etienne Pallier
<pre>
166 1 Etienne Pallier
167 193 Etienne Pallier
$ mkdir private/
168 193 Etienne Pallier
169 133 Etienne Pallier
$ cd private/
170 3 Etienne Pallier
171 3 Etienne Pallier
$ which python3.5
172 3 Etienne Pallier
/opt/local/bin/python3.5
173 15 Etienne Pallier
174 127 Etienne Pallier
$ virtualenv-3.5 venv_py35_pyros -p /opt/local/bin/python3.5
175 3 Etienne Pallier
=> creates a venv_py35_pyros/ folder inside PYROS/private/
176 1 Etienne Pallier
177 131 Etienne Pallier
</pre>
178 1 Etienne Pallier
179 7 Etienne Pallier
---
180 3 Etienne Pallier
181 65 Etienne Pallier
h3. Activate the python virtual environment (from inside the project)
182 7 Etienne Pallier
183 55 Etienne Pallier
<pre>
184 1 Etienne Pallier
185 65 Etienne Pallier
$ pwd
186 134 Etienne Pallier
.../PYROS/private
187 1 Etienne Pallier
188 65 Etienne Pallier
$ source ./venv_py35_pyros/bin/activate
189 65 Etienne Pallier
190 3 Etienne Pallier
$ python -V
191 1 Etienne Pallier
Python 3.5.1
192 3 Etienne Pallier
193 3 Etienne Pallier
$ which pip
194 77 Etienne Pallier
.../PYROS/venv_py35_pyros/bin/pip
195 16 Etienne Pallier
196 194 Etienne Pallier
Upgrade pip to last version available:
197 3 Etienne Pallier
$ pip install --upgrade pip
198 3 Etienne Pallier
Collecting pip
199 3 Etienne Pallier
  Downloading pip-8.1.1-py2.py3-none-any.whl (1.2MB)
200 3 Etienne Pallier
Installing collected packages: pip
201 3 Etienne Pallier
  Found existing installation: pip 7.1.2
202 3 Etienne Pallier
    Uninstalling pip-7.1.2:
203 3 Etienne Pallier
      Successfully uninstalled pip-7.1.2
204 1 Etienne Pallier
Successfully installed pip-8.1.1
205 194 Etienne Pallier
206 194 Etienne Pallier
Upgrade wheel to last version available:
207 194 Etienne Pallier
$ pip install --upgrade wheel
208 194 Etienne Pallier
Collecting wheel
209 194 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
210 194 Etienne Pallier
Installing collected packages: wheel
211 194 Etienne Pallier
  Found existing installation: wheel 0.24.0
212 194 Etienne Pallier
    Uninstalling wheel-0.24.0:
213 194 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
214 194 Etienne Pallier
Successfully installed wheel-0.29.0
215 194 Etienne Pallier
216 55 Etienne Pallier
217 55 Etienne Pallier
</pre>
218 18 Etienne Pallier
219 212 Etienne Pallier
h3. Install the needed Python packages (from within the virtual environment)
220 18 Etienne Pallier
221 66 Etienne Pallier
First, be sure that the virtual environment is activated:
222 66 Etienne Pallier
<pre>
223 66 Etienne Pallier
$ python -V
224 66 Etienne Pallier
Python 3.5.1
225 66 Etienne Pallier
</pre>
226 66 Etienne Pallier
227 62 Etienne Pallier
 * *Automatic Installation of all packages*
228 62 Etienne Pallier
<pre>
229 90 Etienne Pallier
$ pip install -r REQUIREMENTS.txt
230 62 Etienne Pallier
</pre>
231 62 Etienne Pallier
232 93 Etienne Pallier
 * *Or, manual installation of each package*
233 62 Etienne Pallier
234 62 Etienne Pallier
  * *Install Django* :
235 32 Etienne Pallier
<pre>
236 3 Etienne Pallier
$ pip install django
237 3 Etienne Pallier
Collecting django
238 3 Etienne Pallier
  Downloading Django-1.9.4-py2.py3-none-any.whl (6.6MB)
239 3 Etienne Pallier
Installing collected packages: django
240 3 Etienne Pallier
Successfully installed django-1.9.4
241 3 Etienne Pallier
242 3 Etienne Pallier
$ pip install django-admin-tools
243 3 Etienne Pallier
Collecting django-admin-tools
244 3 Etienne Pallier
  Downloading django_admin_tools-0.7.2-py2.py3-none-any.whl (289kB)
245 3 Etienne Pallier
Installing collected packages: django-admin-tools
246 3 Etienne Pallier
Successfully installed django-admin-tools-0.7.2
247 3 Etienne Pallier
248 21 Etienne Pallier
$ pip install django-debug-toolbar
249 21 Etienne Pallier
Collecting django-debug-toolbar
250 21 Etienne Pallier
  Downloading django_debug_toolbar-1.4-py2.py3-none-any.whl (212kB)
251 21 Etienne Pallier
Requirement already satisfied (use --upgrade to upgrade): Django>=1.7 in ./venv_py35_pyros/lib/python3.5/site-packages (from django-debug-toolbar)
252 21 Etienne Pallier
Collecting sqlparse (from django-debug-toolbar)
253 21 Etienne Pallier
  Downloading sqlparse-0.1.19.tar.gz (58kB)
254 21 Etienne Pallier
Building wheels for collected packages: sqlparse
255 21 Etienne Pallier
  Running setup.py bdist_wheel for sqlparse ... done
256 21 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/7b/d4/72/6011bb100dd5fc213164e4bbee13d4e03261dd54ce6a5de6b8
257 21 Etienne Pallier
Successfully built sqlparse
258 21 Etienne Pallier
Installing collected packages: sqlparse, django-debug-toolbar
259 21 Etienne Pallier
Successfully installed django-debug-toolbar-1.4 sqlparse-0.1.19
260 21 Etienne Pallier
261 21 Etienne Pallier
$ pip install django-extensions
262 21 Etienne Pallier
Collecting django-extensions
263 21 Etienne Pallier
  Downloading django_extensions-1.6.1-py2.py3-none-any.whl (202kB)
264 21 Etienne Pallier
Collecting six>=1.2 (from django-extensions)
265 21 Etienne Pallier
  Downloading six-1.10.0-py2.py3-none-any.whl
266 21 Etienne Pallier
Installing collected packages: six, django-extensions
267 21 Etienne Pallier
Successfully installed django-extensions-1.6.1 six-1.10.0
268 21 Etienne Pallier
269 21 Etienne Pallier
$ pip install django-suit
270 21 Etienne Pallier
Collecting django-suit
271 21 Etienne Pallier
  Downloading django-suit-0.2.18.tar.gz (587kB)
272 21 Etienne Pallier
Building wheels for collected packages: django-suit
273 1 Etienne Pallier
  Running setup.py bdist_wheel for django-suit ... done
274 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/12/8b/9a/e02ab0ad9229881638aa040d47d77c8f562999533811927d41
275 1 Etienne Pallier
Successfully built django-suit
276 1 Etienne Pallier
Installing collected packages: django-suit
277 1 Etienne Pallier
Successfully installed django-suit-0.2.18
278 21 Etienne Pallier
279 32 Etienne Pallier
</pre>
280 32 Etienne Pallier
281 63 Etienne Pallier
  * *Install the web application server gunicorn (will be used in production instead of the dev django web server)* :
282 32 Etienne Pallier
<pre>
283 25 Etienne Pallier
$ pip install gunicorn
284 25 Etienne Pallier
Collecting gunicorn
285 25 Etienne Pallier
  Downloading gunicorn-19.4.5-py2.py3-none-any.whl (112kB)
286 21 Etienne Pallier
Installing collected packages: gunicorn
287 26 Etienne Pallier
Successfully installed gunicorn-19.4.5
288 1 Etienne Pallier
</pre>
289 1 Etienne Pallier
290 63 Etienne Pallier
  * *Install the python mysql client*:
291 32 Etienne Pallier
<pre>
292 32 Etienne Pallier
$ pip install mysqlclient
293 72 Etienne Pallier
...
294 72 Etienne Pallier
</pre>
295 33 Etienne Pallier
296 73 Etienne Pallier
   * => Issue under Mac OS X:
297 72 Etienne Pallier
<pre>
298 3 Etienne Pallier
$ pip install mysqlclient
299 3 Etienne Pallier
Collecting mysqlclient
300 1 Etienne Pallier
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
301 22 Etienne Pallier
Building wheels for collected packages: mysqlclient
302 3 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... error
303 3 Etienne Pallier
304 1 Etienne Pallier
  ----------------------------------------
305 1 Etienne Pallier
  Failed building wheel for mysqlclient
306 1 Etienne Pallier
  Running setup.py clean for mysqlclient
307 1 Etienne Pallier
Failed to build mysqlclient
308 1 Etienne Pallier
Installing collected packages: mysqlclient
309 1 Etienne Pallier
  Running setup.py install for mysqlclient ... done
310 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
311 1 Etienne Pallier
312 1 Etienne Pallier
BOUH !!!
313 1 Etienne Pallier
314 1 Etienne Pallier
$ pip install --upgrade wheel
315 1 Etienne Pallier
Collecting wheel
316 1 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
317 1 Etienne Pallier
Installing collected packages: wheel
318 1 Etienne Pallier
  Found existing installation: wheel 0.24.0
319 1 Etienne Pallier
    Uninstalling wheel-0.24.0:
320 1 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
321 1 Etienne Pallier
Successfully installed wheel-0.29.0
322 1 Etienne Pallier
323 1 Etienne Pallier
$ pip uninstall mysqlclient
324 1 Etienne Pallier
325 1 Etienne Pallier
$ pip install mysqlclient
326 1 Etienne Pallier
Collecting mysqlclient
327 1 Etienne Pallier
  Using cached mysqlclient-1.3.7.tar.gz
328 1 Etienne Pallier
Building wheels for collected packages: mysqlclient
329 1 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... done
330 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/9b/06/50/d11418c26cf8f2156b13d4363b5afde8e7e75ebb8540d0228d
331 1 Etienne Pallier
Successfully built mysqlclient
332 1 Etienne Pallier
Installing collected packages: mysqlclient
333 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
334 1 Etienne Pallier
335 1 Etienne Pallier
YES !!!
336 1 Etienne Pallier
337 1 Etienne Pallier
</pre>
338 1 Etienne Pallier
339 107 Paul Carensac
   * => Issues under Ubuntu:
340 107 Paul Carensac
<pre>
341 107 Paul Carensac
$ pip install mysqlclient
342 107 Paul Carensac
Collecting mysqlclient
343 107 Paul Carensac
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
344 107 Paul Carensac
    100% |████████████████████████████████| 81kB 1.5MB/s
345 107 Paul Carensac
    Complete output from command python setup.py egg_info:
346 107 Paul Carensac
    /bin/sh: 1: mysql_config: not found
347 107 Paul Carensac
    Traceback (most recent call last):
348 107 Paul Carensac
      File "<string>", line 1, in <module>
349 107 Paul Carensac
    [...]
350 107 Paul Carensac
    ----------------------------------------
351 107 Paul Carensac
Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-q6j4inuz/mysqlclient/
352 1 Etienne Pallier
353 108 Paul Carensac
BOUH !!!
354 108 Paul Carensac
355 107 Paul Carensac
$ sudo apt-get install libmysqlclient-dev
356 108 Paul Carensac
357 107 Paul Carensac
$ pip install mysqlclient
358 107 Paul Carensac
Collecting mysqlclient
359 107 Paul Carensac
  Using cached mysqlclient-1.3.7.tar.gz
360 107 Paul Carensac
Building wheels for collected packages: mysqlclient
361 107 Paul Carensac
  Running setup.py bdist_wheel for mysqlclient ... error
362 107 Paul Carensac
363 107 Paul Carensac
    _mysql.c:40:20: fatal error: Python.h: No such file or directory
364 107 Paul Carensac
     #include "Python.h"
365 107 Paul Carensac
                        ^
366 107 Paul Carensac
    compilation terminated.
367 107 Paul Carensac
    error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
368 107 Paul Carensac
    
369 107 Paul Carensac
    ----------------------------------------
370 107 Paul Carensac
Command "/home/carens_p/pyros/venv_py35_pyros/bin/python3.5 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-k3klv92j/mysqlclient/setup.py';exec(compile(getattr(tokenize, 'open', open)(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --record /tmp/pip-gz242xxs-record/install-record.txt --single-version-externally-managed --compile --install-headers /home/carens_p/pyros/venv_py35_pyros/include/site/python3.5/mysqlclient" failed with error code 1 in /tmp/pip-build-k3klv92j/mysqlclient/
371 107 Paul Carensac
372 108 Paul Carensac
BOUH !!!
373 108 Paul Carensac
374 107 Paul Carensac
$ sudo apt-get install python3.5-dev
375 108 Paul Carensac
376 107 Paul Carensac
$ pip install mysqlclient
377 107 Paul Carensac
378 107 Paul Carensac
YES !!!
379 107 Paul Carensac
380 107 Paul Carensac
</pre>
381 12 Etienne Pallier
382 12 Etienne Pallier
---
383 28 Etienne Pallier
384 142 Etienne Pallier
h3. Test the project
385 142 Etienne Pallier
386 142 Etienne Pallier
<pre>
387 142 Etienne Pallier
388 150 Etienne Pallier
$ cd src/
389 150 Etienne Pallier
390 1 Etienne Pallier
$ ./manage.py runserver
391 38 Etienne Pallier
(or gunicorn pyros.wsgi)
392 3 Etienne Pallier
==> http://localhost:8000
393 87 Etienne Pallier
...
394 87 Etienne Pallier
...
395 87 Etienne Pallier
Ctrl-c
396 87 Etienne Pallier
397 1 Etienne Pallier
</pre>
398 142 Etienne Pallier
399 142 Etienne Pallier
400 142 Etienne Pallier
401 142 Etienne Pallier
---
402 142 Etienne Pallier
403 156 Paul Carensac
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}IV - CONFIGURATION of the Django Back Office (administration interface)%
404 155 Paul Carensac
405 155 Paul Carensac
---
406 155 Paul Carensac
407 155 Paul Carensac
h3. Back Office setup
408 155 Paul Carensac
409 155 Paul Carensac
 * Prerequisites in src/pyros/settings.py :
410 155 Paul Carensac
411 155 Paul Carensac
    * INSTALLED_APPS must (at least) contain :
412 155 Paul Carensac
413 155 Paul Carensac
        * django.contrib.admin
414 155 Paul Carensac
        * django.contrib.auth
415 155 Paul Carensac
        * django.contrib.contenttypes
416 155 Paul Carensac
        * django.contrib.sessions
417 155 Paul Carensac
418 155 Paul Carensac
    * MIDDLEWARES must (at least) contain :
419 155 Paul Carensac
420 155 Paul Carensac
        * django.contrib.sessions.middleware.SessionMiddleware
421 155 Paul Carensac
        * django.middleware.common.CommonMiddleware
422 155 Paul Carensac
        * django.contrib.auth.middleware.AuthenticationMiddleware
423 155 Paul Carensac
424 155 Paul Carensac
 * At least one 'python manage.py migrate' must have been executed
425 155 Paul Carensac
426 155 Paul Carensac
 * Create a superuser for the administration :
427 155 Paul Carensac
428 155 Paul Carensac
<pre>
429 155 Paul Carensac
$ python manage.py createsuperuser
430 155 Paul Carensac
</pre>
431 155 Paul Carensac
432 156 Paul Carensac
* For each app of the project, fill the admin.py file :
433 155 Paul Carensac
434 155 Paul Carensac
<pre>
435 155 Paul Carensac
from django.contrib import admin
436 155 Paul Carensac
from app.models import Model1, Model2
437 155 Paul Carensac
438 155 Paul Carensac
admin.site.register(Model1)
439 155 Paul Carensac
admin.site.register(Model2)
440 155 Paul Carensac
</pre>
441 155 Paul Carensac
442 155 Paul Carensac
*Reminder* : each application must be registered in the settings.py INSTALLED_APPS variable.
443 157 Paul Carensac
444 168 Paul Carensac
* For each model in models.py, add a '__str__()' method in order to identify the object on the back office. Example :
445 157 Paul Carensac
446 157 Paul Carensac
<pre>
447 157 Paul Carensac
class UserLevel(models.Model):
448 157 Paul Carensac
    name = models.CharField(max_length=45, blank=True, null=True)
449 157 Paul Carensac
    desc = models.TextField(blank=True, null=True)
450 157 Paul Carensac
    priority = models.IntegerField(blank=True, null=True)
451 157 Paul Carensac
    quota = models.FloatField(blank=True, null=True)
452 157 Paul Carensac
453 157 Paul Carensac
    class Meta:
454 157 Paul Carensac
        managed = True
455 157 Paul Carensac
        db_table = 'userlevel'
456 157 Paul Carensac
457 157 Paul Carensac
    def __str__(self):
458 163 Paul Carensac
        return (str(self.name))
459 157 Paul Carensac
</pre>
460 157 Paul Carensac
461 159 Paul Carensac
*Naming convention* : Use self.name when possible, the creation time/date otherwise. Example :
462 159 Paul Carensac
463 159 Paul Carensac
<pre>
464 159 Paul Carensac
class SiteWatch(models.Model):
465 159 Paul Carensac
    updated = models.DateTimeField(blank=True, null=True)
466 159 Paul Carensac
    lights = models.CharField(max_length=45, blank=True, null=True)
467 159 Paul Carensac
    dome = models.CharField(max_length=45, blank=True, null=True)
468 159 Paul Carensac
    doors = models.CharField(max_length=45, blank=True, null=True)
469 159 Paul Carensac
    temperature = models.FloatField(blank=True, null=True)
470 159 Paul Carensac
471 159 Paul Carensac
    class Meta:
472 159 Paul Carensac
        managed = True
473 159 Paul Carensac
        db_table = 'sitewatch'
474 159 Paul Carensac
475 159 Paul Carensac
    def __str__(self):
476 160 Paul Carensac
        return (str(self.updated))
477 159 Paul Carensac
</pre>
478 173 Etienne Pallier
479 211 Paul Carensac
---
480 211 Paul Carensac
481 211 Paul Carensac
h3. Adaptation of the one-to-many and many-to-many display
482 211 Paul Carensac
483 211 Paul Carensac
* The one-to-many relationships are the following (One.many format) :
484 211 Paul Carensac
485 211 Paul Carensac
    * Schedule.sequences
486 211 Paul Carensac
    * Request.sequences
487 211 Paul Carensac
    * Sequence.albums
488 211 Paul Carensac
    * Album.plans
489 211 Paul Carensac
    * Plan.images
490 211 Paul Carensac
    * Telescope.detectors
491 211 Paul Carensac
    * Detector.filters
492 211 Paul Carensac
    * NrtAnalysis.images
493 211 Paul Carensac
    * Filter.plans
494 211 Paul Carensac
    * Detector.albums
495 211 Paul Carensac
    * UserLevel.users
496 211 Paul Carensac
    * Country.users
497 211 Paul Carensac
    * ScientificProgram.requests
498 211 Paul Carensac
    * User.requests
499 211 Paul Carensac
    * StrategyObs.alerts
500 211 Paul Carensac
    * SequenceType.sequences
501 211 Paul Carensac
502 211 Paul Carensac
* For each "many", create a new class in admin.py just after the imports, following these examples :
503 211 Paul Carensac
504 211 Paul Carensac
<pre>
505 211 Paul Carensac
506 211 Paul Carensac
For Schedule.sequences, Request.sequences and Sequentype.sequences, we will need :
507 211 Paul Carensac
508 211 Paul Carensac
class SequenceInline(admin.TabularInline):
509 211 Paul Carensac
    model = Sequence
510 211 Paul Carensac
    fields = ("name",)
511 211 Paul Carensac
    show_change_link = True
512 211 Paul Carensac
513 211 Paul Carensac
514 211 Paul Carensac
For Sequence.albums and Detector.albums, we will need :
515 211 Paul Carensac
516 211 Paul Carensac
class AlbumInline(admin.TabularInline):
517 211 Paul Carensac
    model = Album
518 211 Paul Carensac
    fields = ("name",)
519 211 Paul Carensac
    show_change_link = True
520 211 Paul Carensac
521 211 Paul Carensac
522 211 Paul Carensac
For StrategyObs.alerts, we will need :
523 211 Paul Carensac
524 211 Paul Carensac
class AlertInline(admin.TabularInline):
525 211 Paul Carensac
    model = Alert
526 211 Paul Carensac
    fields = ("request.name",) # there is no 'name' attribute in the Alert model
527 211 Paul Carensac
    show_change_link = True
528 211 Paul Carensac
529 211 Paul Carensac
</pre>
530 211 Paul Carensac
531 222 Paul Carensac
* For each "One", declare a new class in admin.py, just after the "Inlines" class declaration, as done in the following examples :
532 211 Paul Carensac
533 222 Paul Carensac
<pre>
534 222 Paul Carensac
For Request.sequences :
535 222 Paul Carensac
536 222 Paul Carensac
class RequestAdmin(admin.ModelAdmin):
537 222 Paul Carensac
    inlines = [
538 222 Paul Carensac
	SequenceInline,
539 222 Paul Carensac
    ]
540 222 Paul Carensac
541 222 Paul Carensac
For Detector.filters and Detector.albums :
542 222 Paul Carensac
543 222 Paul Carensac
class DetectorAdmin(admin.ModelAdmin):
544 222 Paul Carensac
    inlines = [
545 222 Paul Carensac
	FilterInline,
546 222 Paul Carensac
        AlbumInline,
547 222 Paul Carensac
    ]
548 222 Paul Carensac
549 222 Paul Carensac
</pre>
550 222 Paul Carensac
551 232 Paul Carensac
552 222 Paul Carensac
* The many-to-many relationships are the following :
553 232 Paul Carensac
554 222 Paul Carensac
    * ScientificProgram - User
555 222 Paul Carensac
    * ScheduleHistory - Sequence
556 222 Paul Carensac
557 222 Paul Carensac
* For each many-to-many relationship, declare a new "Inline" class in admin.py just after the imports, like this :
558 222 Paul Carensac
559 222 Paul Carensac
<pre>
560 222 Paul Carensac
For ScientificProgram - User :
561 222 Paul Carensac
562 222 Paul Carensac
class UserAndSPInline(admin.TabularInline):
563 222 Paul Carensac
    model = ScientificProgram.users.through
564 222 Paul Carensac
565 222 Paul Carensac
566 222 Paul Carensac
For ScheduleHistory - Sequence
567 222 Paul Carensac
568 222 Paul Carensac
class SequenceAndSHInline(admin.TabularInline):
569 222 Paul Carensac
    model = ScheduleHistory.sequences.through
570 222 Paul Carensac
571 222 Paul Carensac
</pre>
572 222 Paul Carensac
573 222 Paul Carensac
+Note :+ The order in the line "model = ScientificProgram.users.through" is very important : the first model (ScientificProgram) is the one in which is declared the ManyToManyField relationship.
574 232 Paul Carensac
575 232 Paul Carensac
* For each many-to-many relationship, declare two new classes in admin.py, just after the inlines, like in the following examples :
576 232 Paul Carensac
577 232 Paul Carensac
<pre>
578 232 Paul Carensac
For the ScheduleHistory - Sequence relationship :
579 232 Paul Carensac
580 232 Paul Carensac
class ScheduleHistoryAdmin(admin.ModelAdmin):
581 232 Paul Carensac
    inlines = [
582 232 Paul Carensac
        SequenceAndSHInline,
583 232 Paul Carensac
    ]
584 232 Paul Carensac
    exclude = ('sequences',) # ScheduleHistory declares the ManyToManyField, and we want to replace its display in the back office, so we won't display the default field
585 232 Paul Carensac
586 232 Paul Carensac
class SequenceAdmin(admin.ModelAdmin):
587 232 Paul Carensac
    inlines = [
588 232 Paul Carensac
        AlbumInline,        # This is the Inline for the one-to-many relationship Sequence.albums
589 232 Paul Carensac
        SequenceAndSHInline,                                                                
590 232 Paul Carensac
    ]
591 232 Paul Carensac
592 232 Paul Carensac
For the ScientificProgram - User relationship :
593 232 Paul Carensac
594 232 Paul Carensac
class ScientificProgramAdmin(admin.ModelAdmin):
595 232 Paul Carensac
    inlines = [
596 232 Paul Carensac
        RequestInline,
597 232 Paul Carensac
	UserAndSPInline,                                                                         
598 232 Paul Carensac
    ]
599 232 Paul Carensac
    exclude = ('users',) # Same as ScheduleHistory                                                                         
600 232 Paul Carensac
601 232 Paul Carensac
class UserAdmin(admin.ModelAdmin):
602 232 Paul Carensac
    inlines = [
603 232 Paul Carensac
	RequestInline,   # This is the Inline for the one-to-many relationship User.requests
604 232 Paul Carensac
        UserAndSPInline,                                                                    
605 232 Paul Carensac
    ]
606 232 Paul Carensac
607 232 Paul Carensac
</pre>
608 232 Paul Carensac
609 235 Paul Carensac
* For each ModelAdmin class in the admin.py, change the registering line
610 235 Paul Carensac
611 235 Paul Carensac
<pre>
612 235 Paul Carensac
admin.site.register(Album)
613 235 Paul Carensac
</pre>
614 235 Paul Carensac
615 235 Paul Carensac
to
616 235 Paul Carensac
617 235 Paul Carensac
<pre>
618 235 Paul Carensac
admin.site.register(Album, AlbumAdmin)
619 235 Paul Carensac
</pre>
620 211 Paul Carensac
621 229 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}V - INSTALLATION FROM THE BEGINNING (for dev only, history of the initial project creation)%
622 1 Etienne Pallier
623 236 Etienne Pallier
624 242 Etienne Pallier
[[pyros_install_from_start|Pyros installation from the beginning]]