plugin-wonderful/classes/PWAdboxesClient.php

190 lines
5.0 KiB
PHP
Raw Normal View History

2009-02-07 00:10:58 +00:00
<?php
require_once('PublisherInfo.php');
define("PLUGIN_WONDERFUL_DATABASE_VERSION", 3);
2009-02-13 01:07:23 +00:00
2009-02-07 00:10:58 +00:00
/**
* The interface to the PW database table.
*/
class PWAdboxesClient {
var $table_name;
function PWAdboxesClient() {
global $wpdb;
$this->table_name = $wpdb->prefix . "pw_adboxes";
$this->table_exists = false;
}
/**
* Initialize the table if it doesn't exist.
*/
function initialize() {
global $wpdb;
if ($wpdb->get_var("SHOW TABLES LIKE {$this->table_name}") != $this->table_name) {
if (!$wpdb->is_mock) {
$sql = "CREATE TABLE {$this->table_name} (
type int(1) NOT NULL,
adboxid int(11) NOT NULL,
sitename char(100) NOT NULL,
2009-02-11 23:24:42 +00:00
adtype char(30) NOT NULL,
2009-02-07 00:10:58 +00:00
url char(255) NOT NULL,
dimensions char(10) NOT NULL,
rating char(30) NOT NULL,
category char(50) NOT NULL,
2009-02-07 00:10:58 +00:00
description text NOT NULL,
tags text NOT NULL,
standardcode text NOT NULL,
2009-02-13 01:07:23 +00:00
advancedcode text NOT NULL,
template_tag_id char(30),
in_rss_feed int(1)
2009-02-07 00:10:58 +00:00
);";
require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
dbDelta($sql);
}
}
}
/**
* Destroy the table.
*/
function destroy() {
global $wpdb;
$wpdb->query("DROP TABLE {$this->table_name}");
}
/**
* Post PublisherInfo to the database.
* @param PublisherInfo $ads The PublisherInfo to post to the database.
* @param integer $type The ad type.
*/
function post_ads($ads, $type = PW_ADBOXES_PROJECT_WONDERFUL) {
global $wpdb;
if (is_a($ads, 'PublisherInfo')) {
if ($ads->is_valid) {
2009-02-13 01:07:23 +00:00
$mappings = array();
if (is_array($results = $wpdb->get_results("SELECT adboxid, template_tag_id, in_rss_feed FROM {$this->table_name}"))) {
foreach ($results as $result) {
$mappings[$result->adboxid] = $result;
}
}
2009-02-07 00:10:58 +00:00
$wpdb->query("DELETE FROM {$this->table_name} WHERE type = $type");
foreach ($ads->adboxes as $box) {
$columns = array("type");
$values = array($type);
2009-02-13 01:07:23 +00:00
if (isset($mappings[$box->adboxid])) {
foreach ((array)$mappings[$box->adboxid] as $key => $value) {
$box->{$key} = $value;
}
}
2009-02-07 00:10:58 +00:00
foreach ((array)$box as $key => $value) {
if ($key !== "type") {
$columns[] = $key;
$values[] = '"' . $wpdb->escape($value) . '"';
}
}
2009-02-13 01:07:23 +00:00
if (!$wpdb->query("INSERT INTO {$this->table_name} (" . implode(",", $columns) . ") VALUES (" . implode(",", $values) . ")")) {
return false;
}
2009-02-07 00:10:58 +00:00
}
2009-02-13 01:07:23 +00:00
return true;
2009-02-07 00:10:58 +00:00
}
}
2009-02-13 01:07:23 +00:00
return false;
2009-02-07 00:10:58 +00:00
}
2009-02-13 01:07:23 +00:00
function _handle_ad_retrieval($member_id, $query) {
2009-02-07 00:10:58 +00:00
global $wpdb;
if (count($results = $wpdb->get_results($query)) > 0) {
$ads = new PublisherInfo();
$ads->memberid = $member_id;
$ads->adboxes = $results;
$ads->is_valid = true;
return $ads;
}
return false;
}
2009-02-13 01:07:23 +00:00
/**
* Retrieve all ads from the database and create a new PublisherInfo object.
* @param integer $member_id The Project Wonderful member ID to use.
* @return PublisherInfo The PublisherInfo object for the ads, or false if no ads are found.
*/
function get_ads($member_id, $type = null) {
global $wpdb;
$query = "SELECT * FROM {$this->table_name}";
if (!is_null($type)) { $query .= " WHERE type = {$type}"; }
$query .= " ORDER BY adboxid ASC";
return $this->_handle_ad_retrieval($member_id, $query);
}
2009-02-07 00:10:58 +00:00
/**
* Remove all ads from the database.
*/
function clean_ads() {
global $wpdb;
$wpdb->query("DELETE FROM {$this->table_name}");
}
2009-02-13 01:07:23 +00:00
/**
* Set the template tag id for an advertisement.
*/
function set_template_tag($adboxid, $tag) {
global $wpdb;
$query = "UPDATE {$this->table_name} SET ";
$query .= "template_tag_id = '" . $wpdb->escape($tag) . "'";
$query .= " WHERE adboxid = '" . $wpdb->escape($adboxid) . "'";
$query .= " ORDER BY adboxid ASC";
$result = $wpdb->get_results($query);
return count($result) > 0;
}
/**
* Get an adbox by template tag id.
*/
function get_ad_by_template_tag($member_id, $tag) {
global $wpdb;
$query = "SELECT * FROM {$this->table_name} WHERE template_tag_id = '" . $wpdb->escape($tag) . "'";
if (($result = $this->_handle_ad_retrieval($member_id, $query)) !== false) {
return reset($result->adboxes);
} else {
return false;
}
}
/**
* Enable or disable RSS feed usage.
*/
function set_rss_feed_usage($adboxid, $status = false) {
global $wpdb;
$query = "UPDATE {$this->table_name} SET ";
$query .= "in_rss_feed = '" . ($status ? 1 : 0) . "'";
$query .= " WHERE adboxid = '" . $wpdb->escape($adboxid) . "'";
$result = $wpdb->get_results($query);
return count($result) > 0;
}
2009-02-07 00:10:58 +00:00
}
?>