dbd/postgresql/connection.c

Sun, 23 Nov 2008 04:12:04 +0000

author
nrich@ii.net
date
Sun, 23 Nov 2008 04:12:04 +0000
changeset 2
c4f02fc67e5a
parent 1
408291a6eb3e
child 3
b61020ca4753
permissions
-rw-r--r--

Cleanup and commenting

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
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
5 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
6 * connection = DBD.PostgreSQL.New(dbname, user, password, host, port)
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
7 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
8 static int connection_new(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
9 int n = lua_gettop(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
10 connection_t *conn = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
11
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
12 const char *host = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
13 const char *user = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
14 const char *password = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
15 const char *db = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
16 const char *port = NULL;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
17
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
18 const char *options = NULL; /* TODO always NULL */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
19 const char *tty = NULL; /* TODO always NULL */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
20
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
21 char portbuf[18];
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
22
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
23 /* db, user, password, host, port */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
24 switch (n) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
25 case 5:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
26 if (lua_isnil(L, 5) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
27 {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
28 int pport = luaL_checkint(L, 5);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
29
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
30 if (pport >= 1 && pport <= 65535) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
31 snprintf(portbuf, sizeof(portbuf), "%d", pport);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
32 port = portbuf;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
33 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
34 luaL_error(L, "Invalid port %d", pport);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
35 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
36 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
37 case 4:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
38 if (lua_isnil(L, 4) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
39 host = luaL_checkstring(L, 4);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
40 case 3:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
41 if (lua_isnil(L, 3) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
42 password = luaL_checkstring(L, 3);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
43 case 2:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
44 if (lua_isnil(L, 2) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
45 user = luaL_checkstring(L, 2);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
46 case 1:
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
47 if (lua_isnil(L, 1) == 0)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
48 db = luaL_checkstring(L, 1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
49 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
50
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
51 conn = (connection_t *)lua_newuserdata(L, sizeof(connection_t));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
52
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
53 conn->postgresql = PQsetdbLogin(host, port, options, tty, db, user, password);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
54 conn->statement_id = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
55
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
56 if (PQstatus(conn->postgresql) == CONNECTION_OK) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
57 luaL_getmetatable(L, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
58 lua_setmetatable(L, -2);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
59 } else {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
60 luaL_error(L, "Failed to connect to database: %s", PQerrorMessage(conn->postgresql));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
61 lua_pushnil(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
62 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
63
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
64 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
65 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
66
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
67 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
68 * success = connection:close()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
69 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
70 static int connection_close(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
71 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
72 int disconnect = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
73
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
74 if (conn->postgresql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
75 PQfinish(conn->postgresql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
76 disconnect = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
77 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
78
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
79 lua_pushboolean(L, disconnect);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
80 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
81 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
82
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
83 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
84 * ok = connection:ping()
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
85 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
86 static int connection_ping(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
87 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
88 int ok = 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
89
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
90 if (conn->postgresql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
91 ConnStatusType status = PQstatus(conn->postgresql);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
92
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
93 if (status == CONNECTION_OK)
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
94 ok = 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
95 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
96
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
97 lua_pushboolean(L, ok);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
98 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
99 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
100
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
101 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
102 * statement = connection:prepare(sql_string)
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
103 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
104 static int connection_prepare(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
105 connection_t *conn = (connection_t *)luaL_checkudata(L, 1, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
106
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
107 if (conn->postgresql) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
108 return dbd_postgresql_statement_create(L, conn, luaL_checkstring(L, 2));
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
109 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
110
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
111 lua_pushnil(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
112 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
113 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
114
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
115 /*
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
116 * __gc
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
117 */
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
118 static int connection_gc(lua_State *L) {
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
119 /* always close the connection */
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
120 connection_close(L);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
121
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
122 return 0;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
123 }
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
124
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
125 int dbd_postgresql_connection(lua_State *L) {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
126 static const luaL_Reg connection_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
127 {"close", connection_close},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
128 {"ping", connection_ping},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
129 {"prepare", connection_prepare},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
130 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
131 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
132
2
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
133 static const luaL_Reg connection_class_methods[] = {
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
134 {"New", connection_new},
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
135 {NULL, NULL}
c4f02fc67e5a Cleanup and commenting
nrich@ii.net
parents: 1
diff changeset
136 };
1
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
137
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
138 luaL_newmetatable(L, DBD_POSTGRESQL_CONNECTION);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
139 luaL_register(L, 0, connection_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
140 lua_pushvalue(L,-1);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
141 lua_setfield(L, -2, "__index");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
142
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
143 lua_pushcfunction(L, connection_gc);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
144 lua_setfield(L, -2, "__gc");
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
145
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
146 luaL_register(L, DBD_POSTGRESQL_CONNECTION, connection_class_methods);
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
147
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
148 return 1;
408291a6eb3e Initial import.
nrich@ii.net
parents:
diff changeset
149 }

mercurial