prefix."ad_buttons"; $structure = "CREATE TABLE $table ( id INT(9) NOT NULL AUTO_INCREMENT, ad_picture VARCHAR(100) NOT NULL, ad_link VARCHAR(500) NOT NULL, ad_text VARCHAR(80) NOT NULL, ad_strdat DATE NOT NULL, ad_enddat DATE NOT NULL, ad_views INT(9) DEFAULT 0, ad_clicks INT(9) DEFAULT 0, ad_active TINYINT(1) NOT NULL DEFAULT 0, adg_count VARCHAR(500) NOT NULL, adg_show tinytext NOT NULL, ad_pos INT(9) DEFAULT 0, UNIQUE KEY id (id) );"; require_once(ABSPATH . 'wp-admin/includes/upgrade.php'); dbDelta($structure); $wpdb->query("INSERT INTO $table(id, ad_picture, ad_link, ad_text, ad_views, ad_clicks, ad_active) VALUES(1, 'http://blogio.net/ad_buttons_125.jpg', 'http://blogio.net/blog/wp-ad-plugin/', 'ads powered by Ad Buttons', 1, 0, 1)"); $table = $wpdb->prefix."ad_buttons_stats"; $structure = "CREATE TABLE $table ( abs_dat date NOT NULL, abs_ip int(10) NOT NULL, abs_view tinyint(4) NOT NULL, abs_click tinyint(4) NOT NULL, KEY abs_dat (abs_dat) );"; require_once(ABSPATH . 'wp-admin/includes/upgrade.php'); dbDelta($structure); $ad_buttons_db_version = "1.7"; update_option("ad_buttons_db_version", $ad_buttons_db_version); $ip2nation_db_version = "2.1.7"; update_option("ip2nation_db_available", $ip2nation_db_version); } register_activation_hook(__FILE__,'ad_buttons_install'); //check if user is a bot of some sort function is_bot() { $bots = array('google','yahoo','msn','jeeves','lycos','ArchitectSpider','whatuseek','BSDSeek','BullsEye'); //takes the list above and returns (google)|(yahoo)|(msn)... $regex = '('.implode($bots, ')|(').')'; //uses the generated regex above to see if those keywords are contained in the user agent variable return eregi($regex, $_SERVER['HTTP_USER_AGENT']); } function ab_show_ad($ad_id) { global $wpdb; global $ab_geot; // check if geo targeting has been enabled if(!$ab_geot) return(1); // check if this button has geo targeting information stored at all $results = $wpdb->get_results("SELECT * FROM ".$wpdb->prefix."ad_buttons WHERE id = $ad_id LIMIT 1"); foreach($results as $result){ $adg_count = $result->adg_count; $adg_show = $result->adg_show; } if(!$adg_count) return(1); if(!$adg_show) return(1); $sql = 'SELECT country FROM ip2nation WHERE ip < INET_ATON("'.$_SERVER['REMOTE_ADDR'].'") ORDER BY ip DESC LIMIT 0,1'; list($country) = mysql_fetch_row(mysql_query($sql)); if(stristr($adg_count, $country) === FALSE) { if($adg_show == 's'){ return(0); } else { return(1); } } else { if($adg_show == 's'){ return(1); } else { return(0); } } } function ad_buttons() { global $wpdb; global $ab_geot; $widget_adbuttons_cfg = array( 'ab_title' => '', 'ab_dspcnt' => '', 'ab_target' => '', 'ab_adsense' => '', 'ab_adsense_fixed' => '', 'ab_adsense_pos' => '', 'ab_adsense_pubid' => '', 'ab_adsense_channel' => '', 'ab_adsense_corners' => '', 'ab_adsense_col_border' => '', 'ab_adsense_col_title' => '', 'ab_adsense_col_bg' => '', 'ab_adsense_col_txt' => '', 'ab_adsense_col_url' => '', 'ab_nocss' => '', 'ab_width' => '', 'ab_padding' => '', 'ab_nofollow' => '', 'ab_powered' => '', 'ab_yah' => '', 'ab_yourad' => '', 'ab_geot' => '', 'ab_yaht' => '', 'ab_yahurl' => '', 'ab_anet' => '', 'ab_anetu' => '', 'ab_anett' => '', 'ab_fix' => '' ); $widget_adbuttons_cfg = get_option('widget_adbuttons_cfg'); $wp_root = get_option('home'); $ab_geot = $widget_adbuttons_cfg['ab_geot']; if($widget_adbuttons_cfg['ab_nofollow']){ $ab_nofollow = ' rel="nofollow" '; } if($widget_adbuttons_cfg['ab_powered']){ if($widget_adbuttons_cfg['ab_nocss']){ $ab_powered = 'powered by Ad Buttons'; } else { $ab_powered = '
powered by Ad Buttons
'; } } if($widget_adbuttons_cfg['ab_adsense']){ if($widget_adbuttons_cfg['ab_nocss']){ $ab_adsensecss = ''; $ab_adsenseenddiv = ''; }else{ $ab_adsensecss = '
'; $ab_adsenseenddiv = '
'; } $ab_adsense_ad = $ab_adsensecss.' '.$ab_adsenseenddiv; } if($widget_adbuttons_cfg['ab_target'] == 'bnk'){ $target = " target=\"_blank\" "; } elseif($widget_adbuttons_cfg['ab_target'] == 'top'){ $target = " target=\"_top\" "; } elseif($widget_adbuttons_cfg['ab_target'] == 'non'){ $target = " "; } if($widget_adbuttons_cfg['ab_adsense']){ $ab_count = 1; } else { $ab_count = 0; } echo' '; if(!$widget_adbuttons_cfg['ab_nocss']){ echo '
'; } if($widget_adbuttons_cfg['ab_fix']){ $results = $wpdb->get_results("SELECT * FROM ".$wpdb->prefix."ad_buttons WHERE ad_active = 1 AND ad_strdat <= CURDATE() AND ad_enddat > CURDATE() OR ad_active = 1 AND ad_strdat <= CURDATE() AND ad_enddat = '0000-00-00' ORDER BY ad_pos"); }else{ $results = $wpdb->get_results("SELECT * FROM ".$wpdb->prefix."ad_buttons WHERE ad_active = 1 AND ad_strdat <= CURDATE() AND ad_enddat > CURDATE() OR ad_active = 1 AND ad_strdat <= CURDATE() AND ad_enddat = '0000-00-00' ORDER BY RAND()"); } foreach($results as $result){ if ($ab_count < $widget_adbuttons_cfg['ab_dspcnt']) { if($widget_adbuttons_cfg['ab_adsense']){ if($widget_adbuttons_cfg['ab_adsense_pos']==$ab_count){ echo $ab_adsense_ad; } } if(ab_show_ad($result->id)) { echo"id\" $target title=\"$result->ad_text\" $ab_nofollow>ad_picture\" alt=\"$result->ad_text\" vspace=\"1\" hspace=\"1\" border=\"0\">"; $ab_count = $ab_count + 1; // update view counter on the ad button if(!is_bot()) { $wpdb->query("UPDATE ".$wpdb->prefix."ad_buttons SET ad_views = ad_views + 1 WHERE id = ".$result->id); $ab_ip = ip2long($_SERVER['REMOTE_ADDR']); $wpdb->query("INSERT INTO ".$wpdb->prefix."ad_buttons_stats(abs_dat, abs_ip, abs_view) VALUES(CURDATE(), '$ab_ip', ".$result->id.")"); } } } } if($widget_adbuttons_cfg['ab_adsense']){ if($widget_adbuttons_cfg['ab_adsense_pos']==$ab_count){ echo $ab_adsense_ad; } } if($widget_adbuttons_cfg['ab_anet']){ $length = 10; $chars = 'abcdefghijklmnoqrstuvwxyz1234567890'; // Length of character list $chars_length = (strlen($chars) - 1); // Start our string $string = $chars{rand(0, $chars_length)}; // Generate random string for ($i = 1; $i < $length; $i = strlen($string)) { // Grab a random character from our list $r = $chars{rand(0, $chars_length)}; // Make sure the same two characters don't appear next to each other if ($r != $string{$i - 1}) $string .= $r; } $string = $string.$widget_adbuttons_cfg['ab_anetu']; if ($widget_adbuttons_cfg['ab_anett']){ $string = $string.'t'.$widget_adbuttons_cfg['ab_anett']; } echo''; } if($widget_adbuttons_cfg['ab_yah']){ $ab_plugindir = get_option('siteurl').'/'.PLUGINDIR.'/'.dirname(plugin_basename(__FILE__)); if($widget_adbuttons_cfg['ab_yaht'] == 'url'){ echo'Advertise here'; } else { echo'Advertise here'; } } if($widget_adbuttons_cfg['ab_nocss']){ echo $ab_powered; }else{ echo ''.$ab_powered.'
'; } } function ad_buttons_settings() { global $wpdb; include 'adbuttonsadmin.php'; } function ad_buttons_stats() { global $wpdb; include 'adbuttonsstats.php'; } function ad_buttons_top() { global $wpdb; include 'adbuttonstop.php'; } function ad_buttons_act() { global $wpdb; include 'adbuttonsact.php'; } function ad_buttons_stats_actions() { add_menu_page('Ad Buttons', 'Ad Buttons', 9, __FILE__, 'ad_buttons_act', get_option('siteurl').'/'.PLUGINDIR.'/'.dirname(plugin_basename(__FILE__)).'/ad_buttons_icon.png'); // Add a submenu to the custom top-level menu: add_submenu_page(__FILE__, 'Ad Buttons Settings', 'Settings', 9, 'ad-buttons-settings', 'ad_buttons_settings'); add_submenu_page(__FILE__, 'Ad Buttons Stats', 'Stats', 9, 'ad-buttons-stats', 'ad_buttons_stats'); } add_action('admin_menu', 'ad_buttons_stats_actions'); // process ad clicks function adbuttons_getclick() { global $wpdb; if(isset($_GET['recommends'])) { $ad_id = $_GET['recommends']; if(is_numeric($ad_id)){ $results = $wpdb->get_results("SELECT ad_link FROM ".$wpdb->prefix."ad_buttons WHERE id = $ad_id LIMIT 1"); foreach($results as $result){ $send_to_url = $result->ad_link; if(!is_bot()) { $wpdb->query("UPDATE ".$wpdb->prefix."ad_buttons SET ad_clicks = ad_clicks + 1 WHERE id = ".$ad_id); $ab_ip = ip2long($_SERVER['REMOTE_ADDR']); $wpdb->query("INSERT INTO ".$wpdb->prefix."ad_buttons_stats(abs_dat, abs_ip, abs_click) VALUES(CURDATE(), '$ab_ip', ".$ad_id.")"); } //redirect header("Location: ".$send_to_url); exit(0); } } } } // widget function widget_init_adbuttons_widget() { // Check for required functions if (!function_exists('register_sidebar_widget')) return; function adbuttons_widget($args){ extract($args); $options = get_option('widget_adbuttons_cfg'); $title = empty($options['ab_title']) ? __('Sponsored Links') : $options['ab_title']; ?>


That's all you can set here. All other options and ad controls can be found in the Ad Buttons menu located on the far left side of this page.