Wiki

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