Wiki

Version 127 (Etienne Pallier, 03/21/2016 11:27 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 117 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - DATABASE SCHEMA%
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 118 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}II - INSTALLATION%
35 2 Etienne Pallier
36 120 Etienne Pallier
37 120 Etienne Pallier
---
38 120 Etienne Pallier
39 51 Etienne Pallier
h3. If necessary, install MySql
40 2 Etienne Pallier
41 49 Etienne Pallier
 * Linux Ubuntu
42 49 Etienne Pallier
<pre>
43 107 Paul Carensac
44 107 Paul Carensac
$ sudo apt-get install mysql-server
45 107 Paul Carensac
$ sudo apt-get install mysql-client
46 107 Paul Carensac
47 49 Etienne Pallier
</pre>
48 49 Etienne Pallier
49 49 Etienne Pallier
 * Linux CentOS
50 49 Etienne Pallier
<pre>
51 49 Etienne Pallier
TODO:
52 49 Etienne Pallier
$ sudo yum install mysql
53 49 Etienne Pallier
...
54 49 Etienne Pallier
</pre>
55 49 Etienne Pallier
56 49 Etienne Pallier
 * Mac OS X
57 49 Etienne Pallier
<pre>
58 49 Etienne Pallier
TODO:
59 49 Etienne Pallier
Install XAMPP
60 49 Etienne Pallier
(but you could also use the pre-installed Mac OS MySql)
61 49 Etienne Pallier
</pre>
62 49 Etienne Pallier
63 49 Etienne Pallier
 * Windows
64 49 Etienne Pallier
<pre>
65 49 Etienne Pallier
TODO:
66 49 Etienne Pallier
</pre>
67 49 Etienne Pallier
68 49 Etienne Pallier
69 49 Etienne Pallier
---
70 1 Etienne Pallier
71 6 Etienne Pallier
h3. Create database
72 1 Etienne Pallier
73 52 Etienne Pallier
74 52 Etienne Pallier
 * Linux and Mac OS X:
75 52 Etienne Pallier
<pre>
76 3 Etienne Pallier
One liner:
77 115 Etienne Pallier
$ mysql -u root < pyros_create.sql
78 1 Etienne Pallier
79 3 Etienne Pallier
Or :
80 3 Etienne Pallier
$ mysql -u root
81 3 Etienne Pallier
mysql> create database pyros;
82 3 Etienne Pallier
mysql> use pyros;
83 115 Etienne Pallier
mysql> source pyros_create.sql;
84 1 Etienne Pallier
85 3 Etienne Pallier
(
86 3 Etienne Pallier
TODO:
87 3 Etienne Pallier
mysql> grant all on pyros.* to pyros@localhost identified by ‘pyros’;)
88 3 Etienne Pallier
mysql> flush privileges;
89 3 Etienne Pallier
)
90 52 Etienne Pallier
</pre>
91 1 Etienne Pallier
92 53 Etienne Pallier
93 53 Etienne Pallier
 * Windows:
94 52 Etienne Pallier
<pre>
95 52 Etienne Pallier
TODO: Use phpmyadmin ?
96 52 Etienne Pallier
</pre>
97 1 Etienne Pallier
98 1 Etienne Pallier
99 4 Etienne Pallier
---
100 5 Etienne Pallier
101 6 Etienne Pallier
h3. Install python3.5
102 1 Etienne Pallier
103 11 Etienne Pallier
104 11 Etienne Pallier
 * Mac OS X :
105 23 Etienne Pallier
<pre>
106 24 Etienne Pallier
1) Installer MacPort
107 24 Etienne Pallier
(TODO: doc)
108 24 Etienne Pallier
109 24 Etienne Pallier
2) Installer le "port" python35
110 1 Etienne Pallier
$ sudo port install python35
111 1 Etienne Pallier
</pre>
112 1 Etienne Pallier
113 1 Etienne Pallier
 * Linux (Ubuntu) :
114 1 Etienne Pallier
<pre>
115 107 Paul Carensac
sudo add-apt-repository ppa:fkrull/deadsnakes
116 107 Paul Carensac
sudo apt-get update
117 107 Paul Carensac
sudo apt-get install python3.5
118 107 Paul Carensac
119 107 Paul Carensac
sudo pip install virtualenv
120 23 Etienne Pallier
</pre>
121 1 Etienne Pallier
122 5 Etienne Pallier
123 3 Etienne Pallier
124 4 Etienne Pallier
---
125 5 Etienne Pallier
126 13 Etienne Pallier
h3. Create project dir
127 13 Etienne Pallier
128 68 Etienne Pallier
<pre>
129 74 Etienne Pallier
$ mkdir PYROS
130 68 Etienne Pallier
</pre>
131 13 Etienne Pallier
132 13 Etienne Pallier
---
133 59 Etienne Pallier
134 59 Etienne Pallier
h3. Get the project (from git)
135 59 Etienne Pallier
136 78 Etienne Pallier
<pre>
137 59 Etienne Pallier
TODO:
138 79 Etienne Pallier
139 80 Etienne Pallier
$ git ...
140 78 Etienne Pallier
</pre>
141 78 Etienne Pallier
142 59 Etienne Pallier
143 59 Etienne Pallier
144 59 Etienne Pallier
---
145 59 Etienne Pallier
146 60 Etienne Pallier
h3. Create virtualenv with python3.5 dedicated to pyros project (inside the project folder)
147 3 Etienne Pallier
148 127 Etienne Pallier
$ cd PYROS/private/
149 3 Etienne Pallier
150 3 Etienne Pallier
$ which python3.5
151 3 Etienne Pallier
/opt/local/bin/python3.5
152 3 Etienne Pallier
153 15 Etienne Pallier
$ virtualenv-3.5 venv_py35_pyros -p /opt/local/bin/python3.5
154 127 Etienne Pallier
=> creates a venv_py35_pyros/ folder inside PYROS/private/
155 3 Etienne Pallier
156 1 Etienne Pallier
157 1 Etienne Pallier
158 7 Etienne Pallier
---
159 3 Etienne Pallier
160 65 Etienne Pallier
h3. Activate the python virtual environment (from inside the project)
161 7 Etienne Pallier
162 55 Etienne Pallier
<pre>
163 1 Etienne Pallier
164 65 Etienne Pallier
$ pwd
165 76 Etienne Pallier
.../PYROS
166 1 Etienne Pallier
167 65 Etienne Pallier
$ source ./venv_py35_pyros/bin/activate
168 65 Etienne Pallier
169 3 Etienne Pallier
$ python -V
170 1 Etienne Pallier
Python 3.5.1
171 3 Etienne Pallier
172 3 Etienne Pallier
$ which pip
173 77 Etienne Pallier
.../PYROS/venv_py35_pyros/bin/pip
174 16 Etienne Pallier
175 18 Etienne Pallier
Upgrade pip to last version available :
176 3 Etienne Pallier
$ pip install --upgrade pip
177 3 Etienne Pallier
Collecting pip
178 3 Etienne Pallier
  Downloading pip-8.1.1-py2.py3-none-any.whl (1.2MB)
179 3 Etienne Pallier
Installing collected packages: pip
180 3 Etienne Pallier
  Found existing installation: pip 7.1.2
181 3 Etienne Pallier
    Uninstalling pip-7.1.2:
182 3 Etienne Pallier
      Successfully uninstalled pip-7.1.2
183 1 Etienne Pallier
Successfully installed pip-8.1.1
184 55 Etienne Pallier
185 55 Etienne Pallier
</pre>
186 18 Etienne Pallier
187 27 Etienne Pallier
h3. Install needed python packages (from within the virtual environment)
188 18 Etienne Pallier
189 66 Etienne Pallier
First, be sure that the virtual environment is activated:
190 66 Etienne Pallier
<pre>
191 66 Etienne Pallier
$ python -V
192 66 Etienne Pallier
Python 3.5.1
193 66 Etienne Pallier
</pre>
194 66 Etienne Pallier
195 62 Etienne Pallier
 * *Automatic Installation of all packages*
196 62 Etienne Pallier
<pre>
197 90 Etienne Pallier
$ pip install -r REQUIREMENTS.txt
198 62 Etienne Pallier
</pre>
199 62 Etienne Pallier
200 93 Etienne Pallier
 * *Or, manual installation of each package*
201 62 Etienne Pallier
202 62 Etienne Pallier
  * *Install Django* :
203 32 Etienne Pallier
<pre>
204 3 Etienne Pallier
$ pip install django
205 3 Etienne Pallier
Collecting django
206 3 Etienne Pallier
  Downloading Django-1.9.4-py2.py3-none-any.whl (6.6MB)
207 3 Etienne Pallier
Installing collected packages: django
208 3 Etienne Pallier
Successfully installed django-1.9.4
209 3 Etienne Pallier
210 3 Etienne Pallier
$ pip install django-admin-tools
211 3 Etienne Pallier
Collecting django-admin-tools
212 3 Etienne Pallier
  Downloading django_admin_tools-0.7.2-py2.py3-none-any.whl (289kB)
213 3 Etienne Pallier
Installing collected packages: django-admin-tools
214 3 Etienne Pallier
Successfully installed django-admin-tools-0.7.2
215 3 Etienne Pallier
216 21 Etienne Pallier
$ pip install django-debug-toolbar
217 21 Etienne Pallier
Collecting django-debug-toolbar
218 21 Etienne Pallier
  Downloading django_debug_toolbar-1.4-py2.py3-none-any.whl (212kB)
219 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)
220 21 Etienne Pallier
Collecting sqlparse (from django-debug-toolbar)
221 21 Etienne Pallier
  Downloading sqlparse-0.1.19.tar.gz (58kB)
222 21 Etienne Pallier
Building wheels for collected packages: sqlparse
223 21 Etienne Pallier
  Running setup.py bdist_wheel for sqlparse ... done
224 21 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/7b/d4/72/6011bb100dd5fc213164e4bbee13d4e03261dd54ce6a5de6b8
225 21 Etienne Pallier
Successfully built sqlparse
226 21 Etienne Pallier
Installing collected packages: sqlparse, django-debug-toolbar
227 21 Etienne Pallier
Successfully installed django-debug-toolbar-1.4 sqlparse-0.1.19
228 21 Etienne Pallier
229 21 Etienne Pallier
$ pip install django-extensions
230 21 Etienne Pallier
Collecting django-extensions
231 21 Etienne Pallier
  Downloading django_extensions-1.6.1-py2.py3-none-any.whl (202kB)
232 21 Etienne Pallier
Collecting six>=1.2 (from django-extensions)
233 21 Etienne Pallier
  Downloading six-1.10.0-py2.py3-none-any.whl
234 21 Etienne Pallier
Installing collected packages: six, django-extensions
235 21 Etienne Pallier
Successfully installed django-extensions-1.6.1 six-1.10.0
236 21 Etienne Pallier
237 21 Etienne Pallier
$ pip install django-suit
238 21 Etienne Pallier
Collecting django-suit
239 21 Etienne Pallier
  Downloading django-suit-0.2.18.tar.gz (587kB)
240 21 Etienne Pallier
Building wheels for collected packages: django-suit
241 1 Etienne Pallier
  Running setup.py bdist_wheel for django-suit ... done
242 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/12/8b/9a/e02ab0ad9229881638aa040d47d77c8f562999533811927d41
243 1 Etienne Pallier
Successfully built django-suit
244 1 Etienne Pallier
Installing collected packages: django-suit
245 1 Etienne Pallier
Successfully installed django-suit-0.2.18
246 21 Etienne Pallier
247 32 Etienne Pallier
</pre>
248 32 Etienne Pallier
249 63 Etienne Pallier
  * *Install the web application server gunicorn (will be used in production instead of the dev django web server)* :
250 32 Etienne Pallier
<pre>
251 25 Etienne Pallier
$ pip install gunicorn
252 25 Etienne Pallier
Collecting gunicorn
253 25 Etienne Pallier
  Downloading gunicorn-19.4.5-py2.py3-none-any.whl (112kB)
254 21 Etienne Pallier
Installing collected packages: gunicorn
255 26 Etienne Pallier
Successfully installed gunicorn-19.4.5
256 1 Etienne Pallier
</pre>
257 1 Etienne Pallier
258 63 Etienne Pallier
  * *Install the python mysql client*:
259 32 Etienne Pallier
<pre>
260 32 Etienne Pallier
$ pip install mysqlclient
261 72 Etienne Pallier
...
262 72 Etienne Pallier
</pre>
263 33 Etienne Pallier
264 73 Etienne Pallier
   * => Issue under Mac OS X:
265 72 Etienne Pallier
<pre>
266 3 Etienne Pallier
$ pip install mysqlclient
267 3 Etienne Pallier
Collecting mysqlclient
268 1 Etienne Pallier
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
269 22 Etienne Pallier
Building wheels for collected packages: mysqlclient
270 3 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... error
271 3 Etienne Pallier
272 1 Etienne Pallier
  ----------------------------------------
273 1 Etienne Pallier
  Failed building wheel for mysqlclient
274 1 Etienne Pallier
  Running setup.py clean for mysqlclient
275 1 Etienne Pallier
Failed to build mysqlclient
276 1 Etienne Pallier
Installing collected packages: mysqlclient
277 1 Etienne Pallier
  Running setup.py install for mysqlclient ... done
278 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
279 1 Etienne Pallier
280 1 Etienne Pallier
BOUH !!!
281 1 Etienne Pallier
282 1 Etienne Pallier
$ pip install --upgrade wheel
283 1 Etienne Pallier
Collecting wheel
284 1 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
285 1 Etienne Pallier
Installing collected packages: wheel
286 1 Etienne Pallier
  Found existing installation: wheel 0.24.0
287 1 Etienne Pallier
    Uninstalling wheel-0.24.0:
288 1 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
289 1 Etienne Pallier
Successfully installed wheel-0.29.0
290 1 Etienne Pallier
291 1 Etienne Pallier
$ pip uninstall mysqlclient
292 1 Etienne Pallier
293 1 Etienne Pallier
$ pip install mysqlclient
294 1 Etienne Pallier
Collecting mysqlclient
295 1 Etienne Pallier
  Using cached mysqlclient-1.3.7.tar.gz
296 1 Etienne Pallier
Building wheels for collected packages: mysqlclient
297 1 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... done
298 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/9b/06/50/d11418c26cf8f2156b13d4363b5afde8e7e75ebb8540d0228d
299 1 Etienne Pallier
Successfully built mysqlclient
300 1 Etienne Pallier
Installing collected packages: mysqlclient
301 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
302 1 Etienne Pallier
303 1 Etienne Pallier
YES !!!
304 1 Etienne Pallier
305 1 Etienne Pallier
</pre>
306 1 Etienne Pallier
307 107 Paul Carensac
   * => Issues under Ubuntu:
308 107 Paul Carensac
<pre>
309 107 Paul Carensac
$ pip install mysqlclient
310 107 Paul Carensac
Collecting mysqlclient
311 107 Paul Carensac
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
312 107 Paul Carensac
    100% |████████████████████████████████| 81kB 1.5MB/s
313 107 Paul Carensac
    Complete output from command python setup.py egg_info:
314 107 Paul Carensac
    /bin/sh: 1: mysql_config: not found
315 107 Paul Carensac
    Traceback (most recent call last):
316 107 Paul Carensac
      File "<string>", line 1, in <module>
317 107 Paul Carensac
    [...]
318 107 Paul Carensac
    ----------------------------------------
319 107 Paul Carensac
Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-q6j4inuz/mysqlclient/
320 1 Etienne Pallier
321 108 Paul Carensac
BOUH !!!
322 108 Paul Carensac
323 107 Paul Carensac
$ sudo apt-get install libmysqlclient-dev
324 108 Paul Carensac
325 107 Paul Carensac
$ pip install mysqlclient
326 107 Paul Carensac
Collecting mysqlclient
327 107 Paul Carensac
  Using cached mysqlclient-1.3.7.tar.gz
328 107 Paul Carensac
Building wheels for collected packages: mysqlclient
329 107 Paul Carensac
  Running setup.py bdist_wheel for mysqlclient ... error
330 107 Paul Carensac
331 107 Paul Carensac
    _mysql.c:40:20: fatal error: Python.h: No such file or directory
332 107 Paul Carensac
     #include "Python.h"
333 107 Paul Carensac
                        ^
334 107 Paul Carensac
    compilation terminated.
335 107 Paul Carensac
    error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
336 107 Paul Carensac
    
337 107 Paul Carensac
    ----------------------------------------
338 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/
339 107 Paul Carensac
340 108 Paul Carensac
BOUH !!!
341 108 Paul Carensac
342 107 Paul Carensac
$ sudo apt-get install python3.5-dev
343 108 Paul Carensac
344 107 Paul Carensac
$ pip install mysqlclient
345 107 Paul Carensac
346 107 Paul Carensac
YES !!!
347 107 Paul Carensac
348 107 Paul Carensac
</pre>
349 12 Etienne Pallier
350 82 Etienne Pallier
 * *Set Requirements*
351 82 Etienne Pallier
352 82 Etienne Pallier
<pre>
353 82 Etienne Pallier
$ pip freeze > REQUIREMENTS.txt
354 82 Etienne Pallier
</pre>
355 12 Etienne Pallier
356 12 Etienne Pallier
---
357 28 Etienne Pallier
358 12 Etienne Pallier
h3. Project organization
359 29 Etienne Pallier
 
360 1 Etienne Pallier
Example of a good organization :
361 29 Etienne Pallier
362 29 Etienne Pallier
1 project = N applis
363 30 Etienne Pallier
(but 1 appli can be part of many projects)
364 12 Etienne Pallier
(then 1 appli = N models)
365 31 Etienne Pallier
366 34 Etienne Pallier
<pre>
367 29 Etienne Pallier
368 34 Etienne Pallier
MYPROJECT/
369 50 Etienne Pallier
370 1 Etienne Pallier
371 1 Etienne Pallier
	src/
372 34 Etienne Pallier
		myproject/
373 34 Etienne Pallier
		appli1/
374 12 Etienne Pallier
		appli2/
375 34 Etienne Pallier
376 34 Etienne Pallier
		appliN/
377 12 Etienne Pallier
378 34 Etienne Pallier
	public/
379 34 Etienne Pallier
		static/
380 12 Etienne Pallier
381 1 Etienne Pallier
	private/
382 89 Etienne Pallier
		REQUIREMENTS.txt
383 50 Etienne Pallier
384 50 Etienne Pallier
	venv_py35_pyros/
385 1 Etienne Pallier
386 1 Etienne Pallier
</pre>
387 1 Etienne Pallier
388 37 Etienne Pallier
389 37 Etienne Pallier
Set needed folders:
390 37 Etienne Pallier
<pre>
391 81 Etienne Pallier
$ cd PYROS/
392 12 Etienne Pallier
$ mkdir private public
393 37 Etienne Pallier
$ mkdir public/static
394 3 Etienne Pallier
</pre>
395 7 Etienne Pallier
396 3 Etienne Pallier
---
397 39 Etienne Pallier
398 7 Etienne Pallier
h3. Create Django project pyros
399 38 Etienne Pallier
400 38 Etienne Pallier
<pre>
401 1 Etienne Pallier
402 83 Etienne Pallier
From inside the project:
403 83 Etienne Pallier
$ pwd
404 83 Etienne Pallier
.../PYROS/
405 83 Etienne Pallier
406 1 Etienne Pallier
$ django-admin startproject pyros
407 1 Etienne Pallier
408 84 Etienne Pallier
$ mv pyros src
409 84 Etienne Pallier
410 86 Etienne Pallier
$ mv REQUIREMENTS.txt private/
411 1 Etienne Pallier
412 86 Etienne Pallier
We have then this architecture:
413 86 Etienne Pallier
414 1 Etienne Pallier
PYROS
415 83 Etienne Pallier
├── private
416 86 Etienne Pallier
│   └── REQUIREMENTS.txt
417 83 Etienne Pallier
├── public
418 83 Etienne Pallier
│   └── static
419 83 Etienne Pallier
├── src
420 83 Etienne Pallier
│   ├── db.sqlite3
421 83 Etienne Pallier
│   ├── manage.py
422 1 Etienne Pallier
│   ├── pyros
423 84 Etienne Pallier
│   │   ├── __init__.py
424 84 Etienne Pallier
│   │   ├── settings.py
425 84 Etienne Pallier
│   │   ├── urls.py
426 84 Etienne Pallier
│   │   └── wsgi.py
427 85 Etienne Pallier
└── venv_py35_pyros
428 3 Etienne Pallier
429 3 Etienne Pallier
430 3 Etienne Pallier
$ cd src/
431 40 Etienne Pallier
432 1 Etienne Pallier
$ ./manage.py runserver
433 38 Etienne Pallier
(or gunicorn pyros.wsgi)
434 3 Etienne Pallier
==> http://localhost:8000
435 87 Etienne Pallier
...
436 87 Etienne Pallier
...
437 87 Etienne Pallier
Ctrl-c
438 87 Etienne Pallier
439 3 Etienne Pallier
</pre>
440 7 Etienne Pallier
441 3 Etienne Pallier
442 42 Etienne Pallier
---
443 7 Etienne Pallier
444 3 Etienne Pallier
h3. Set Database engine as MySql
445 3 Etienne Pallier
446 41 Etienne Pallier
Edit src/pyros/settings.py
447 3 Etienne Pallier
448 3 Etienne Pallier
<pre>
449 3 Etienne Pallier
DATABASES = {
450 1 Etienne Pallier
    'default': {
451 3 Etienne Pallier
        'ENGINE': 'django.db.backends.mysql',
452 1 Etienne Pallier
        'NAME': 'pyros',
453 1 Etienne Pallier
        'USER': 'root',
454 1 Etienne Pallier
        'PASSWORD': ''
455 41 Etienne Pallier
    }
456 3 Etienne Pallier
}
457 7 Etienne Pallier
</pre>
458 3 Etienne Pallier
459 43 Etienne Pallier
---
460 7 Etienne Pallier
461 43 Etienne Pallier
h3. Import database into Django (with inspectdb)
462 3 Etienne Pallier
463 101 Etienne Pallier
From src/ :
464 94 Etienne Pallier
465 3 Etienne Pallier
<pre>
466 44 Etienne Pallier
$ ./manage.py inspectdb > models.py
467 94 Etienne Pallier
</pre>
468 44 Etienne Pallier
469 97 Etienne Pallier
Issue on Mac OS X:
470 3 Etienne Pallier
<pre>
471 3 Etienne Pallier
Traceback (most recent call last):
472 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>
473 3 Etienne Pallier
    import MySQLdb as Database
474 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>
475 3 Etienne Pallier
    import _mysql
476 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
477 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
478 3 Etienne Pallier
  Reason: image not found
479 3 Etienne Pallier
480 3 Etienne Pallier
=> BOUH !!!
481 3 Etienne Pallier
482 3 Etienne Pallier
LA SOLUTION EST ICI : http://stackoverflow.com/questions/6383310/python-mysqldb-library-not-loaded-libmysqlclient-18-dylib
483 3 Etienne Pallier
484 124 Etienne Pallier
Il suffit de faire ceci:
485 3 Etienne Pallier
486 124 Etienne Pallier
$ sudo mkdir -p /usr/local/lib   
487 124 Etienne Pallier
$ sudo ln -s /Applications/XAMPP/xamppfiles/lib/libmysql* /usr/local/lib/
488 124 Etienne Pallier
489 124 Etienne Pallier
Mais on peut aussi faire ceci:
490 3 Etienne Pallier
491 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
492 123 Etienne Pallier
493 123 Etienne Pallier
Next, figure out where _mysql.so thinks it should find libmysqlclient.18.dylib:
494 123 Etienne Pallier
495 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
496 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:
497 3 Etienne Pallier
	libmysqlclient.18.dylib (compatibility version 18.0.0, current version 18.0.0)
498 3 Etienne Pallier
...
499 3 Etienne Pallier
500 123 Etienne Pallier
So, it's looking for libmysqlclient.18.dylib with no path information, let's fix that:
501 123 Etienne Pallier
502 1 Etienne Pallier
$ locate libmysqlclient.18.dylib
503 1 Etienne Pallier
/Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib
504 1 Etienne Pallier
/Library/SystemMigration/History/Migration-68137DFB-CB6A-4FBB-81E2-11BDB5D01E48/QuarantineRoot/usr/lib/libmysqlclient.18.dylib
505 1 Etienne Pallier
506 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
507 123 Etienne Pallier
508 123 Etienne Pallier
Now _mysql.so knows the full path to the library and everything works, regardless of environment variables.
509 10 Etienne Pallier
510 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
511 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:
512 3 Etienne Pallier
	/Applications/XAMPP/xamppfiles/lib/libmysqlclient.18.dylib (compatibility version 18.0.0, current version 18.0.0)
513 1 Etienne Pallier
...
514 1 Etienne Pallier
515 3 Etienne Pallier
$ ./manage.py inspectdb > models.py
516 44 Etienne Pallier
517 3 Etienne Pallier
=> YES !!!
518 3 Etienne Pallier
</pre>
519 7 Etienne Pallier
520 3 Etienne Pallier
521 48 Etienne Pallier
---
522 7 Etienne Pallier
523 3 Etienne Pallier
h3. Create a Django application pyrosapp
524 3 Etienne Pallier
525 102 Etienne Pallier
From src/ :
526 98 Etienne Pallier
527 102 Etienne Pallier
<pre>
528 1 Etienne Pallier
$ ./manage.py startapp pyrosapp
529 1 Etienne Pallier
</pre>
530 1 Etienne Pallier
531 103 Etienne Pallier
We obtain this structure:
532 103 Etienne Pallier
533 104 Etienne Pallier
<pre>
534 103 Etienne Pallier
535 103 Etienne Pallier
PYROS/
536 103 Etienne Pallier
├── private
537 103 Etienne Pallier
│   └── REQUIREMENTS.txt
538 103 Etienne Pallier
├── public
539 103 Etienne Pallier
│   └── static
540 103 Etienne Pallier
├── src
541 103 Etienne Pallier
│   ├── db.sqlite3
542 103 Etienne Pallier
│   ├── manage.py
543 103 Etienne Pallier
│   ├── pyros
544 103 Etienne Pallier
│   │   ├── __init__.py
545 103 Etienne Pallier
│   │   ├── __pycache__
546 103 Etienne Pallier
│   │   ├── settings.py
547 103 Etienne Pallier
│   │   ├── urls.py
548 103 Etienne Pallier
│   │   └── wsgi.py
549 103 Etienne Pallier
│   └── pyrosapp
550 103 Etienne Pallier
│       ├── __init__.py
551 103 Etienne Pallier
│       ├── admin.py
552 103 Etienne Pallier
│       ├── apps.py
553 103 Etienne Pallier
│       ├── migrations
554 103 Etienne Pallier
│       ├── models.py
555 103 Etienne Pallier
│       ├── tests.py
556 103 Etienne Pallier
│       └── views.py
557 103 Etienne Pallier
└── venv_py35_pyros
558 103 Etienne Pallier
559 7 Etienne Pallier
</pre>
560 1 Etienne Pallier
561 7 Etienne Pallier
---
562 7 Etienne Pallier
563 3 Etienne Pallier
h3. Replace the default pyrosapp models.py with the inspectdb generated one
564 3 Etienne Pallier
565 105 Etienne Pallier
From src/ :
566 1 Etienne Pallier
567 105 Etienne Pallier
<pre>
568 105 Etienne Pallier
$ mv models.py pyrosapp/
569 105 Etienne Pallier
</pre>
570 3 Etienne Pallier
571 7 Etienne Pallier
572 1 Etienne Pallier
573 9 Etienne Pallier
574 47 Etienne Pallier
---
575 3 Etienne Pallier
576 113 Etienne Pallier
h3. *TODO: Fix and improve the pyrosapp models.py file (generated by inspectdb)*
577 3 Etienne Pallier
578 114 Etienne Pallier
From src/pyrosapp/ :
579 1 Etienne Pallier
580 106 Etienne Pallier
Edit models.py
581 106 Etienne Pallier
582 106 Etienne Pallier
Do these changes:
583 106 Etienne Pallier
...
584 109 Etienne Pallier
585 109 Etienne Pallier
586 109 Etienne Pallier
587 109 Etienne Pallier
---
588 109 Etienne Pallier
589 111 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}II - CONFIGURATION of the Django Back Office (administration interface)%