. */ // No direct call if( !defined( 'YOURLS_ABSPATH' ) ) die(); // Hook the custom function into the 'pre_check_domain_flood' event yourls_add_filter( 'shunt_add_new_link', 'apelly_blacklist_domain_root' ); // Hook the admin page into the 'plugins_loaded' event yourls_add_action( 'plugins_loaded', 'apelly_blacklist_domain_add_page' ); // Get blacklisted domains from YOURLS options feature and compare with current domain address function apelly_blacklist_domain_root ( $bol, $url ) { $parse = parse_url($url); $domain = str_ireplace('www.', '', parse_url($url, PHP_URL_HOST)); $domain = str_ireplace('http://', '', parse_url($url, PHP_URL_HOST)); $domain = str_ireplace('https://', '', parse_url($url, PHP_URL_HOST)); $return = false; $domain_list = yourls_get_option ('apelly_blacklist_domain_list'); if ( $domain_list ) { $domain_list_display = unserialize ( $domain_list ); if (strpos($domain_list_display,$domain) === true) { // Check if a YourlsBlacklistIPs is installed and active if (yourls_is_active_plugin( YOURLS_PLUGINDIR .'/BlackListIP/plugin.php' )) { // fetch the blacklisted IP addresses $IP_List = yourls_get_option ('ludo_blacklist_ip_liste'); $IP_List = ( $IP_List ) ? ( unserialize ( $IP_List ) ):((array)NULL); // add this IP $IP = yourls_get_IP(); $Parsed_IP = ludo_blacklist_ip_Analyze_IP ( $IP ) ; if ( $Parsed_IP != "NULL" ) { $IPList[] = $Parsed_IP ; } // Update the blacklist yourls_update_option ( 'ludo_blacklist_ip_liste', serialize ( $IP_List ) ); } // stop //yourls_die( 'Blacklisted domain', 'Forbidden', 403 ); echo "
Blacklisted domain.
"; die(); } } return $return; } // Add admin page function apelly_blacklist_domain_add_page () { yourls_register_plugin_page( 'apelly_blacklist_domain', 'Blacklist domains', 'apelly_blacklist_domain_do_page' ); } // Display admin page function apelly_blacklist_domain_do_page () { if( isset( $_POST['action'] ) && $_POST['action'] == 'blacklist_domain' ) { apelly_blacklist_domain_process (); } else { apelly_blacklist_domain_form (); } } // Display form to administrate blacklisted domains list function apelly_blacklist_domain_form () { $nonce = yourls_create_nonce( 'blacklist_domain' ) ; $domain_list = yourls_get_option ('apelly_blacklist_domain_list','Enter domain addresses here, one per line'); if ($domain_list != 'Enter domain addresses here, one per line' ){ $domain_list_display = unserialize ( $domain_list ); }else{ $domain_list_display = $domain_list; } echo <<BlackList domains

Blacklist following domains

HTML; } // Update blacklisted domains list function apelly_blacklist_domain_process () { // Check nonce yourls_verify_nonce( 'blacklist_domain' ) ; // Update list $sent_list = serialize($_POST['blacklist_form']); yourls_update_option ( 'apelly_blacklist_domain_list',$sent_list ); echo "Black list updated. New blacklist is " ; if ( count ( $IPList ) == 0 ) echo "sent_list."; else { echo ":
"; foreach ($sent_list as $value) echo $value."
"; } } ?>