Wiki

Version 258 (Etienne Pallier, 03/22/2016 11:54 pm)

1 1 Etienne Pallier
h1. Technical Documentation for the PYROS project (FGFT-CC)
2 1 Etienne Pallier
3 1 Etienne Pallier
4 1 Etienne Pallier
HOWTO Format Redmine Wiki : http://www.redmine.org/projects/redmine/wiki/FrRedmineWikiFormatting
5 1 Etienne Pallier
6 1 Etienne Pallier
{{>toc}}
7 1 Etienne Pallier
8 1 Etienne Pallier
9 121 Etienne Pallier
---
10 1 Etienne Pallier
11 121 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - TODO%
12 121 Etienne Pallier
13 251 Etienne Pallier
 * Intégration dans Eclipse
14 125 Etienne Pallier
15 251 Etienne Pallier
 * Séparation des BD Django et Pyros
16 126 Etienne Pallier
17 174 Etienne Pallier
 * Intégration des modules Django déjà développés
18 125 Etienne Pallier
19 121 Etienne Pallier
20 3 Etienne Pallier
---
21 1 Etienne Pallier
22 140 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}I - DATABASE SCHEMA (v0.2.1)%
23 116 Etienne Pallier
24 116 Etienne Pallier
25 117 Etienne Pallier
{{thumbnail(PYROS_PDM_v021.png, size=300, title=Pyros data model)}}
26 121 Etienne Pallier
27 121 Etienne Pallier
28 121 Etienne Pallier
---
29 116 Etienne Pallier
30 141 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}II - Get the project (from gitlab)%
31 141 Etienne Pallier
32 253 Etienne Pallier
h3. Project structure
33 1 Etienne Pallier
34 253 Etienne Pallier
Once you have fetched the project, you should obtain this structure:
35 1 Etienne Pallier
36 226 Etienne Pallier
<pre>
37 1 Etienne Pallier
38 1 Etienne Pallier
PYROS/
39 254 Etienne Pallier
├── install/
40 254 Etienne Pallier
│   └── REQUIREMENTS.txt
41 254 Etienne Pallier
│   └── INSTALLATION.txt
42 226 Etienne Pallier
├── public/
43 226 Etienne Pallier
│   └── static/
44 226 Etienne Pallier
├── src/
45 226 Etienne Pallier
│   ├── manage.py
46 226 Etienne Pallier
│   ├── pyros/
47 226 Etienne Pallier
│   │   ├── __init__.py
48 226 Etienne Pallier
│   │   ├── __pycache__
49 226 Etienne Pallier
│   │   ├── settings.py
50 1 Etienne Pallier
│   │   ├── urls.py
51 1 Etienne Pallier
│   │   └── wsgi.py
52 1 Etienne Pallier
│   └── pyrosapp/
53 1 Etienne Pallier
│       ├── __init__.py
54 1 Etienne Pallier
│       ├── admin.py
55 1 Etienne Pallier
│       ├── apps.py
56 1 Etienne Pallier
│       ├── migrations
57 1 Etienne Pallier
│       ├── models.py
58 1 Etienne Pallier
│       ├── tests.py
59 1 Etienne Pallier
│       └── views.py
60 1 Etienne Pallier
61 1 Etienne Pallier
62 253 Etienne Pallier
</pre>
63 253 Etienne Pallier
64 253 Etienne Pallier
h3. Get the project from the terminal
65 253 Etienne Pallier
66 253 Etienne Pallier
<pre>
67 253 Etienne Pallier
git clone https://gitlab.irap.omp.eu/epallier/pyros.git PYROS
68 256 Etienne Pallier
(or also : git clone git@gitlab.irap.omp.eu:epallier/pyros.git PYROS)
69 253 Etienne Pallier
</pre>
70 255 Etienne Pallier
71 253 Etienne Pallier
This creates a PYROS/ folder containing the project (with a .git/ subfolder for synchronization with the git repository)
72 253 Etienne Pallier
73 257 Etienne Pallier
_If you just wanted a static copy of the project (without synchronization), just remove the .git/ folder:_
74 253 Etienne Pallier
<pre>
75 253 Etienne Pallier
$ rm -r .git/
76 253 Etienne Pallier
</pre>
77 226 Etienne Pallier
78 1 Etienne Pallier
h3. Get the project from Eclipse
79 1 Etienne Pallier
80 258 Etienne Pallier
1) Fetch the project
81 258 Etienne Pallier
82 252 Etienne Pallier
File/Import project from git
83 1 Etienne Pallier
84 258 Etienne Pallier
Select repository source: Clone URI: https://gitlab.irap.omp.eu/epallier/pyros.git
85 252 Etienne Pallier
86 252 Etienne Pallier
Directory: 
87 252 Etienne Pallier
par défaut, il propose : /Users/epallier/git/pyros
88 258 Etienne Pallier
mais on peut le mettre ailleurs (c'est ce que j'ai fait)
89 252 Etienne Pallier
90 252 Etienne Pallier
initial branch: master
91 1 Etienne Pallier
remote name: origin
92 1 Etienne Pallier
93 1 Etienne Pallier
Import as general project
94 252 Etienne Pallier
95 252 Etienne Pallier
Project name: PYROS
96 252 Etienne Pallier
97 258 Etienne Pallier
98 258 Etienne Pallier
2) Configure the project
99 258 Etienne Pallier
100 252 Etienne Pallier
The project is created. Now, you have to set it as a «PyDev » and a « Django » project.
101 252 Etienne Pallier
102 252 Etienne Pallier
clic droit sur le projet / PyDev / set as a PyDev project
103 252 Etienne Pallier
104 1 Etienne Pallier
clic droit sur le projet / PyDev / set as a Django project
105 1 Etienne Pallier
106 1 Etienne Pallier
clic droit sur le projet : on doit maintenant avoir un sous-menu Django
107 252 Etienne Pallier
108 252 Etienne Pallier
clic droit sur le dossier src / PyDev / set as source folder (add to PYTHONPATH)
109 252 Etienne Pallier
110 252 Etienne Pallier
clic droit sur projet / Properties / Pydev-Django :
111 258 Etienne Pallier
  - Django manage.py : src/manage.py
112 258 Etienne Pallier
  - Django settings module : pyros.settings
113 252 Etienne Pallier
114 258 Etienne Pallier
115 258 Etienne Pallier
3) Test by running the web server :
116 252 Etienne Pallier
clic droit sur projet, Django/Custom command/runserver
117 252 Etienne Pallier
118 252 Etienne Pallier
check http://localhost:8000/
119 252 Etienne Pallier
120 252 Etienne Pallier
121 252 Etienne Pallier
122 252 Etienne Pallier
mkdir private
123 252 Etienne Pallier
124 252 Etienne Pallier
sudo port install py35-virtualenv
125 252 Etienne Pallier
126 252 Etienne Pallier
virtualenv-3.5 venv_py35_pyros -p /opt/local/bin/python3.5
127 252 Etienne Pallier
128 252 Etienne Pallier
pip install -r ../PYROS/private/REQUIREMENTS.txt
129 252 Etienne Pallier
130 252 Etienne Pallier
131 252 Etienne Pallier
132 252 Etienne Pallier
133 252 Etienne Pallier
clic droit sur projet / Properties / PyDev - Interpreter/Grammar :
134 252 Etienne Pallier
Grammar version : 3
135 252 Etienne Pallier
Interpreter : click on « click here to configure an interpreter not listed »
136 252 Etienne Pallier
click on « New » :
137 252 Etienne Pallier
- Interpreter name : venv_py35_pyros
138 252 Etienne Pallier
- Interpreter executable : click on « Browse »
139 252 Etienne Pallier
	Select your private/venv_py35_pyros/bin/python3.5 executable
140 252 Etienne Pallier
	click OK
141 252 Etienne Pallier
	click OK again
142 252 Etienne Pallier
143 252 Etienne Pallier
Interpreter: select now venv_py35_pyros from the list
144 252 Etienne Pallier
145 252 Etienne Pallier
146 252 Etienne Pallier
Code style checking:
147 252 Etienne Pallier
148 252 Etienne Pallier
Window/Preferences : Pydev / Editor
149 252 Etienne Pallier
- Auto Imports : uncheck « Do auto import »
150 252 Etienne Pallier
- Code style:
151 252 Etienne Pallier
	- Locals … : camelCase
152 252 Etienne Pallier
	- Methods : camelCase() with first lower
153 252 Etienne Pallier
- Code style / Code Formatter: activer « use autopep8.py for code formatting »
154 252 Etienne Pallier
- Tabs : Tab length : 4
155 169 Etienne Pallier
156 141 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}III - INSTALLATION%
157 2 Etienne Pallier
158 120 Etienne Pallier
159 120 Etienne Pallier
---
160 120 Etienne Pallier
161 184 Etienne Pallier
h3. Install MySql (only if necessary)
162 2 Etienne Pallier
163 49 Etienne Pallier
 * Linux Ubuntu
164 49 Etienne Pallier
<pre>
165 107 Paul Carensac
166 107 Paul Carensac
$ sudo apt-get install mysql-server
167 107 Paul Carensac
$ sudo apt-get install mysql-client
168 107 Paul Carensac
169 49 Etienne Pallier
</pre>
170 49 Etienne Pallier
171 49 Etienne Pallier
 * Linux CentOS
172 49 Etienne Pallier
<pre>
173 49 Etienne Pallier
TODO:
174 49 Etienne Pallier
$ sudo yum install mysql
175 49 Etienne Pallier
...
176 49 Etienne Pallier
</pre>
177 49 Etienne Pallier
178 49 Etienne Pallier
 * Mac OS X
179 1 Etienne Pallier
Install XAMPP
180 1 Etienne Pallier
(but you could also use the pre-installed Mac OS MySql)
181 177 Etienne Pallier
<pre>
182 177 Etienne Pallier
TODO:
183 49 Etienne Pallier
</pre>
184 1 Etienne Pallier
185 49 Etienne Pallier
 * Windows
186 243 Paul Carensac
187 1 Etienne Pallier
<pre>
188 243 Paul Carensac
Download and install the newest version on https://dev.mysql.com/downloads/installer/
189 243 Paul Carensac
190 243 Paul Carensac
Once installed, launch MySQL Installer. Clic on 'Add...' on the right.
191 243 Paul Carensac
In MySQLServers section, choose the newest, then clic on next.
192 243 Paul Carensac
Install and configure the server (just follow the installation guide).
193 243 Paul Carensac
194 243 Paul Carensac
Then launch mysql (via the Windows menu).
195 49 Etienne Pallier
</pre>
196 49 Etienne Pallier
197 49 Etienne Pallier
198 49 Etienne Pallier
---
199 1 Etienne Pallier
200 185 Etienne Pallier
h3. Install Python3.5 (only if necessary)
201 1 Etienne Pallier
202 11 Etienne Pallier
203 11 Etienne Pallier
 * Mac OS X :
204 1 Etienne Pallier
<pre>
205 183 Etienne Pallier
206 24 Etienne Pallier
1) Installer MacPort
207 24 Etienne Pallier
(TODO: doc)
208 24 Etienne Pallier
209 24 Etienne Pallier
2) Installer le "port" python35
210 1 Etienne Pallier
$ sudo port install python35
211 183 Etienne Pallier
212 1 Etienne Pallier
</pre>
213 1 Etienne Pallier
214 1 Etienne Pallier
 * Linux (Ubuntu) :
215 1 Etienne Pallier
<pre>
216 244 Paul Carensac
$ sudo add-apt-repository ppa:fkrull/deadsnakes
217 244 Paul Carensac
$ sudo apt-get update
218 244 Paul Carensac
$ sudo apt-get install python3.5
219 1 Etienne Pallier
220 244 Paul Carensac
$ sudo pip install virtualenv
221 1 Etienne Pallier
</pre>
222 1 Etienne Pallier
223 244 Paul Carensac
224 244 Paul Carensac
 * Windows 7 :
225 244 Paul Carensac
<pre>
226 244 Paul Carensac
Go to https://www.python.org/downloads/windows/ , choose the wanted version
227 244 Paul Carensac
On the wanted version’s page, download Windows x86 executable installer
228 244 Paul Carensac
229 244 Paul Carensac
Run the executable
230 244 Paul Carensac
    * On the first page, check "Add python3.5 to PATH"
231 244 Paul Carensac
    * Choose "Install now" option
232 245 Paul Carensac
233 245 Paul Carensac
Open cmd (windows + R, cmd) :
234 245 Paul Carensac
 $ python -m pip install --upgrade pip
235 245 Paul Carensac
 $ pip install virtualenv
236 244 Paul Carensac
</pre>
237 1 Etienne Pallier
238 183 Etienne Pallier
 * Windows 10 :
239 183 Etienne Pallier
<pre>
240 187 Etienne Pallier
TODO:
241 183 Etienne Pallier
</pre>
242 3 Etienne Pallier
243 4 Etienne Pallier
---
244 5 Etienne Pallier
245 192 Etienne Pallier
h3. Create a Python3 virtual environment dedicated to the project (inside the project folder)
246 127 Etienne Pallier
247 131 Etienne Pallier
<pre>
248 1 Etienne Pallier
249 193 Etienne Pallier
$ mkdir private/
250 193 Etienne Pallier
251 133 Etienne Pallier
$ cd private/
252 3 Etienne Pallier
253 246 Paul Carensac
$ which python3.5 ("where python" for windows)
254 3 Etienne Pallier
/opt/local/bin/python3.5
255 15 Etienne Pallier
256 127 Etienne Pallier
$ virtualenv-3.5 venv_py35_pyros -p /opt/local/bin/python3.5
257 3 Etienne Pallier
=> creates a venv_py35_pyros/ folder inside PYROS/private/
258 1 Etienne Pallier
259 131 Etienne Pallier
</pre>
260 1 Etienne Pallier
261 7 Etienne Pallier
---
262 3 Etienne Pallier
263 65 Etienne Pallier
h3. Activate the python virtual environment (from inside the project)
264 7 Etienne Pallier
265 55 Etienne Pallier
<pre>
266 1 Etienne Pallier
267 65 Etienne Pallier
$ pwd
268 134 Etienne Pallier
.../PYROS/private
269 1 Etienne Pallier
270 247 Paul Carensac
$ source ./venv_py35_pyros/bin/activate (venv_py35_pyros/Scripts/activate on Windows)
271 247 Paul Carensac
272 65 Etienne Pallier
273 3 Etienne Pallier
$ python -V
274 1 Etienne Pallier
Python 3.5.1
275 3 Etienne Pallier
276 3 Etienne Pallier
$ which pip
277 77 Etienne Pallier
.../PYROS/venv_py35_pyros/bin/pip
278 16 Etienne Pallier
279 194 Etienne Pallier
Upgrade pip to last version available:
280 3 Etienne Pallier
$ pip install --upgrade pip
281 3 Etienne Pallier
Collecting pip
282 3 Etienne Pallier
  Downloading pip-8.1.1-py2.py3-none-any.whl (1.2MB)
283 3 Etienne Pallier
Installing collected packages: pip
284 3 Etienne Pallier
  Found existing installation: pip 7.1.2
285 3 Etienne Pallier
    Uninstalling pip-7.1.2:
286 3 Etienne Pallier
      Successfully uninstalled pip-7.1.2
287 1 Etienne Pallier
Successfully installed pip-8.1.1
288 194 Etienne Pallier
289 194 Etienne Pallier
Upgrade wheel to last version available:
290 194 Etienne Pallier
$ pip install --upgrade wheel
291 194 Etienne Pallier
Collecting wheel
292 194 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
293 194 Etienne Pallier
Installing collected packages: wheel
294 194 Etienne Pallier
  Found existing installation: wheel 0.24.0
295 194 Etienne Pallier
    Uninstalling wheel-0.24.0:
296 194 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
297 194 Etienne Pallier
Successfully installed wheel-0.29.0
298 194 Etienne Pallier
299 55 Etienne Pallier
300 55 Etienne Pallier
</pre>
301 18 Etienne Pallier
302 212 Etienne Pallier
h3. Install the needed Python packages (from within the virtual environment)
303 18 Etienne Pallier
304 66 Etienne Pallier
First, be sure that the virtual environment is activated:
305 66 Etienne Pallier
<pre>
306 66 Etienne Pallier
$ python -V
307 66 Etienne Pallier
Python 3.5.1
308 66 Etienne Pallier
</pre>
309 66 Etienne Pallier
310 62 Etienne Pallier
 * *Automatic Installation of all packages*
311 62 Etienne Pallier
<pre>
312 90 Etienne Pallier
$ pip install -r REQUIREMENTS.txt
313 62 Etienne Pallier
</pre>
314 62 Etienne Pallier
315 93 Etienne Pallier
 * *Or, manual installation of each package*
316 62 Etienne Pallier
317 62 Etienne Pallier
  * *Install Django* :
318 32 Etienne Pallier
<pre>
319 3 Etienne Pallier
$ pip install django
320 3 Etienne Pallier
Collecting django
321 3 Etienne Pallier
  Downloading Django-1.9.4-py2.py3-none-any.whl (6.6MB)
322 3 Etienne Pallier
Installing collected packages: django
323 3 Etienne Pallier
Successfully installed django-1.9.4
324 3 Etienne Pallier
325 3 Etienne Pallier
$ pip install django-admin-tools
326 3 Etienne Pallier
Collecting django-admin-tools
327 3 Etienne Pallier
  Downloading django_admin_tools-0.7.2-py2.py3-none-any.whl (289kB)
328 3 Etienne Pallier
Installing collected packages: django-admin-tools
329 3 Etienne Pallier
Successfully installed django-admin-tools-0.7.2
330 3 Etienne Pallier
331 21 Etienne Pallier
$ pip install django-debug-toolbar
332 21 Etienne Pallier
Collecting django-debug-toolbar
333 21 Etienne Pallier
  Downloading django_debug_toolbar-1.4-py2.py3-none-any.whl (212kB)
334 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)
335 21 Etienne Pallier
Collecting sqlparse (from django-debug-toolbar)
336 21 Etienne Pallier
  Downloading sqlparse-0.1.19.tar.gz (58kB)
337 21 Etienne Pallier
Building wheels for collected packages: sqlparse
338 21 Etienne Pallier
  Running setup.py bdist_wheel for sqlparse ... done
339 21 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/7b/d4/72/6011bb100dd5fc213164e4bbee13d4e03261dd54ce6a5de6b8
340 21 Etienne Pallier
Successfully built sqlparse
341 21 Etienne Pallier
Installing collected packages: sqlparse, django-debug-toolbar
342 21 Etienne Pallier
Successfully installed django-debug-toolbar-1.4 sqlparse-0.1.19
343 21 Etienne Pallier
344 21 Etienne Pallier
$ pip install django-extensions
345 21 Etienne Pallier
Collecting django-extensions
346 21 Etienne Pallier
  Downloading django_extensions-1.6.1-py2.py3-none-any.whl (202kB)
347 21 Etienne Pallier
Collecting six>=1.2 (from django-extensions)
348 21 Etienne Pallier
  Downloading six-1.10.0-py2.py3-none-any.whl
349 21 Etienne Pallier
Installing collected packages: six, django-extensions
350 21 Etienne Pallier
Successfully installed django-extensions-1.6.1 six-1.10.0
351 21 Etienne Pallier
352 21 Etienne Pallier
$ pip install django-suit
353 21 Etienne Pallier
Collecting django-suit
354 21 Etienne Pallier
  Downloading django-suit-0.2.18.tar.gz (587kB)
355 21 Etienne Pallier
Building wheels for collected packages: django-suit
356 1 Etienne Pallier
  Running setup.py bdist_wheel for django-suit ... done
357 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/12/8b/9a/e02ab0ad9229881638aa040d47d77c8f562999533811927d41
358 1 Etienne Pallier
Successfully built django-suit
359 1 Etienne Pallier
Installing collected packages: django-suit
360 1 Etienne Pallier
Successfully installed django-suit-0.2.18
361 21 Etienne Pallier
362 32 Etienne Pallier
</pre>
363 32 Etienne Pallier
364 63 Etienne Pallier
  * *Install the web application server gunicorn (will be used in production instead of the dev django web server)* :
365 32 Etienne Pallier
<pre>
366 25 Etienne Pallier
$ pip install gunicorn
367 25 Etienne Pallier
Collecting gunicorn
368 25 Etienne Pallier
  Downloading gunicorn-19.4.5-py2.py3-none-any.whl (112kB)
369 21 Etienne Pallier
Installing collected packages: gunicorn
370 26 Etienne Pallier
Successfully installed gunicorn-19.4.5
371 1 Etienne Pallier
</pre>
372 1 Etienne Pallier
373 63 Etienne Pallier
  * *Install the python mysql client*:
374 32 Etienne Pallier
<pre>
375 32 Etienne Pallier
$ pip install mysqlclient
376 72 Etienne Pallier
...
377 72 Etienne Pallier
</pre>
378 33 Etienne Pallier
379 73 Etienne Pallier
   * => Issue under Mac OS X:
380 72 Etienne Pallier
<pre>
381 3 Etienne Pallier
$ pip install mysqlclient
382 3 Etienne Pallier
Collecting mysqlclient
383 1 Etienne Pallier
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
384 22 Etienne Pallier
Building wheels for collected packages: mysqlclient
385 3 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... error
386 3 Etienne Pallier
387 1 Etienne Pallier
  ----------------------------------------
388 1 Etienne Pallier
  Failed building wheel for mysqlclient
389 1 Etienne Pallier
  Running setup.py clean for mysqlclient
390 1 Etienne Pallier
Failed to build mysqlclient
391 1 Etienne Pallier
Installing collected packages: mysqlclient
392 1 Etienne Pallier
  Running setup.py install for mysqlclient ... done
393 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
394 1 Etienne Pallier
395 1 Etienne Pallier
BOUH !!!
396 1 Etienne Pallier
397 1 Etienne Pallier
$ pip install --upgrade wheel
398 1 Etienne Pallier
Collecting wheel
399 1 Etienne Pallier
  Downloading wheel-0.29.0-py2.py3-none-any.whl (66kB)
400 1 Etienne Pallier
Installing collected packages: wheel
401 1 Etienne Pallier
  Found existing installation: wheel 0.24.0
402 1 Etienne Pallier
    Uninstalling wheel-0.24.0:
403 1 Etienne Pallier
      Successfully uninstalled wheel-0.24.0
404 1 Etienne Pallier
Successfully installed wheel-0.29.0
405 1 Etienne Pallier
406 1 Etienne Pallier
$ pip uninstall mysqlclient
407 1 Etienne Pallier
408 1 Etienne Pallier
$ pip install mysqlclient
409 1 Etienne Pallier
Collecting mysqlclient
410 1 Etienne Pallier
  Using cached mysqlclient-1.3.7.tar.gz
411 1 Etienne Pallier
Building wheels for collected packages: mysqlclient
412 1 Etienne Pallier
  Running setup.py bdist_wheel for mysqlclient ... done
413 1 Etienne Pallier
  Stored in directory: /Users/epallier/Library/Caches/pip/wheels/9b/06/50/d11418c26cf8f2156b13d4363b5afde8e7e75ebb8540d0228d
414 1 Etienne Pallier
Successfully built mysqlclient
415 1 Etienne Pallier
Installing collected packages: mysqlclient
416 1 Etienne Pallier
Successfully installed mysqlclient-1.3.7
417 1 Etienne Pallier
418 1 Etienne Pallier
YES !!!
419 1 Etienne Pallier
420 1 Etienne Pallier
</pre>
421 1 Etienne Pallier
422 107 Paul Carensac
   * => Issues under Ubuntu:
423 107 Paul Carensac
<pre>
424 107 Paul Carensac
$ pip install mysqlclient
425 107 Paul Carensac
Collecting mysqlclient
426 107 Paul Carensac
  Downloading mysqlclient-1.3.7.tar.gz (79kB)
427 107 Paul Carensac
    100% |████████████████████████████████| 81kB 1.5MB/s
428 107 Paul Carensac
    Complete output from command python setup.py egg_info:
429 107 Paul Carensac
    /bin/sh: 1: mysql_config: not found
430 107 Paul Carensac
    Traceback (most recent call last):
431 107 Paul Carensac
      File "<string>", line 1, in <module>
432 107 Paul Carensac
    [...]
433 107 Paul Carensac
    ----------------------------------------
434 107 Paul Carensac
Command "python setup.py egg_info" failed with error code 1 in /tmp/pip-build-q6j4inuz/mysqlclient/
435 1 Etienne Pallier
436 108 Paul Carensac
BOUH !!!
437 108 Paul Carensac
438 107 Paul Carensac
$ sudo apt-get install libmysqlclient-dev
439 108 Paul Carensac
440 107 Paul Carensac
$ pip install mysqlclient
441 107 Paul Carensac
Collecting mysqlclient
442 107 Paul Carensac
  Using cached mysqlclient-1.3.7.tar.gz
443 107 Paul Carensac
Building wheels for collected packages: mysqlclient
444 107 Paul Carensac
  Running setup.py bdist_wheel for mysqlclient ... error
445 107 Paul Carensac
446 107 Paul Carensac
    _mysql.c:40:20: fatal error: Python.h: No such file or directory
447 107 Paul Carensac
     #include "Python.h"
448 107 Paul Carensac
                        ^
449 107 Paul Carensac
    compilation terminated.
450 107 Paul Carensac
    error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
451 107 Paul Carensac
    
452 107 Paul Carensac
    ----------------------------------------
453 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/
454 107 Paul Carensac
455 108 Paul Carensac
BOUH !!!
456 108 Paul Carensac
457 107 Paul Carensac
$ sudo apt-get install python3.5-dev
458 108 Paul Carensac
459 107 Paul Carensac
$ pip install mysqlclient
460 107 Paul Carensac
461 107 Paul Carensac
YES !!!
462 107 Paul Carensac
463 107 Paul Carensac
</pre>
464 12 Etienne Pallier
465 250 Paul Carensac
 * => Issue under Windows
466 250 Paul Carensac
<pre>
467 250 Paul Carensac
Same message as the issue for Mac.
468 250 Paul Carensac
469 250 Paul Carensac
Go to http://www.lfd.uci.edu/~gohlke/pythonlibs/#mysqlclient to download the newest mysqlclient wheel
470 250 Paul Carensac
471 250 Paul Carensac
$ pip install path\to\mysqlclient\wheel
472 250 Paul Carensac
473 250 Paul Carensac
No need to redo "pip install mysqlclient"
474 250 Paul Carensac
</pre>
475 250 Paul Carensac
476 12 Etienne Pallier
---
477 28 Etienne Pallier
478 142 Etienne Pallier
h3. Test the project
479 142 Etienne Pallier
480 142 Etienne Pallier
<pre>
481 142 Etienne Pallier
482 150 Etienne Pallier
$ cd src/
483 150 Etienne Pallier
484 1 Etienne Pallier
$ ./manage.py runserver
485 38 Etienne Pallier
(or gunicorn pyros.wsgi)
486 3 Etienne Pallier
==> http://localhost:8000
487 87 Etienne Pallier
...
488 87 Etienne Pallier
...
489 87 Etienne Pallier
Ctrl-c
490 87 Etienne Pallier
491 1 Etienne Pallier
</pre>
492 142 Etienne Pallier
493 142 Etienne Pallier
494 142 Etienne Pallier
495 142 Etienne Pallier
---
496 142 Etienne Pallier
497 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)%
498 155 Paul Carensac
499 155 Paul Carensac
---
500 155 Paul Carensac
501 155 Paul Carensac
h3. Back Office setup
502 155 Paul Carensac
503 155 Paul Carensac
 * Prerequisites in src/pyros/settings.py :
504 155 Paul Carensac
505 155 Paul Carensac
    * INSTALLED_APPS must (at least) contain :
506 155 Paul Carensac
507 155 Paul Carensac
        * django.contrib.admin
508 155 Paul Carensac
        * django.contrib.auth
509 155 Paul Carensac
        * django.contrib.contenttypes
510 155 Paul Carensac
        * django.contrib.sessions
511 155 Paul Carensac
512 155 Paul Carensac
    * MIDDLEWARES must (at least) contain :
513 155 Paul Carensac
514 155 Paul Carensac
        * django.contrib.sessions.middleware.SessionMiddleware
515 155 Paul Carensac
        * django.middleware.common.CommonMiddleware
516 155 Paul Carensac
        * django.contrib.auth.middleware.AuthenticationMiddleware
517 155 Paul Carensac
518 155 Paul Carensac
 * At least one 'python manage.py migrate' must have been executed
519 155 Paul Carensac
520 155 Paul Carensac
 * Create a superuser for the administration :
521 155 Paul Carensac
522 155 Paul Carensac
<pre>
523 155 Paul Carensac
$ python manage.py createsuperuser
524 155 Paul Carensac
</pre>
525 155 Paul Carensac
526 156 Paul Carensac
* For each app of the project, fill the admin.py file :
527 155 Paul Carensac
528 155 Paul Carensac
<pre>
529 155 Paul Carensac
from django.contrib import admin
530 155 Paul Carensac
from app.models import Model1, Model2
531 155 Paul Carensac
532 155 Paul Carensac
admin.site.register(Model1)
533 155 Paul Carensac
admin.site.register(Model2)
534 155 Paul Carensac
</pre>
535 155 Paul Carensac
536 155 Paul Carensac
*Reminder* : each application must be registered in the settings.py INSTALLED_APPS variable.
537 157 Paul Carensac
538 168 Paul Carensac
* For each model in models.py, add a '__str__()' method in order to identify the object on the back office. Example :
539 157 Paul Carensac
540 157 Paul Carensac
<pre>
541 157 Paul Carensac
class UserLevel(models.Model):
542 157 Paul Carensac
    name = models.CharField(max_length=45, blank=True, null=True)
543 157 Paul Carensac
    desc = models.TextField(blank=True, null=True)
544 157 Paul Carensac
    priority = models.IntegerField(blank=True, null=True)
545 157 Paul Carensac
    quota = models.FloatField(blank=True, null=True)
546 157 Paul Carensac
547 157 Paul Carensac
    class Meta:
548 157 Paul Carensac
        managed = True
549 157 Paul Carensac
        db_table = 'userlevel'
550 157 Paul Carensac
551 157 Paul Carensac
    def __str__(self):
552 163 Paul Carensac
        return (str(self.name))
553 157 Paul Carensac
</pre>
554 157 Paul Carensac
555 159 Paul Carensac
*Naming convention* : Use self.name when possible, the creation time/date otherwise. Example :
556 159 Paul Carensac
557 159 Paul Carensac
<pre>
558 159 Paul Carensac
class SiteWatch(models.Model):
559 159 Paul Carensac
    updated = models.DateTimeField(blank=True, null=True)
560 159 Paul Carensac
    lights = models.CharField(max_length=45, blank=True, null=True)
561 159 Paul Carensac
    dome = models.CharField(max_length=45, blank=True, null=True)
562 159 Paul Carensac
    doors = models.CharField(max_length=45, blank=True, null=True)
563 159 Paul Carensac
    temperature = models.FloatField(blank=True, null=True)
564 159 Paul Carensac
565 159 Paul Carensac
    class Meta:
566 159 Paul Carensac
        managed = True
567 159 Paul Carensac
        db_table = 'sitewatch'
568 159 Paul Carensac
569 159 Paul Carensac
    def __str__(self):
570 160 Paul Carensac
        return (str(self.updated))
571 159 Paul Carensac
</pre>
572 173 Etienne Pallier
573 211 Paul Carensac
---
574 211 Paul Carensac
575 211 Paul Carensac
h3. Adaptation of the one-to-many and many-to-many display
576 211 Paul Carensac
577 211 Paul Carensac
* The one-to-many relationships are the following (One.many format) :
578 211 Paul Carensac
579 211 Paul Carensac
    * Schedule.sequences
580 211 Paul Carensac
    * Request.sequences
581 211 Paul Carensac
    * Sequence.albums
582 211 Paul Carensac
    * Album.plans
583 211 Paul Carensac
    * Plan.images
584 211 Paul Carensac
    * Telescope.detectors
585 211 Paul Carensac
    * Detector.filters
586 211 Paul Carensac
    * NrtAnalysis.images
587 211 Paul Carensac
    * Filter.plans
588 211 Paul Carensac
    * Detector.albums
589 211 Paul Carensac
    * UserLevel.users
590 211 Paul Carensac
    * Country.users
591 211 Paul Carensac
    * ScientificProgram.requests
592 211 Paul Carensac
    * User.requests
593 211 Paul Carensac
    * StrategyObs.alerts
594 211 Paul Carensac
    * SequenceType.sequences
595 211 Paul Carensac
596 211 Paul Carensac
* For each "many", create a new class in admin.py just after the imports, following these examples :
597 211 Paul Carensac
598 211 Paul Carensac
<pre>
599 211 Paul Carensac
600 211 Paul Carensac
For Schedule.sequences, Request.sequences and Sequentype.sequences, we will need :
601 211 Paul Carensac
602 211 Paul Carensac
class SequenceInline(admin.TabularInline):
603 211 Paul Carensac
    model = Sequence
604 211 Paul Carensac
    fields = ("name",)
605 211 Paul Carensac
    show_change_link = True
606 211 Paul Carensac
607 211 Paul Carensac
608 211 Paul Carensac
For Sequence.albums and Detector.albums, we will need :
609 211 Paul Carensac
610 211 Paul Carensac
class AlbumInline(admin.TabularInline):
611 211 Paul Carensac
    model = Album
612 211 Paul Carensac
    fields = ("name",)
613 211 Paul Carensac
    show_change_link = True
614 211 Paul Carensac
615 211 Paul Carensac
616 211 Paul Carensac
For StrategyObs.alerts, we will need :
617 211 Paul Carensac
618 211 Paul Carensac
class AlertInline(admin.TabularInline):
619 211 Paul Carensac
    model = Alert
620 211 Paul Carensac
    fields = ("request.name",) # there is no 'name' attribute in the Alert model
621 211 Paul Carensac
    show_change_link = True
622 211 Paul Carensac
623 211 Paul Carensac
</pre>
624 211 Paul Carensac
625 222 Paul Carensac
* For each "One", declare a new class in admin.py, just after the "Inlines" class declaration, as done in the following examples :
626 211 Paul Carensac
627 222 Paul Carensac
<pre>
628 222 Paul Carensac
For Request.sequences :
629 222 Paul Carensac
630 222 Paul Carensac
class RequestAdmin(admin.ModelAdmin):
631 222 Paul Carensac
    inlines = [
632 222 Paul Carensac
	SequenceInline,
633 222 Paul Carensac
    ]
634 222 Paul Carensac
635 222 Paul Carensac
For Detector.filters and Detector.albums :
636 222 Paul Carensac
637 222 Paul Carensac
class DetectorAdmin(admin.ModelAdmin):
638 222 Paul Carensac
    inlines = [
639 222 Paul Carensac
	FilterInline,
640 222 Paul Carensac
        AlbumInline,
641 222 Paul Carensac
    ]
642 222 Paul Carensac
643 222 Paul Carensac
</pre>
644 222 Paul Carensac
645 232 Paul Carensac
646 222 Paul Carensac
* The many-to-many relationships are the following :
647 232 Paul Carensac
648 222 Paul Carensac
    * ScientificProgram - User
649 222 Paul Carensac
    * ScheduleHistory - Sequence
650 222 Paul Carensac
651 222 Paul Carensac
* For each many-to-many relationship, declare a new "Inline" class in admin.py just after the imports, like this :
652 222 Paul Carensac
653 222 Paul Carensac
<pre>
654 222 Paul Carensac
For ScientificProgram - User :
655 222 Paul Carensac
656 222 Paul Carensac
class UserAndSPInline(admin.TabularInline):
657 222 Paul Carensac
    model = ScientificProgram.users.through
658 222 Paul Carensac
659 222 Paul Carensac
660 222 Paul Carensac
For ScheduleHistory - Sequence
661 222 Paul Carensac
662 222 Paul Carensac
class SequenceAndSHInline(admin.TabularInline):
663 222 Paul Carensac
    model = ScheduleHistory.sequences.through
664 222 Paul Carensac
665 222 Paul Carensac
</pre>
666 222 Paul Carensac
667 222 Paul Carensac
+Note :+ The order in the line "model = ScientificProgram.users.through" is very important : the first model (ScientificProgram) is the one in which is declared the ManyToManyField relationship.
668 232 Paul Carensac
669 232 Paul Carensac
* For each many-to-many relationship, declare two new classes in admin.py, just after the inlines, like in the following examples :
670 232 Paul Carensac
671 232 Paul Carensac
<pre>
672 232 Paul Carensac
For the ScheduleHistory - Sequence relationship :
673 232 Paul Carensac
674 232 Paul Carensac
class ScheduleHistoryAdmin(admin.ModelAdmin):
675 232 Paul Carensac
    inlines = [
676 232 Paul Carensac
        SequenceAndSHInline,
677 232 Paul Carensac
    ]
678 232 Paul Carensac
    exclude = ('sequences',) # ScheduleHistory declares the ManyToManyField, and we want to replace its display in the back office, so we won't display the default field
679 232 Paul Carensac
680 232 Paul Carensac
class SequenceAdmin(admin.ModelAdmin):
681 232 Paul Carensac
    inlines = [
682 232 Paul Carensac
        AlbumInline,        # This is the Inline for the one-to-many relationship Sequence.albums
683 232 Paul Carensac
        SequenceAndSHInline,                                                                
684 232 Paul Carensac
    ]
685 232 Paul Carensac
686 232 Paul Carensac
For the ScientificProgram - User relationship :
687 232 Paul Carensac
688 232 Paul Carensac
class ScientificProgramAdmin(admin.ModelAdmin):
689 232 Paul Carensac
    inlines = [
690 232 Paul Carensac
        RequestInline,
691 232 Paul Carensac
	UserAndSPInline,                                                                         
692 232 Paul Carensac
    ]
693 232 Paul Carensac
    exclude = ('users',) # Same as ScheduleHistory                                                                         
694 232 Paul Carensac
695 232 Paul Carensac
class UserAdmin(admin.ModelAdmin):
696 232 Paul Carensac
    inlines = [
697 232 Paul Carensac
	RequestInline,   # This is the Inline for the one-to-many relationship User.requests
698 232 Paul Carensac
        UserAndSPInline,                                                                    
699 232 Paul Carensac
    ]
700 232 Paul Carensac
701 232 Paul Carensac
</pre>
702 232 Paul Carensac
703 235 Paul Carensac
* For each ModelAdmin class in the admin.py, change the registering line
704 235 Paul Carensac
705 235 Paul Carensac
<pre>
706 235 Paul Carensac
admin.site.register(Album)
707 235 Paul Carensac
</pre>
708 235 Paul Carensac
709 235 Paul Carensac
to
710 235 Paul Carensac
711 235 Paul Carensac
<pre>
712 235 Paul Carensac
admin.site.register(Album, AlbumAdmin)
713 235 Paul Carensac
</pre>
714 211 Paul Carensac
715 229 Etienne Pallier
h2. %{margin-left:0px; font-weight:bold; font-size:25px;  display:block; color:red;}V - INSTALLATION FROM THE BEGINNING (for dev only, history of the initial project creation)%
716 1 Etienne Pallier
717 236 Etienne Pallier
718 242 Etienne Pallier
[[pyros_install_from_start|Pyros installation from the beginning]]