Python: Pyramid framework
Segons la introducció a la web de Pyramid:
Frameworks vs. Libraries A framework differs from a library in one very important way: library code is always called by code that you write, while a framework always calls code that you write. Using a set of libraries to create an application is usually easier than using a framework initially, because you can choose to cede control to library code you have not authored very selectively. But when you use a framework, you are required to cede a greater portion of control to code you have not authored: code that resides in the framework itself. You needn’t use a framework at all to create a web application using Python. A rich set of libraries already exists for the platform. In practice, however, using a framework to create an application is often more practical than rolling your own via a set of libraries if the framework provides a set of facilities that fits your application requirements. |
Tal i com diu aquest enunciat, un framework:
- té el control principal de l'aplicació, que en un moment donat el cedeix al teu codi.
- incialment aparenta ser més complex que utilizar una llibreria.
- finalment facilita molt el desenvolupament d'aplicacions.
Intro:
- http://docs.pylonsproject.org/projects/pyramid/en/1.4-branch/narr/introduction.html
- Pylons + repoze.bfg = Pyramid
- Traversal vs. url_dispatcher
- Estructura típica dels arxius en una web amb Pyramid (models, __init__, views, etc.)
Contingut
Fase de desenvolupament
Virutalenv és una potent eina que ens permetrà no haver d'instal·lar cap package al sistema operatiu. Podrem tenir una versió "neta" del python, sense cap llibreria, i instal·lar el què volguem sense afectar el comportarment del sistema (i, per tant, sense afectar a altres funcionalitats com l'escriptori). Cal recordar que Python és un llenguatge que s'utilitza en el Gnome i altres escritporis per aplicacions "stand-alone", pel que la instal·lació de paquets per l'escriptri podria afectar-nos al desenvolupament web i viceversa.
Anem a pams:
- Virtualenv (ens caldrà prèviament als scaffolds): http://docs.pylonsproject.org/projects/pyramid/en/latest/narr/install.html
- El més important a partir d'ara és no instal·lar cap pakage de Python (easy_install) en el sistema operatiu. O sigui, a partir d'ara, no hem de fer "sudo" per a res, ja que tot ho instal·larem al virtualenv (carpeta env).
- Un cop instal·lat el Virtualenv, a part de poder executar els scripts dintre de la carpeta "env" (nom típic), també podem ajustar l'entorn on treballem perquè, estiguem on estiguem, utilitzem les versions de les llibreries del virtualenv (encara que no estiguem al directori "env"):
$ source env/bin/activate
- Si tot ha anat bé, hem de tenir un prompt amb el nom de la carpeta del Virtualenv:
(env)enric@pepino:~$
- Si tot ha anat bé, hem de tenir un prompt amb el nom de la carpeta del Virtualenv:
- Primer projecte en Pyramid amb "single file" (sense scaffold): http://docs.pylonsproject.org/projects/pyramid_tutorials/en/latest/single_file_tasks/single_file_tasks.html
- Pyramid scaffolds (esquelet de projecte): http://docs.pylonsproject.org/projects/pyramid/en/latest/narr/project.html
Exercicis
- Instal·lar el virtualenv com es descriu en el link anterior.
- Crear el primer projecte Pyramid "single-file" (tasks).
- Crear un projecte Pyramid ("pyramidproject1") amb scaffolds (crear la plantilla que ve per defecte i arrencar el servidor).
- Inspecciona el contingut dels arxius, en especial __init__.py i views.py.
- Modificar el projecte "pyramidproject1" i afegir-hi una view "hello" com la que surt a la introducció:
- Aquesta view ha de retornar "Hello Enric!" si accedeixo a la URL http://localhost:6543/hello/Enric
- http://docs.pylonsproject.org/projects/pyramid/en/1.4-branch/narr/introduction.html#single-file-applications
- OJU: haureu de combinar el què veieu en l'exemple anterior, utilitzant la funció "Response" amb el què trobareu als arxius que el projecte ens ha creat, amb els decorators @view_config.
- Passar el projecte "tasks" (single-file) a un projecte amb scaffolds amb el nom "tasks2".
Fase de deployment (desplegament, producció)
Apache i WSGI
- Apache i WSGI: http://code.google.com/p/modwsgi/wiki/InstallationInstructions
- Configurant WSGI: http://code.google.com/p/modwsgi/wiki/QuickConfigurationGuide
- Integració de Apache WSGI i Pylons: http://code.google.com/p/modwsgi/wiki/IntegrationWithPylons
Buildout
El buildout ens permet construir projectes amb divereses versions dels packages necessaris. Així no tindrem conflictes de diverses aplicacions en un mateix entorn de producció (passaria si instal·lessim els packages al sistema).
- Article principal (cacauet): Buildout
- Variables d'entorn al fitxer .ini: http://pyramid.readthedocs.org/en/latest/narr/environment.html
- En producció, per problemes de la codificació per defecte i canviar-la a "utf-8", editar /usr/lib/pythonX.Y/sitecustomize.py i afegir:
import sys
sys.setdefaultencoding('utf-8')
- Per generar passwords: http://stackoverflow.com/questions/2257441/python-random-string-generation-with-upper-case-letters-and-digits
- ...