Wiki

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