Wiki

Version 215 (Etienne Pallier, 03/22/2016 10:43 am)

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