Wiki

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