Wiki

Version 162 (Etienne Pallier, 03/21/2016 04:58 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 126 Etienne Pallier
 * récupération des modules existants
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 141 Etienne Pallier
https://gitlab.irap.omp.eu/epallier/pyros
37 141 Etienne Pallier
38 161 Etienne Pallier
https://gitlab.irap.omp.eu/epallier/pyros.git
39 161 Etienne Pallier
40 161 Etienne Pallier
ssh git@gitlab.irap.omp.eu:epallier/pyros.git
41 141 Etienne Pallier
42 162 Etienne Pallier
43 162 Etienne Pallier
h3. How the git repository was created
44 162 Etienne Pallier
45 162 Etienne Pallier
<pre>
46 162 Etienne Pallier
47 162 Etienne Pallier
48 162 Etienne Pallier
$ cd PYROS/
49 162 Etienne Pallier
50 162 Etienne Pallier
Define files and folders to be ignored:
51 162 Etienne Pallier
$ vi .gitignore
52 162 Etienne Pallier
.DS_Store
53 162 Etienne Pallier
private
54 162 Etienne Pallier
__pycache__
55 162 Etienne Pallier
56 162 Etienne Pallier
$ 
57 162 Etienne Pallier
58 162 Etienne Pallier
</pre>
59 162 Etienne Pallier
60 141 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}III - INSTALLATION%
61 2 Etienne Pallier
62 120 Etienne Pallier
63 120 Etienne Pallier
---
64 120 Etienne Pallier
65 51 Etienne Pallier
h3. If necessary, install MySql
66 2 Etienne Pallier
67 49 Etienne Pallier
 * Linux Ubuntu
68 49 Etienne Pallier
<pre>
69 107 Paul Carensac
70 107 Paul Carensac
$ sudo apt-get install mysql-server
71 107 Paul Carensac
$ sudo apt-get install mysql-client
72 107 Paul Carensac
73 49 Etienne Pallier
</pre>
74 49 Etienne Pallier
75 49 Etienne Pallier
 * Linux CentOS
76 49 Etienne Pallier
<pre>
77 49 Etienne Pallier
TODO:
78 49 Etienne Pallier
$ sudo yum install mysql
79 49 Etienne Pallier
...
80 49 Etienne Pallier
</pre>
81 49 Etienne Pallier
82 49 Etienne Pallier
 * Mac OS X
83 49 Etienne Pallier
<pre>
84 49 Etienne Pallier
TODO:
85 49 Etienne Pallier
Install XAMPP
86 49 Etienne Pallier
(but you could also use the pre-installed Mac OS MySql)
87 49 Etienne Pallier
</pre>
88 49 Etienne Pallier
89 49 Etienne Pallier
 * Windows
90 49 Etienne Pallier
<pre>
91 49 Etienne Pallier
TODO:
92 49 Etienne Pallier
</pre>
93 49 Etienne Pallier
94 49 Etienne Pallier
95 49 Etienne Pallier
---
96 1 Etienne Pallier
97 6 Etienne Pallier
h3. Create database
98 1 Etienne Pallier
99 52 Etienne Pallier
100 52 Etienne Pallier
 * Linux and Mac OS X:
101 52 Etienne Pallier
<pre>
102 3 Etienne Pallier
One liner:
103 115 Etienne Pallier
$ mysql -u root < pyros_create.sql
104 1 Etienne Pallier
105 3 Etienne Pallier
Or :
106 3 Etienne Pallier
$ mysql -u root
107 3 Etienne Pallier
mysql> create database pyros;
108 3 Etienne Pallier
mysql> use pyros;
109 115 Etienne Pallier
mysql> source pyros_create.sql;
110 1 Etienne Pallier
111 3 Etienne Pallier
(
112 3 Etienne Pallier
TODO:
113 3 Etienne Pallier
mysql> grant all on pyros.* to pyros@localhost identified by ‘pyros’;)
114 3 Etienne Pallier
mysql> flush privileges;
115 3 Etienne Pallier
)
116 52 Etienne Pallier
</pre>
117 1 Etienne Pallier
118 53 Etienne Pallier
119 53 Etienne Pallier
 * Windows:
120 52 Etienne Pallier
<pre>
121 52 Etienne Pallier
TODO: Use phpmyadmin ?
122 52 Etienne Pallier
</pre>
123 1 Etienne Pallier
124 1 Etienne Pallier
125 4 Etienne Pallier
---
126 5 Etienne Pallier
127 6 Etienne Pallier
h3. Install python3.5
128 1 Etienne Pallier
129 11 Etienne Pallier
130 11 Etienne Pallier
 * Mac OS X :
131 23 Etienne Pallier
<pre>
132 24 Etienne Pallier
1) Installer MacPort
133 24 Etienne Pallier
(TODO: doc)
134 24 Etienne Pallier
135 24 Etienne Pallier
2) Installer le "port" python35
136 1 Etienne Pallier
$ sudo port install python35
137 1 Etienne Pallier
</pre>
138 1 Etienne Pallier
139 1 Etienne Pallier
 * Linux (Ubuntu) :
140 1 Etienne Pallier
<pre>
141 107 Paul Carensac
sudo add-apt-repository ppa:fkrull/deadsnakes
142 107 Paul Carensac
sudo apt-get update
143 107 Paul Carensac
sudo apt-get install python3.5
144 107 Paul Carensac
145 107 Paul Carensac
sudo pip install virtualenv
146 23 Etienne Pallier
</pre>
147 1 Etienne Pallier
148 5 Etienne Pallier
149 3 Etienne Pallier
150 4 Etienne Pallier
---
151 5 Etienne Pallier
152 59 Etienne Pallier
h3. Get the project (from git)
153 59 Etienne Pallier
154 78 Etienne Pallier
<pre>
155 59 Etienne Pallier
TODO:
156 79 Etienne Pallier
157 130 Etienne Pallier
$ git http://pyros... PYROS
158 78 Etienne Pallier
</pre>
159 1 Etienne Pallier
160 130 Etienne Pallier
This creates a PYROS folder containing the project
161 59 Etienne Pallier
162 59 Etienne Pallier
163 59 Etienne Pallier
---
164 59 Etienne Pallier
165 131 Etienne Pallier
h3. Create project structure
166 131 Etienne Pallier
167 131 Etienne Pallier
<pre>
168 131 Etienne Pallier
$ mkdir PYROS
169 132 Etienne Pallier
</pre>
170 131 Etienne Pallier
171 131 Etienne Pallier
Example of a good organization :
172 131 Etienne Pallier
173 131 Etienne Pallier
1 project = N applis
174 158 Etienne Pallier
1 appli = N models
175 158 Etienne Pallier
A! L’appli est à côté du projet, PAS DEDANS,
176 158 Etienne Pallier
cela facilite la REUTILISATION
177 158 Etienne Pallier
(an appli can be part of many projects => reuse)
178 131 Etienne Pallier
1 appli = 1 Python module, organized for Django, by default = appli web (but not mandatory)
179 131 Etienne Pallier
180 131 Etienne Pallier
<pre>
181 131 Etienne Pallier
182 131 Etienne Pallier
MYPROJECT/
183 131 Etienne Pallier
184 131 Etienne Pallier
185 131 Etienne Pallier
	src/
186 131 Etienne Pallier
		myproject/
187 131 Etienne Pallier
		appli1/
188 131 Etienne Pallier
		appli2/
189 131 Etienne Pallier
190 131 Etienne Pallier
		appliN/
191 131 Etienne Pallier
192 131 Etienne Pallier
	public/
193 131 Etienne Pallier
		static/
194 131 Etienne Pallier
195 131 Etienne Pallier
	private/
196 131 Etienne Pallier
		REQUIREMENTS.txt
197 148 Etienne Pallier
		venv_py35_pyros/
198 131 Etienne Pallier
199 131 Etienne Pallier
</pre>
200 131 Etienne Pallier
201 131 Etienne Pallier
202 131 Etienne Pallier
Set needed folders:
203 131 Etienne Pallier
<pre>
204 131 Etienne Pallier
$ cd PYROS/
205 131 Etienne Pallier
$ mkdir private public
206 131 Etienne Pallier
$ mkdir public/static
207 131 Etienne Pallier
</pre>
208 131 Etienne Pallier
209 131 Etienne Pallier
210 131 Etienne Pallier
211 131 Etienne Pallier
---
212 131 Etienne Pallier
213 3 Etienne Pallier
h3. Create virtualenv with python3.5 dedicated to pyros project (inside the project folder)
214 127 Etienne Pallier
215 131 Etienne Pallier
<pre>
216 1 Etienne Pallier
217 133 Etienne Pallier
$ cd private/
218 3 Etienne Pallier
219 3 Etienne Pallier
$ which python3.5
220 3 Etienne Pallier
/opt/local/bin/python3.5
221 15 Etienne Pallier
222 127 Etienne Pallier
$ virtualenv-3.5 venv_py35_pyros -p /opt/local/bin/python3.5
223 3 Etienne Pallier
=> creates a venv_py35_pyros/ folder inside PYROS/private/
224 1 Etienne Pallier
225 131 Etienne Pallier
</pre>
226 1 Etienne Pallier
227 7 Etienne Pallier
---
228 3 Etienne Pallier
229 65 Etienne Pallier
h3. Activate the python virtual environment (from inside the project)
230 7 Etienne Pallier
231 55 Etienne Pallier
<pre>
232 1 Etienne Pallier
233 65 Etienne Pallier
$ pwd
234 134 Etienne Pallier
.../PYROS/private
235 1 Etienne Pallier
236 65 Etienne Pallier
$ source ./venv_py35_pyros/bin/activate
237 65 Etienne Pallier
238 3 Etienne Pallier
$ python -V
239 1 Etienne Pallier
Python 3.5.1
240 3 Etienne Pallier
241 3 Etienne Pallier
$ which pip
242 77 Etienne Pallier
.../PYROS/venv_py35_pyros/bin/pip
243 16 Etienne Pallier
244 18 Etienne Pallier
Upgrade pip to last version available :
245 3 Etienne Pallier
$ pip install --upgrade pip
246 3 Etienne Pallier
Collecting pip
247 3 Etienne Pallier
  Downloading pip-8.1.1-py2.py3-none-any.whl (1.2MB)
248 3 Etienne Pallier
Installing collected packages: pip
249 3 Etienne Pallier
  Found existing installation: pip 7.1.2
250 3 Etienne Pallier
    Uninstalling pip-7.1.2:
251 3 Etienne Pallier
      Successfully uninstalled pip-7.1.2
252 1 Etienne Pallier
Successfully installed pip-8.1.1
253 55 Etienne Pallier
254 55 Etienne Pallier
</pre>
255 18 Etienne Pallier
256 27 Etienne Pallier
h3. Install needed python packages (from within the virtual environment)
257 18 Etienne Pallier
258 66 Etienne Pallier
First, be sure that the virtual environment is activated:
259 66 Etienne Pallier
<pre>
260 66 Etienne Pallier
$ python -V
261 66 Etienne Pallier
Python 3.5.1
262 66 Etienne Pallier
</pre>
263 66 Etienne Pallier
264 62 Etienne Pallier
 * *Automatic Installation of all packages*
265 62 Etienne Pallier
<pre>
266 90 Etienne Pallier
$ pip install -r REQUIREMENTS.txt
267 62 Etienne Pallier
</pre>
268 62 Etienne Pallier
269 93 Etienne Pallier
 * *Or, manual installation of each package*
270 62 Etienne Pallier
271 62 Etienne Pallier
  * *Install Django* :
272 32 Etienne Pallier
<pre>
273 3 Etienne Pallier
$ pip install django
274 3 Etienne Pallier
Collecting django
275 3 Etienne Pallier
  Downloading Django-1.9.4-py2.py3-none-any.whl (6.6MB)
276 3 Etienne Pallier
Installing collected packages: django
277 3 Etienne Pallier
Successfully installed django-1.9.4
278 3 Etienne Pallier
279 3 Etienne Pallier
$ pip install django-admin-tools
280 3 Etienne Pallier
Collecting django-admin-tools
281 3 Etienne Pallier
  Downloading django_admin_tools-0.7.2-py2.py3-none-any.whl (289kB)
282 3 Etienne Pallier
Installing collected packages: django-admin-tools
283 3 Etienne Pallier
Successfully installed django-admin-tools-0.7.2
284 3 Etienne Pallier
285 21 Etienne Pallier
$ pip install django-debug-toolbar
286 21 Etienne Pallier
Collecting django-debug-toolbar
287 21 Etienne Pallier
  Downloading django_debug_toolbar-1.4-py2.py3-none-any.whl (212kB)
288 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)
289 21 Etienne Pallier
Collecting sqlparse (from django-debug-toolbar)
290 21 Etienne Pallier
  Downloading sqlparse-0.1.19.tar.gz (58kB)
291 21 Etienne Pallier
Building wheels for collected packages: sqlparse
292 21 Etienne Pallier
  Running setup.py bdist_wheel for sqlparse ... done
293 21 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/7b/d4/72/6011bb100dd5fc213164e4bbee13d4e03261dd54ce6a5de6b8
294 21 Etienne Pallier
Successfully built sqlparse
295 21 Etienne Pallier
Installing collected packages: sqlparse, django-debug-toolbar
296 21 Etienne Pallier
Successfully installed django-debug-toolbar-1.4 sqlparse-0.1.19
297 21 Etienne Pallier
298 21 Etienne Pallier
$ pip install django-extensions
299 21 Etienne Pallier
Collecting django-extensions
300 21 Etienne Pallier
  Downloading django_extensions-1.6.1-py2.py3-none-any.whl (202kB)
301 21 Etienne Pallier
Collecting six>=1.2 (from django-extensions)
302 21 Etienne Pallier
  Downloading six-1.10.0-py2.py3-none-any.whl
303 21 Etienne Pallier
Installing collected packages: six, django-extensions
304 21 Etienne Pallier
Successfully installed django-extensions-1.6.1 six-1.10.0
305 21 Etienne Pallier
306 21 Etienne Pallier
$ pip install django-suit
307 21 Etienne Pallier
Collecting django-suit
308 21 Etienne Pallier
  Downloading django-suit-0.2.18.tar.gz (587kB)
309 21 Etienne Pallier
Building wheels for collected packages: django-suit
310 1 Etienne Pallier
  Running setup.py bdist_wheel for django-suit ... done
311 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/12/8b/9a/e02ab0ad9229881638aa040d47d77c8f562999533811927d41
312 1 Etienne Pallier
Successfully built django-suit
313 1 Etienne Pallier
Installing collected packages: django-suit
314 1 Etienne Pallier
Successfully installed django-suit-0.2.18
315 21 Etienne Pallier
316 32 Etienne Pallier
</pre>
317 32 Etienne Pallier
318 63 Etienne Pallier
  * *Install the web application server gunicorn (will be used in production instead of the dev django web server)* :
319 32 Etienne Pallier
<pre>
320 25 Etienne Pallier
$ pip install gunicorn
321 25 Etienne Pallier
Collecting gunicorn
322 25 Etienne Pallier
  Downloading gunicorn-19.4.5-py2.py3-none-any.whl (112kB)
323 21 Etienne Pallier
Installing collected packages: gunicorn
324 26 Etienne Pallier
Successfully installed gunicorn-19.4.5
325 1 Etienne Pallier
</pre>
326 1 Etienne Pallier
327 63 Etienne Pallier
  * *Install the python mysql client*:
328 32 Etienne Pallier
<pre>
329 32 Etienne Pallier
$ pip install mysqlclient
330 72 Etienne Pallier
...
331 72 Etienne Pallier
</pre>
332 33 Etienne Pallier
333 73 Etienne Pallier
   * => Issue under Mac OS X:
334 72 Etienne Pallier
<pre>
335 3 Etienne Pallier
$ pip install mysqlclient
336 3 Etienne Pallier
Collecting mysqlclient
337 1 Etienne Pallier
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
338 22 Etienne Pallier
Building wheels for collected packages: mysqlclient
339 3 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... error
340 3 Etienne Pallier
341 1 Etienne Pallier
  ----------------------------------------
342 1 Etienne Pallier
  Failed building wheel for mysqlclient
343 1 Etienne Pallier
  Running setup.py clean for mysqlclient
344 1 Etienne Pallier
Failed to build mysqlclient
345 1 Etienne Pallier
Installing collected packages: mysqlclient
346 1 Etienne Pallier
  Running setup.py install for mysqlclient ... done
347 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
348 1 Etienne Pallier
349 1 Etienne Pallier
BOUH !!!
350 1 Etienne Pallier
351 1 Etienne Pallier
$ pip install --upgrade wheel
352 1 Etienne Pallier
Collecting wheel
353 1 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
354 1 Etienne Pallier
Installing collected packages: wheel
355 1 Etienne Pallier
  Found existing installation: wheel 0.24.0
356 1 Etienne Pallier
    Uninstalling wheel-0.24.0:
357 1 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
358 1 Etienne Pallier
Successfully installed wheel-0.29.0
359 1 Etienne Pallier
360 1 Etienne Pallier
$ pip uninstall mysqlclient
361 1 Etienne Pallier
362 1 Etienne Pallier
$ pip install mysqlclient
363 1 Etienne Pallier
Collecting mysqlclient
364 1 Etienne Pallier
  Using cached mysqlclient-1.3.7.tar.gz
365 1 Etienne Pallier
Building wheels for collected packages: mysqlclient
366 1 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... done
367 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/9b/06/50/d11418c26cf8f2156b13d4363b5afde8e7e75ebb8540d0228d
368 1 Etienne Pallier
Successfully built mysqlclient
369 1 Etienne Pallier
Installing collected packages: mysqlclient
370 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
371 1 Etienne Pallier
372 1 Etienne Pallier
YES !!!
373 1 Etienne Pallier
374 1 Etienne Pallier
</pre>
375 1 Etienne Pallier
376 107 Paul Carensac
   * => Issues under Ubuntu:
377 107 Paul Carensac
<pre>
378 107 Paul Carensac
$ pip install mysqlclient
379 107 Paul Carensac
Collecting mysqlclient
380 107 Paul Carensac
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
381 107 Paul Carensac
    100% |████████████████████████████████| 81kB 1.5MB/s
382 107 Paul Carensac
    Complete output from command python setup.py egg_info:
383 107 Paul Carensac
    /bin/sh: 1: mysql_config: not found
384 107 Paul Carensac
    Traceback (most recent call last):
385 107 Paul Carensac
      File "<string>", line 1, in <module>
386 107 Paul Carensac
    [...]
387 107 Paul Carensac
    ----------------------------------------
388 107 Paul Carensac
Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-q6j4inuz/mysqlclient/
389 1 Etienne Pallier
390 108 Paul Carensac
BOUH !!!
391 108 Paul Carensac
392 107 Paul Carensac
$ sudo apt-get install libmysqlclient-dev
393 108 Paul Carensac
394 107 Paul Carensac
$ pip install mysqlclient
395 107 Paul Carensac
Collecting mysqlclient
396 107 Paul Carensac
  Using cached mysqlclient-1.3.7.tar.gz
397 107 Paul Carensac
Building wheels for collected packages: mysqlclient
398 107 Paul Carensac
  Running setup.py bdist_wheel for mysqlclient ... error
399 107 Paul Carensac
400 107 Paul Carensac
    _mysql.c:40:20: fatal error: Python.h: No such file or directory
401 107 Paul Carensac
     #include "Python.h"
402 107 Paul Carensac
                        ^
403 107 Paul Carensac
    compilation terminated.
404 107 Paul Carensac
    error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
405 107 Paul Carensac
    
406 107 Paul Carensac
    ----------------------------------------
407 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/
408 107 Paul Carensac
409 108 Paul Carensac
BOUH !!!
410 108 Paul Carensac
411 107 Paul Carensac
$ sudo apt-get install python3.5-dev
412 108 Paul Carensac
413 107 Paul Carensac
$ pip install mysqlclient
414 107 Paul Carensac
415 107 Paul Carensac
YES !!!
416 107 Paul Carensac
417 107 Paul Carensac
</pre>
418 12 Etienne Pallier
419 82 Etienne Pallier
 * *Set Requirements*
420 82 Etienne Pallier
421 82 Etienne Pallier
<pre>
422 82 Etienne Pallier
$ pip freeze > REQUIREMENTS.txt
423 136 Etienne Pallier
424 136 Etienne Pallier
$ mv REQUIREMENTS.txt .../PYROS/private/
425 136 Etienne Pallier
426 82 Etienne Pallier
</pre>
427 12 Etienne Pallier
428 12 Etienne Pallier
---
429 28 Etienne Pallier
430 7 Etienne Pallier
h3. Create Django project pyros
431 38 Etienne Pallier
432 38 Etienne Pallier
<pre>
433 1 Etienne Pallier
434 83 Etienne Pallier
From inside the project:
435 83 Etienne Pallier
$ pwd
436 83 Etienne Pallier
.../PYROS/
437 83 Etienne Pallier
438 1 Etienne Pallier
$ django-admin startproject pyros
439 1 Etienne Pallier
440 149 Etienne Pallier
Rename the project folder "pyros/" as "src/"
441 149 Etienne Pallier
442 84 Etienne Pallier
$ mv pyros src
443 84 Etienne Pallier
444 86 Etienne Pallier
We have then this architecture:
445 86 Etienne Pallier
446 1 Etienne Pallier
PYROS
447 83 Etienne Pallier
├── private
448 86 Etienne Pallier
│   └── REQUIREMENTS.txt
449 137 Etienne Pallier
│   └── venv_py35_pyros
450 83 Etienne Pallier
├── public
451 83 Etienne Pallier
│   └── static
452 83 Etienne Pallier
├── src
453 83 Etienne Pallier
│   ├── manage.py
454 1 Etienne Pallier
│   ├── pyros
455 84 Etienne Pallier
│   │   ├── __init__.py
456 84 Etienne Pallier
│   │   ├── settings.py
457 84 Etienne Pallier
│   │   ├── urls.py
458 1 Etienne Pallier
│   │   └── wsgi.py
459 137 Etienne Pallier
460 142 Etienne Pallier
</pre>
461 3 Etienne Pallier
462 3 Etienne Pallier
463 1 Etienne Pallier
464 142 Etienne Pallier
465 142 Etienne Pallier
---
466 142 Etienne Pallier
467 142 Etienne Pallier
h3. Test the project
468 142 Etienne Pallier
469 142 Etienne Pallier
<pre>
470 142 Etienne Pallier
471 150 Etienne Pallier
$ cd src/
472 150 Etienne Pallier
473 1 Etienne Pallier
$ ./manage.py runserver
474 38 Etienne Pallier
(or gunicorn pyros.wsgi)
475 3 Etienne Pallier
==> http://localhost:8000
476 87 Etienne Pallier
...
477 87 Etienne Pallier
...
478 87 Etienne Pallier
Ctrl-c
479 87 Etienne Pallier
480 1 Etienne Pallier
</pre>
481 142 Etienne Pallier
482 142 Etienne Pallier
483 142 Etienne Pallier
484 142 Etienne Pallier
---
485 142 Etienne Pallier
486 142 Etienne Pallier
h3. The Web server
487 142 Etienne Pallier
488 142 Etienne Pallier
489 142 Etienne Pallier
Apache : gère tous les fichiers statiques (images, html…), et délègue les fichiers python au serveur django (par défaut)
490 142 Etienne Pallier
491 143 Etienne Pallier
Le fichier pyros/urls.py prend le relai pour tout ce qui est django
492 143 Etienne Pallier
493 142 Etienne Pallier
Le moteur web django sera soit du wsgi soit du unicorn
494 142 Etienne Pallier
495 142 Etienne Pallier
Par défaut, 1 seul worker, mais on peut en configurer plusieurs, l’idéal étant de faire "nb coeurs + 1" 
496 142 Etienne Pallier
(le worker maître qui fait le dispatching aux autres)
497 142 Etienne Pallier
498 142 Etienne Pallier
Frontend : Apache ou Ngininx
499 142 Etienne Pallier
500 142 Etienne Pallier
Backend : gunicorn (gère facilement des workers) ou uwsgi
501 142 Etienne Pallier
502 152 Etienne Pallier
<pre>
503 152 Etienne Pallier
$ gunicorn pyros.wsgi
504 1 Etienne Pallier
(à la place de manage runserver => A EVITER EN PROD)
505 152 Etienne Pallier
506 1 Etienne Pallier
Ou encore:
507 1 Etienne Pallier
508 152 Etienne Pallier
$ gunicorn --workers 5 library.wsgi
509 152 Etienne Pallier
</pre>
510 3 Etienne Pallier
511 42 Etienne Pallier
---
512 7 Etienne Pallier
513 3 Etienne Pallier
h3. Set Database engine as MySql
514 3 Etienne Pallier
515 41 Etienne Pallier
Edit src/pyros/settings.py
516 3 Etienne Pallier
517 3 Etienne Pallier
<pre>
518 3 Etienne Pallier
DATABASES = {
519 1 Etienne Pallier
    'default': {
520 3 Etienne Pallier
        'ENGINE': 'django.db.backends.mysql',
521 1 Etienne Pallier
        'NAME': 'pyros',
522 1 Etienne Pallier
        'USER': 'root',
523 1 Etienne Pallier
        'PASSWORD': ''
524 41 Etienne Pallier
    }
525 3 Etienne Pallier
}
526 7 Etienne Pallier
</pre>
527 3 Etienne Pallier
528 43 Etienne Pallier
---
529 7 Etienne Pallier
530 43 Etienne Pallier
h3. Import database into Django (with inspectdb)
531 3 Etienne Pallier
532 101 Etienne Pallier
From src/ :
533 94 Etienne Pallier
534 3 Etienne Pallier
<pre>
535 44 Etienne Pallier
$ ./manage.py inspectdb > models.py
536 94 Etienne Pallier
</pre>
537 44 Etienne Pallier
538 97 Etienne Pallier
Issue on Mac OS X:
539 3 Etienne Pallier
<pre>
540 3 Etienne Pallier
Traceback (most recent call last):
541 3 Etienne Pallier
  File "/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/django/db/backends/mysql/base.py", line 25, in <module>
542 3 Etienne Pallier
    import MySQLdb as Database
543 3 Etienne Pallier
  File "/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/MySQLdb/__init__.py", line 19, in <module>
544 3 Etienne Pallier
    import _mysql
545 3 Etienne Pallier
ImportError: dlopen(/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so, 2): Library not loaded: libmysqlclient.18.dylib
546 3 Etienne Pallier
  Referenced from: /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
547 3 Etienne Pallier
  Reason: image not found
548 3 Etienne Pallier
549 3 Etienne Pallier
=> BOUH !!!
550 3 Etienne Pallier
551 3 Etienne Pallier
LA SOLUTION EST ICI : http://stackoverflow.com/questions/6383310/python-mysqldb-library-not-loaded-libmysqlclient-18-dylib
552 3 Etienne Pallier
553 124 Etienne Pallier
Il suffit de faire ceci:
554 3 Etienne Pallier
555 124 Etienne Pallier
$ sudo mkdir -p /usr/local/lib   
556 124 Etienne Pallier
$ sudo ln -s /Applications/XAMPP/xamppfiles/lib/libmysql* /usr/local/lib/
557 124 Etienne Pallier
558 124 Etienne Pallier
Mais on peut aussi faire ceci:
559 3 Etienne Pallier
560 123 Etienne Pallier
Okay, so the offending file is /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
561 123 Etienne Pallier
562 123 Etienne Pallier
Next, figure out where _mysql.so thinks it should find libmysqlclient.18.dylib:
563 123 Etienne Pallier
564 1 Etienne Pallier
$ otool -L /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
565 10 Etienne Pallier
/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so:
566 3 Etienne Pallier
	libmysqlclient.18.dylib (compatibility version 18.0.0, current version 18.0.0)
567 3 Etienne Pallier
...
568 3 Etienne Pallier
569 123 Etienne Pallier
So, it's looking for libmysqlclient.18.dylib with no path information, let's fix that:
570 123 Etienne Pallier
571 1 Etienne Pallier
$ locate libmysqlclient.18.dylib
572 1 Etienne Pallier
/Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib
573 1 Etienne Pallier
/Library/SystemMigration/History/Migration-68137DFB-CB6A-4FBB-81E2-11BDB5D01E48/QuarantineRoot/usr/lib/libmysqlclient.18.dylib
574 1 Etienne Pallier
575 10 Etienne Pallier
$ sudo install_name_tool -change libmysqlclient.18.dylib /Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
576 123 Etienne Pallier
577 123 Etienne Pallier
Now _mysql.so knows the full path to the library and everything works, regardless of environment variables.
578 10 Etienne Pallier
579 10 Etienne Pallier
$ otool -L /Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so
580 10 Etienne Pallier
/Users/epallier/Documents/_W_more/PROJECTS/GFT/SOFT/PYROS/pyros/venv_py35_pyros/lib/python3.5/site-packages/_mysql.cpython-35m-darwin.so:
581 3 Etienne Pallier
	/Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib (compatibility version 18.0.0, current version 18.0.0)
582 1 Etienne Pallier
...
583 1 Etienne Pallier
584 3 Etienne Pallier
$ ./manage.py inspectdb > models.py
585 44 Etienne Pallier
586 3 Etienne Pallier
=> YES !!!
587 3 Etienne Pallier
</pre>
588 7 Etienne Pallier
589 3 Etienne Pallier
590 48 Etienne Pallier
---
591 7 Etienne Pallier
592 3 Etienne Pallier
h3. Create a Django application pyrosapp
593 3 Etienne Pallier
594 102 Etienne Pallier
From src/ :
595 98 Etienne Pallier
596 102 Etienne Pallier
<pre>
597 1 Etienne Pallier
$ ./manage.py startapp pyrosapp
598 1 Etienne Pallier
</pre>
599 1 Etienne Pallier
600 103 Etienne Pallier
We obtain this structure:
601 103 Etienne Pallier
602 104 Etienne Pallier
<pre>
603 103 Etienne Pallier
604 103 Etienne Pallier
PYROS/
605 153 Etienne Pallier
├── private/
606 1 Etienne Pallier
│   └── REQUIREMENTS.txt
607 153 Etienne Pallier
│   └── venv_py35_pyros/
608 153 Etienne Pallier
├── public/
609 153 Etienne Pallier
│   └── static/
610 153 Etienne Pallier
├── src/
611 103 Etienne Pallier
│   ├── db.sqlite3
612 103 Etienne Pallier
│   ├── manage.py
613 153 Etienne Pallier
│   ├── pyros/
614 103 Etienne Pallier
│   │   ├── __init__.py
615 103 Etienne Pallier
│   │   ├── __pycache__
616 103 Etienne Pallier
│   │   ├── settings.py
617 103 Etienne Pallier
│   │   ├── urls.py
618 103 Etienne Pallier
│   │   └── wsgi.py
619 153 Etienne Pallier
│   └── pyrosapp/
620 1 Etienne Pallier
│       ├── __init__.py
621 103 Etienne Pallier
│       ├── admin.py
622 103 Etienne Pallier
│       ├── apps.py
623 103 Etienne Pallier
│       ├── migrations
624 103 Etienne Pallier
│       ├── models.py
625 103 Etienne Pallier
│       ├── tests.py
626 103 Etienne Pallier
│       └── views.py
627 153 Etienne Pallier
628 103 Etienne Pallier
629 7 Etienne Pallier
</pre>
630 1 Etienne Pallier
631 7 Etienne Pallier
---
632 7 Etienne Pallier
633 3 Etienne Pallier
h3. Replace the default pyrosapp models.py with the inspectdb generated one
634 3 Etienne Pallier
635 105 Etienne Pallier
From src/ :
636 1 Etienne Pallier
637 105 Etienne Pallier
<pre>
638 105 Etienne Pallier
$ mv models.py pyrosapp/
639 105 Etienne Pallier
</pre>
640 3 Etienne Pallier
641 139 Paul Carensac
Add pyrosapp to the project's applications :
642 7 Etienne Pallier
643 139 Paul Carensac
Edit src/pyros/settings.py
644 1 Etienne Pallier
645 139 Paul Carensac
<pre>
646 139 Paul Carensac
INSTALLED_APPS = [
647 139 Paul Carensac
    'django.contrib.admin',
648 139 Paul Carensac
    'django.contrib.auth',
649 139 Paul Carensac
    'django.contrib.contenttypes',
650 139 Paul Carensac
    'django.contrib.sessions',
651 139 Paul Carensac
    'django.contrib.messages',
652 139 Paul Carensac
    'django.contrib.staticfiles',
653 139 Paul Carensac
    'pyrosapp',
654 139 Paul Carensac
]
655 139 Paul Carensac
</pre>
656 9 Etienne Pallier
657 47 Etienne Pallier
---
658 3 Etienne Pallier
659 145 Paul Carensac
h3. Fix and improve the pyrosapp models.py file (generated by inspectdb)
660 1 Etienne Pallier
661 145 Paul Carensac
Once models.py file generated, we need to delete the database and create an empty one :
662 145 Paul Carensac
 
663 145 Paul Carensac
<pre>
664 145 Paul Carensac
$ mysql -u root [-p (if password needed)]
665 106 Etienne Pallier
666 145 Paul Carensac
mysql> DROP DATABSE pyros
667 145 Paul Carensac
mysql> CREATE SCHEMA IF NOT EXISTS 'pyros' DEFAULT CHARACTER SET utf8;
668 1 Etienne Pallier
669 145 Paul Carensac
</pre>
670 1 Etienne Pallier
671 145 Paul Carensac
Then edit pyrosapp/models.py :
672 1 Etienne Pallier
673 145 Paul Carensac
 * Change 'managed = False' to 'managed = True' for every model
674 145 Paul Carensac
675 145 Paul Carensac
 * Change classes names to CamelCase (do not change the 'db_table = ...' lines). *Be careful* : it is needed to change all occurences :
676 145 Paul Carensac
677 145 Paul Carensac
    * NrtAlanysis
678 145 Paul Carensac
    * ScheduleHistory
679 145 Paul Carensac
    * ScientificProgram
680 145 Paul Carensac
    * SequenceType
681 145 Paul Carensac
    * SiteWatch
682 145 Paul Carensac
    * SiteWatchHistory
683 145 Paul Carensac
    * StrategyObs
684 154 Paul Carensac
    * UserLevel
685 145 Paul Carensac
    * WeatherWatch
686 145 Paul Carensac
    * WeatherWatchHistory
687 145 Paul Carensac
688 145 Paul Carensac
 * Change the deleting mode from 'models.DO_NOTHING' to 'models.CASCADE' for the following foreign keys :
689 145 Paul Carensac
690 145 Paul Carensac
    * Image.plan
691 145 Paul Carensac
    * Plan.album
692 145 Paul Carensac
    * Album.sequence
693 145 Paul Carensac
    * Sequence.request
694 145 Paul Carensac
695 145 Paul Carensac
 * Change the 'ForeignKey' liaisons to 'OneToOneField' liaisons (just replace ForeignKey by OneToOneField), and change deleting mode to 'models.CASCADE' for the following foreign keys :
696 145 Paul Carensac
697 145 Paul Carensac
    * Alert.request
698 145 Paul Carensac
    * Detector.device
699 145 Paul Carensac
    * Filter.device
700 145 Paul Carensac
    * Telescope.device
701 145 Paul Carensac
702 145 Paul Carensac
 * We need to redefine many to many relationships for the following classes :
703 145 Paul Carensac
704 145 Paul Carensac
    * User - ScientificProgram :
705 145 Paul Carensac
706 145 Paul Carensac
        * add 'users = models.ManyToManyField('User')' in ScientificProgram class
707 145 Paul Carensac
        * delete UserHasScientificProgram class
708 145 Paul Carensac
709 145 Paul Carensac
    * Sequence - ScheduleHistory
710 145 Paul Carensac
711 145 Paul Carensac
        * add 'sequences = models.ManyToManyField('Sequence')' in ScheduleHistory class
712 145 Paul Carensac
        * delete ScheduleHasSequences class
713 145 Paul Carensac
714 145 Paul Carensac
 * Finally apply modifications to the database :
715 145 Paul Carensac
716 145 Paul Carensac
<pre>
717 145 Paul Carensac
$ pwd
718 145 Paul Carensac
.../PYROS/src
719 145 Paul Carensac
$ python manage.py makemigrations pyrosapp
720 145 Paul Carensac
$ python manage.py migrate
721 145 Paul Carensac
</pre>
722 109 Etienne Pallier
723 109 Etienne Pallier
---
724 111 Etienne Pallier
725 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)%
726 155 Paul Carensac
727 155 Paul Carensac
---
728 155 Paul Carensac
729 155 Paul Carensac
h3. Back Office setup
730 155 Paul Carensac
731 155 Paul Carensac
 * Prerequisites in src/pyros/settings.py :
732 155 Paul Carensac
733 155 Paul Carensac
    * INSTALLED_APPS must (at least) contain :
734 155 Paul Carensac
735 155 Paul Carensac
        * django.contrib.admin
736 155 Paul Carensac
        * django.contrib.auth
737 155 Paul Carensac
        * django.contrib.contenttypes
738 155 Paul Carensac
        * django.contrib.sessions
739 155 Paul Carensac
740 155 Paul Carensac
    * MIDDLEWARES must (at least) contain :
741 155 Paul Carensac
742 155 Paul Carensac
        * django.contrib.sessions.middleware.SessionMiddleware
743 155 Paul Carensac
        * django.middleware.common.CommonMiddleware
744 155 Paul Carensac
        * django.contrib.auth.middleware.AuthenticationMiddleware
745 155 Paul Carensac
746 155 Paul Carensac
 * At least one 'python manage.py migrate' must have been executed
747 155 Paul Carensac
748 155 Paul Carensac
 * Create a superuser for the administration :
749 155 Paul Carensac
750 155 Paul Carensac
<pre>
751 155 Paul Carensac
$ python manage.py createsuperuser
752 155 Paul Carensac
</pre>
753 155 Paul Carensac
754 156 Paul Carensac
* For each app of the project, fill the admin.py file :
755 155 Paul Carensac
756 155 Paul Carensac
<pre>
757 155 Paul Carensac
from django.contrib import admin
758 155 Paul Carensac
from app.models import Model1, Model2
759 155 Paul Carensac
760 155 Paul Carensac
admin.site.register(Model1)
761 155 Paul Carensac
admin.site.register(Model2)
762 155 Paul Carensac
</pre>
763 155 Paul Carensac
764 155 Paul Carensac
*Reminder* : each application must be registered in the settings.py INSTALLED_APPS variable.
765 157 Paul Carensac
766 157 Paul Carensac
* For each model in models.py, add a __str__() method in order to identify the object on the back office. Example :
767 157 Paul Carensac
768 157 Paul Carensac
<pre>
769 157 Paul Carensac
class UserLevel(models.Model):
770 157 Paul Carensac
    name = models.CharField(max_length=45, blank=True, null=True)
771 157 Paul Carensac
    desc = models.TextField(blank=True, null=True)
772 157 Paul Carensac
    priority = models.IntegerField(blank=True, null=True)
773 157 Paul Carensac
    quota = models.FloatField(blank=True, null=True)
774 157 Paul Carensac
775 157 Paul Carensac
    class Meta:
776 157 Paul Carensac
        managed = True
777 157 Paul Carensac
        db_table = 'userlevel'
778 157 Paul Carensac
779 157 Paul Carensac
    def __str__(self):
780 157 Paul Carensac
        return (self.name)
781 157 Paul Carensac
</pre>
782 157 Paul Carensac
783 159 Paul Carensac
*Naming convention* : Use self.name when possible, the creation time/date otherwise. Example :
784 159 Paul Carensac
785 159 Paul Carensac
<pre>
786 159 Paul Carensac
class SiteWatch(models.Model):
787 159 Paul Carensac
    updated = models.DateTimeField(blank=True, null=True)
788 159 Paul Carensac
    lights = models.CharField(max_length=45, blank=True, null=True)
789 159 Paul Carensac
    dome = models.CharField(max_length=45, blank=True, null=True)
790 159 Paul Carensac
    doors = models.CharField(max_length=45, blank=True, null=True)
791 159 Paul Carensac
    temperature = models.FloatField(blank=True, null=True)
792 159 Paul Carensac
793 159 Paul Carensac
    class Meta:
794 159 Paul Carensac
        managed = True
795 159 Paul Carensac
        db_table = 'sitewatch'
796 159 Paul Carensac
797 159 Paul Carensac
    def __str__(self):
798 160 Paul Carensac
        return (str(self.updated))
799 159 Paul Carensac
</pre>