Wiki

Version 175 (Etienne Pallier, 03/22/2016 10:04 am)

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