aboutsummaryrefslogtreecommitdiffstats
path: root/src/charon/plugins/sql/sql_attribute.c
diff options
context:
space:
mode:
authorMartin Willi <martin@strongswan.org>2008-05-09 15:01:22 +0000
committerMartin Willi <martin@strongswan.org>2008-05-09 15:01:22 +0000
commit6cf1215e3ce19e949450c66b7c8fe71bdce6bdd5 (patch)
tree5ffc99aa224725fd1289f9f3c2be8c5b39983883 /src/charon/plugins/sql/sql_attribute.c
parent7051ef40916451ef94f90731d489ffb4ce167d24 (diff)
downloadstrongswan-6cf1215e3ce19e949450c66b7c8fe71bdce6bdd5.tar.bz2
strongswan-6cf1215e3ce19e949450c66b7c8fe71bdce6bdd5.tar.xz
ported IP pool to mysql
Diffstat (limited to 'src/charon/plugins/sql/sql_attribute.c')
-rw-r--r--src/charon/plugins/sql/sql_attribute.c44
1 files changed, 22 insertions, 22 deletions
diff --git a/src/charon/plugins/sql/sql_attribute.c b/src/charon/plugins/sql/sql_attribute.c
index 717d8fe59..7c26d1281 100644
--- a/src/charon/plugins/sql/sql_attribute.c
+++ b/src/charon/plugins/sql/sql_attribute.c
@@ -95,20 +95,20 @@ static host_t* get_lease(private_sql_attribute_t *this,
"JOIN pools AS p ON l.pool = p.id "
"JOIN identities AS i ON l.identity = i.id "
"WHERE p.name = ? AND i.type = ? AND i.data = ? "
- "AND (l.release ISNULL OR p.timeout ISNULL "
- " OR (l.release >= (? - p.timeout))) "
- "ORDER BY l.acquire LIMIT 1", DB_TEXT, name,
+ "AND (l.released IS NULL OR p.timeout IS NULL "
+ " OR (l.released >= (? - p.timeout))) "
+ "ORDER BY l.acquired LIMIT 1", DB_TEXT, name,
DB_INT, id->get_type(id), DB_BLOB, id->get_encoding(id),
DB_UINT, time(NULL),
- DB_INT, DB_BLOB);
+ DB_UINT, DB_BLOB);
if (e)
{
if (e->enumerate(e, &lease, &address))
{
/* found one, set the lease to active */
if (this->db->execute(this->db, NULL,
- "UPDATE leases SET release = NULL WHERE id = ?",
- DB_INT, lease) > 0)
+ "UPDATE leases SET released = NULL WHERE id = ?",
+ DB_UINT, lease) > 0)
{
ip = ip_from_chunk(address);
DBG1(DBG_CFG, "reassigning address from valid lease "
@@ -130,7 +130,7 @@ static host_t* create_lease(private_sql_attribute_t *this,
enumerator_t *e;
chunk_t address;
host_t *ip = NULL;
- int pool, identity = 0;
+ u_int pool, identity = 0, released, timeout;
bool new = FALSE;
/* we currently do not use database transactions. While this would be
@@ -143,22 +143,22 @@ static host_t* create_lease(private_sql_attribute_t *this,
/* find an address which has outdated leases only */
e = this->db->query(this->db,
- "SELECT pool, address FROM leases "
+ "SELECT pool, address, released, timeout FROM leases "
"JOIN pools ON leases.pool = pools.id "
"WHERE name = ? "
- "GROUP BY address HAVING release NOTNULL "
- "AND MAX(release) < ? + pools.timeout LIMIT 1",
+ "GROUP BY address HAVING released IS NOT NULL "
+ "AND MAX(released) < (? + timeout) LIMIT 1",
DB_TEXT, name, DB_UINT, time(NULL),
- DB_INT, DB_BLOB);
+ DB_UINT, DB_BLOB, DB_UINT, DB_UINT);
- if (!e || !e->enumerate(e, &pool, &address))
+ if (!e || !e->enumerate(e, &pool, &address, &released, &timeout))
{
DESTROY_IF(e);
/* no outdated lease found, acquire new address */
e = this->db->query(this->db,
"SELECT id, next FROM pools WHERE name = ? AND next <= end",
DB_TEXT, name,
- DB_INT, DB_BLOB);
+ DB_UINT, DB_BLOB);
if (!e || !e->enumerate(e, &pool, &address))
{
/* pool seems full */
@@ -175,7 +175,7 @@ static host_t* create_lease(private_sql_attribute_t *this,
e = this->db->query(this->db,
"SELECT id FROM identities WHERE type = ? AND data = ?",
DB_INT, id->get_type(id), DB_BLOB, id->get_encoding(id),
- DB_INT);
+ DB_UINT);
if (!e || !e->enumerate(e, &identity))
{
DESTROY_IF(e);
@@ -192,18 +192,18 @@ static host_t* create_lease(private_sql_attribute_t *this,
if (identity)
{
if (this->db->execute(this->db, NULL,
- "INSERT INTO leases (pool, address, identity, acquire) "
- "VALUES (?, ?, ?, ?)",
- DB_INT, pool, DB_BLOB, address, DB_INT, identity,
- DB_UINT, time(NULL)) > 0)
+ "INSERT INTO leases (pool, address, identity, acquired) "
+ "VALUES (?, ?, ?, ?)",
+ DB_UINT, pool, DB_BLOB, address, DB_UINT, identity,
+ DB_UINT, time(NULL)) > 0)
{
ip = ip_from_chunk(address);
if (new)
{ /* update next address, as we have consumed one */
increment_chunk(address);
this->db->execute(this->db, NULL,
- "UPDATE pools set next = ? WHERE id = ?",
- DB_BLOB, address, DB_INT, pool);
+ "UPDATE pools SET next = ? WHERE id = ?",
+ DB_BLOB, address, DB_UINT, pool);
DBG1(DBG_CFG, "assigning lease with new address "
"from pool %s", name);
}
@@ -242,9 +242,9 @@ static bool release_address(private_sql_attribute_t *this,
char *name, host_t *address)
{
if (this->db->execute(this->db, NULL,
- "UPDATE leases SET release = ? WHERE "
+ "UPDATE leases SET released = ? WHERE "
"pool IN (SELECT id FROM pools WHERE name = ?) AND "
- "address = ? AND release ISNULL",
+ "address = ? AND released IS NULL",
DB_UINT, time(NULL),
DB_TEXT, name, DB_BLOB, address->get_address(address)) > 0)
{