author | Tero Marttila <terom@fixme.fi> |
Fri, 21 Jan 2011 04:44:30 +0200 | |
changeset 61 | ce1d012d02fe |
parent 25 | cfb55708ee03 |
permissions | -rw-r--r-- |
6
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
1 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
2 |
Application runtime state |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
3 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
4 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
5 |
from sqlalchemy import create_engine |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
6 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
7 |
import logging |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
8 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
9 |
from svv import database as db |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
10 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
11 |
log = logging.getLogger('svv.app') |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
12 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
13 |
class Application (object) : |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
14 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
15 |
Our core run-time state, which e.g. WSGIAoo acts as a frontend to |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
16 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
17 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
18 |
def __init__ (self, db_url) : |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
19 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
20 |
Initialize app, connecting to database. |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
21 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
22 |
db_url - sqlalchemy-style URL to database |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
23 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
24 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
25 |
if db_url : |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
26 |
# connect |
7 | 27 |
self._engine = engine = create_engine(db_url) |
6
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
28 |
|
7 | 29 |
log.info("Connected to database %s", engine) |
6
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
30 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
31 |
else : |
7 | 32 |
self._engine = None |
33 |
||
34 |
@property |
|
35 |
def engine (self) : |
|
36 |
""" |
|
37 |
Our sqlalchemy engine providing access to our database |
|
38 |
""" |
|
39 |
||
40 |
if not self._engine : |
|
41 |
raise RuntimeError("No database configured") |
|
42 |
||
43 |
return self._engine |
|
6
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
44 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
45 |
def create_tables (self) : |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
46 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
47 |
Initialize the database if new. |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
48 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
49 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
50 |
log.warn("Creating database tables...") |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
51 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
52 |
db.schema.create_all(self.engine) |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
53 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
54 |
def get_connection (self) : |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
55 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
56 |
Return an active sqlalchemy Connection for our database. |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
57 |
""" |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
58 |
|
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
59 |
return self.engine.connect() |
72c73df76db2
Split wsgi.py into controllers/customers/urls for now; start orders form
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
60 |
|
7 | 61 |
def query (self, sql) : |
62 |
""" |
|
63 |
Execute a simple SQL query, and return results |
|
64 |
""" |
|
65 |
||
66 |
return self.engine.execute(sql) |
|
9
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
67 |
|
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
68 |
def insert (self, sql, **values) : |
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
69 |
""" |
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
70 |
Execute a simple SQL insert, returning the new IDs a a tuple. |
7 | 71 |
|
9
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
72 |
For the common case of a table with a simplex primary key, a call looks like: |
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
73 |
|
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
74 |
new_id, = app.insert(sql, foo=bar) |
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
75 |
""" |
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
76 |
|
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
77 |
return self.engine.execute(sql, **values).last_inserted_ids() |
0327b83959e9
Implement working NewOrderView, and start restructuring it again right away...
Tero Marttila <terom@fixme.fi>
parents:
7
diff
changeset
|
78 |
|
12 | 79 |
def execute (self, sql, **values) : |
80 |
""" |
|
81 |
Execute an SQL statement (UPDATE) that doesn't return any values. |
|
82 |
""" |
|
83 |
||
84 |
self.engine.execute(sql, **values) |
|
85 |
||
25
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
86 |
# XXX: rename this to something else, conflicts, to some degree, with web session with cookies (although using |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
87 |
# SQL transctions at that level would be pretty cool..) |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
88 |
# orm orm_session objects dbsession dbmapping dbmaps |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
89 |
def session (self) : |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
90 |
""" |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
91 |
Return a new SQLAlchemy database session, for use with ORM mapped objects. |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
92 |
""" |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
93 |
|
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
94 |
return db.session_factory(bind=self.engine) |
cfb55708ee03
db: change ForeignKey columns to use _id suffix; start using SQLAlchemy ORM for Order model
Tero Marttila <terom@fixme.fi>
parents:
12
diff
changeset
|
95 |