dbd/postgresql/connection.c

Fri, 24 Dec 2010 00:34:04 +0000

author
nrich@ii.net
date
Fri, 24 Dec 2010 00:34:04 +0000
changeset 44
aab3ed7d93fe
parent 32
03ed0ca09837
permissions
-rw-r--r--

Make calling autocommit with the same value as set a NOOP to suppress a warning from the DB

1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
1 #include "dbd_postgresql.h"
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
2
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
3 int dbd_postgresql_statement_create(lua_State *L, connection_t *conn, const char *sql_query);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
4
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
5 static int run(connection_t *conn, const char *command) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
6 PGresult *result = PQexec(conn->postgresql, command);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
7 ExecStatusType status;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
8
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
9 if (!result)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
10 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
11
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
12 status = PQresultStatus(result);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
13 PQclear(result);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
14
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
15 if (status != PGRES_COMMAND_OK && status != PGRES_TUPLES_OK)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
16 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
17
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
18 return 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
19 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
20
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
21 static int commit(connection_t *conn) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
22 return run(conn, "COMMIT");
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
23 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
24
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
25
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
26 static int begin(connection_t *conn) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
27 return run(conn, "BEGIN");
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
28 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
29
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
30
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
31 static int rollback(connection_t *conn) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
32 return run(conn, "ROLLBACK");
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
33 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
34
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
35
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
36 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
37 * connection = DBD.PostgreSQL.New(dbname, user, password, host, port)
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
38 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
39 static int connection_new(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
40 int n = lua_gettop(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
41 connection_t *conn = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
42
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
43 const char *host = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
44 const char *user = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
45 const char *password = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
46 const char *db = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
47 const char *port = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
48
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
49 const char *options = NULL; /* TODO always NULL */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
50 const char *tty = NULL; /* TODO always NULL */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
51
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
52 char portbuf[18];
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
53
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
54 /* db, user, password, host, port */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
55 switch (n) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
56 case 5:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
57 if (lua_isnil(L, 5) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
58 {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
59 int pport = luaL_checkint(L, 5);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
60
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
61 if (pport >= 1 && pport <= 65535) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
62 snprintf(portbuf, sizeof(portbuf), "%d", pport);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
63 port = portbuf;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
64 } else {
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
65 luaL_error(L, DBI_ERR_INVALID_PORT, pport);
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
66 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
67 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
68 case 4:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
69 if (lua_isnil(L, 4) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
70 host = luaL_checkstring(L, 4);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
71 case 3:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
72 if (lua_isnil(L, 3) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
73 password = luaL_checkstring(L, 3);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
74 case 2:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
75 if (lua_isnil(L, 2) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
76 user = luaL_checkstring(L, 2);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
77 case 1:
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
78 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
79 * db is the only mandatory parameter
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
80 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents: 13
diff changeset
81 db = luaL_checkstring(L, 1);
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
82 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
83
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
84 conn = (connection_t *)lua_newuserdata(L, sizeof(connection_t));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
85
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
86 conn->postgresql = PQsetdbLogin(host, port, options, tty, db, user, password);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
87 conn->statement_id = 0;
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
88 conn->autocommit = 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
89 begin(conn);
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
90
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
91 if (PQstatus(conn->postgresql) != CONNECTION_OK) {
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
92 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
93 lua_pushfstring(L, DBI_ERR_CONNECTION_FAILED, PQerrorMessage(conn->postgresql));
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
94 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
95 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
96
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
97 luaL_getmetatable(L, DBD_POSTGRESQL_CONNECTION);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
98 lua_setmetatable(L, -2);
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
99
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
100 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
101 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
102
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
103 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
104 * success = connection:autocommit(on)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
105 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
106 static int connection_autocommit(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
107 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
108 int on = lua_toboolean(L, 2);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
109 int err = 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
110
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
111 if (conn->postgresql) {
44
aab3ed7d93fe Make calling autocommit with the same value as set a NOOP to suppress a warning from the DB
nrich@ii.net
parents: 32
diff changeset
112 if (on != conn->autocommit) {
aab3ed7d93fe Make calling autocommit with the same value as set a NOOP to suppress a warning from the DB
nrich@ii.net
parents: 32
diff changeset
113 if (on)
aab3ed7d93fe Make calling autocommit with the same value as set a NOOP to suppress a warning from the DB
nrich@ii.net
parents: 32
diff changeset
114 err = rollback(conn);
aab3ed7d93fe Make calling autocommit with the same value as set a NOOP to suppress a warning from the DB
nrich@ii.net
parents: 32
diff changeset
115 else
aab3ed7d93fe Make calling autocommit with the same value as set a NOOP to suppress a warning from the DB
nrich@ii.net
parents: 32
diff changeset
116 err = begin(conn);
aab3ed7d93fe Make calling autocommit with the same value as set a NOOP to suppress a warning from the DB
nrich@ii.net
parents: 32
diff changeset
117 }
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
118
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
119 conn->autocommit = on;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
120 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
121
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
122 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
123 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
124 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
125
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
126 /*
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
127 * success = connection:close()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
128 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
129 static int connection_close(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
130 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
131 int disconnect = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
132
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
133 if (conn->postgresql) {
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
134 /*
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
135 * if autocommit is turned off, we probably
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
136 * want to rollback any outstanding transactions.
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
137 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
138 if (!conn->autocommit)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
139 rollback(conn);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
140
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
141 PQfinish(conn->postgresql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
142 disconnect = 1;
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
143 conn->postgresql = NULL;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
144 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
145
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
146 lua_pushboolean(L, disconnect);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
147 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
148 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
149
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
150 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
151 * success = connection:commit()
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
152 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
153 static int connection_commit(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
154 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
155 int err = 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
156
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
157 if (conn->postgresql) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
158 commit(conn);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
159
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
160 if (!conn->autocommit)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
161 err = begin(conn);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
162 else
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
163 err = 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
164 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
165
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
166 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
167 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
168 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
169
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
170 /*
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
171 * ok = connection:ping()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
172 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
173 static int connection_ping(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
174 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
175 int ok = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
176
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
177 if (conn->postgresql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
178 ConnStatusType status = PQstatus(conn->postgresql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
179
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
180 if (status == CONNECTION_OK)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
181 ok = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
182 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
183
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
184 lua_pushboolean(L, ok);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
185 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
186 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
187
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
188 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
189 * statement = connection:prepare(sql_string)
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
190 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
191 static int connection_prepare(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
192 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
193
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
194 if (conn->postgresql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
195 return dbd_postgresql_statement_create(L, conn, luaL_checkstring(L, 2));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
196 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
197
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
198 lua_pushnil(L);
4
c50b0e6f25d6 Clean up error messages for consistency.
nrich@ii.net
parents: 3
diff changeset
199 lua_pushstring(L, DBI_ERR_DB_UNAVAILABLE);
3
b61020ca4753 Cleanup and 'assert' error handling.
nrich@ii.net
parents: 2
diff changeset
200 return 2;
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
201 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
202
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
203 /*
22
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
204 * quoted = connection:quote(str)
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
205 */
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
206 static int connection_quote(lua_State *L) {
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
207 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
208 size_t len;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
209 const char *from = luaL_checklstring(L, 2, &len);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
210 char *to = (char *)calloc(len*2+1, sizeof(char));
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
211 int err = 0;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
212 int quoted_len;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
213
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
214 if (!conn->postgresql) {
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
215 luaL_error(L, DBI_ERR_DB_UNAVAILABLE);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
216 }
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
217
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
218 quoted_len = PQescapeStringConn(conn->postgresql, to, from, len, &err);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
219
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
220 if (err) {
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
221 free(to);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
222
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
223 luaL_error(L, DBI_ERR_QUOTING_STR, PQerrorMessage(conn->postgresql));
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
224 }
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
225
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
226 lua_pushlstring(L, to, quoted_len);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
227 free(to);
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
228
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
229 return 1;
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
230 }
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
231
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
232 /*
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
233 * success = connection:rollback()
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
234 */
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
235 static int connection_rollback(lua_State *L) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
236 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
237 int err = 0;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
238
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
239 if (conn->postgresql) {
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
240 rollback(conn);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
241
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
242 if (!conn->autocommit)
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
243 err = begin(conn);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
244 else
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
245 err = 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
246 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
247
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
248 lua_pushboolean(L, !err);
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
249 return 1;
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
250 }
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
251
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
252 /*
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
253 * __gc
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
254 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
255 static int connection_gc(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
256 /* always close the connection */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
257 connection_close(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
258
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
259 return 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
260 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
261
32
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
262 /*
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
263 * __tostring
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
264 */
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
265 static int connection_tostring(lua_State *L) {
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
266 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
267
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
268 lua_pushfstring(L, "%s: %p", DBD_POSTGRESQL_CONNECTION, conn);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
269
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
270 return 1;
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
271 }
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
272
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
273 int dbd_postgresql_connection(lua_State *L) {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
274 static const luaL_Reg connection_methods[] = {
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
275 {"autocommit", connection_autocommit},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
276 {"close", connection_close},
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
277 {"commit", connection_commit},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
278 {"ping", connection_ping},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
279 {"prepare", connection_prepare},
22
fd78e9cdc6e9 * Added the connection:quote() method
nrich@ii.net
parents: 14
diff changeset
280 {"quote", connection_quote},
13
10c8c6f0da14 Added connection:autocommit(), connection:commit(), and connection:rollback() to control transactions.
nrich@ii.net
parents: 4
diff changeset
281 {"rollback", connection_rollback},
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
282 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
283 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
284
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
285 static const luaL_Reg connection_class_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
286 {"New", connection_new},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
287 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
288 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
289
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
290 luaL_newmetatable(L, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
291 luaL_register(L, 0, connection_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
292 lua_pushvalue(L,-1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
293 lua_setfield(L, -2, "__index");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
294
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
295 lua_pushcfunction(L, connection_gc);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
296 lua_setfield(L, -2, "__gc");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
297
32
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
298 lua_pushcfunction(L, connection_tostring);
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
299 lua_setfield(L, -2, "__tostring");
03ed0ca09837 Add __tostring method to connection and statement objects.
nrich@ii.net
parents: 22
diff changeset
300
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
301 luaL_register(L, DBD_POSTGRESQL_CONNECTION, connection_class_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
302
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
303 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
304 }

mercurial