Wiki

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