2012-03-25 01:49:21 +00:00
< ? php
/**
* Debug / Status page
*
* @ author WooThemes
* @ category Admin
* @ package WooCommerce
*/
function woocommerce_debug () {
global $woocommerce ;
?>
< div class = " wrap woocommerce " >
2012-04-10 17:13:31 +00:00
< div class = " icon32 icon32-woocommerce-status " id = " icon-woocommerce " >< br /></ div >
2012-03-25 01:49:21 +00:00
< h2 >< ? php _e ( 'Debugging Information' , 'woocommerce' ); ?> <a href="#" class="add-new-h2 debug-report"><?php _e('Generate report', 'woocommerce'); ?></a></h2>
< ? php
if ( ! empty ( $_GET [ 'action' ] ) && ! empty ( $_REQUEST [ '_wpnonce' ] ) && wp_verify_nonce ( $_REQUEST [ '_wpnonce' ], 'debug_action' ) ) {
switch ( $_GET [ 'action' ] ) {
case " clear_transients " :
$woocommerce -> clear_product_transients ();
echo '<div class="updated"><p>' . __ ( 'Product Transients Cleared' , 'woocommerce' ) . '</p></div>' ;
break ;
case " reset_roles " :
global $wp_roles ;
// Roles
remove_role ( 'customer' );
remove_role ( 'shop_manager' );
// Capabilities
$wp_roles -> remove_cap ( 'administrator' , 'manage_woocommerce' );
$woocommerce -> init_user_roles ();
echo '<div class="updated"><p>' . __ ( 'Roles successfully reset' , 'woocommerce' ) . '</p></div>' ;
break ;
}
}
?>
< br />
< textarea id = " debug-report " readonly = " readonly " ></ textarea >
< table class = " wc_status_table widefat " cellspacing = " 0 " >
< thead >
< tr >
< th colspan = " 2 " >< ? php _e ( 'Versions' , 'woocommerce' ); ?> </th>
</ tr >
</ thead >
< tbody >
< tr class = " alternate " >
< td >< ? php _e ( 'WooCommerce version' , 'woocommerce' ) ?> </td>
< td >< ? php echo $woocommerce -> version ; ?> </td>
</ tr >
< tr >
< td >< ? php _e ( 'WordPress version' , 'woocommerce' ) ?> </td>
< td >< ? php if ( is_multisite () ) echo 'WPMU' ; else echo 'WP' ; ?> <?php echo bloginfo('version'); ?></td>
</ tr >
< tr class = " alternate " >
< td >< ? php _e ( 'Installed plugins' , 'woocommerce' ) ?> </td>
< td >< ? php
$active_plugins = ( array ) get_option ( 'active_plugins' , array () );
if ( is_multisite () )
$active_plugins = array_merge ( $active_plugins , get_site_option ( 'active_sitewide_plugins' , array () ) );
$active_plugins = array_map ( 'strtolower' , $active_plugins );
$wc_plugins = array ();
foreach ( $active_plugins as $plugin ) {
//if ( strstr( $plugin, 'woocommerce' ) ) {
$plugin_data = @ get_plugin_data ( WP_PLUGIN_DIR . '/' . $plugin );
if ( ! empty ( $plugin_data [ 'Name' ] ) ) {
$wc_plugins [] = $plugin_data [ 'Name' ] . ' ' . __ ( 'by' , 'woocommerce' ) . ' ' . $plugin_data [ 'Author' ] . ' ' . __ ( 'version' , 'woocommerce' ) . ' ' . $plugin_data [ 'Version' ];
}
//}
}
if ( sizeof ( $wc_plugins ) == 0 ) echo '-' ; else echo '<ul><li>' . implode ( ', </li><li>' , $wc_plugins ) . '</li></ul>' ;
?> </td>
</ tr >
</ tbody >
< thead >
< tr >
< th colspan = " 2 " >< ? php _e ( 'Settings' , 'woocommerce' ); ?> </th>
</ tr >
</ thead >
< tbody >
< tr class = " alternate " >
< td >< ? php _e ( 'Home URL' , 'woocommerce' ) ?> </td>
< td >< ? php echo home_url (); ?> </td>
</ tr >
< tr >
< td >< ? php _e ( 'Site URL' , 'woocommerce' ) ?> </td>
< td >< ? php echo site_url (); ?> </td>
</ tr >
< tr class = " alternate " >
< td >< ? php _e ( 'Force SSL' , 'woocommerce' ) ?> </td>
< td >< ? php echo ucwords ( get_option ( 'woocommerce_force_ssl_checkout' )); ?> </td>
</ tr >
</ tbody >
< thead >
< tr >
< th colspan = " 2 " >< ? php _e ( 'Shop Pages' , 'woocommerce' ); ?> </th>
</ tr >
</ thead >
< tbody >
< ? php
$check_pages = array (
__ ( 'Shop base page' , 'woocommerce' ) => array (
'option' => 'woocommerce_shop_page_id' ,
'shortcode' => ''
),
__ ( 'Cart Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_cart_page_id' ,
'shortcode' => '[woocommerce_cart]'
),
__ ( 'Checkout Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_checkout_page_id' ,
'shortcode' => '[woocommerce_checkout]'
),
__ ( 'Pay Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_pay_page_id' ,
'shortcode' => '[woocommerce_pay]'
),
__ ( 'Thanks Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_thanks_page_id' ,
'shortcode' => '[woocommerce_thankyou]'
),
__ ( 'My Account Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_myaccount_page_id' ,
'shortcode' => '[woocommerce_my_account]'
),
__ ( 'Edit Address Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_edit_address_page_id' ,
'shortcode' => '[woocommerce_edit_address]'
),
__ ( 'View Order Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_view_order_page_id' ,
'shortcode' => '[woocommerce_view_order]'
),
__ ( 'Change Password Page' , 'woocommerce' ) => array (
'option' => 'woocommerce_change_password_page_id' ,
'shortcode' => '[woocommerce_change_password]'
)
);
$alt = 1 ;
foreach ( $check_pages as $page_name => $values ) {
if ( $alt == 1 ) echo '<tr class="alternate">' ; else echo '<tr>' ;
echo '<td>' . $page_name . '</td><td>' ;
$error = false ;
$page_id = get_option ( $values [ 'option' ]);
// Page ID check
if ( ! $page_id ) {
echo '<mark class="error">' . __ ( 'Page not set' , 'woocommerce' ) . '</mark>' ;
$error = true ;
} else {
// Shortcode check
if ( $values [ 'shortcode' ] ) {
$page = get_post ( $page_id );
if ( ! strstr ( $page -> post_content , $values [ 'shortcode' ] ) ) {
echo '<mark class="error">' . sprintf ( __ ( 'Page does not contain the shortcode: %s' , 'woocommerce' ), $values [ 'shortcode' ] ) . '</mark>' ;
$error = true ;
}
}
}
if ( ! $error ) echo '<mark class="yes">#' . $page_id . ' - ' . get_permalink ( $page_id ) . '</mark>' ;
echo '</td></tr>' ;
$alt = $alt * - 1 ;
}
?>
</ tbody >
< thead >
< tr >
< th colspan = " 2 " >< ? php _e ( 'Server Environment' , 'woocommerce' ); ?> </th>
</ tr >
</ thead >
< tbody >
< tr class = " alternate " >
< td >< ? php _e ( 'PHP Version' , 'woocommerce' ) ?> </td>
< td >< ? php
if ( function_exists ( 'phpversion' ) ) echo phpversion ();
?> </td>
</ tr >
< tr >
< td >< ? php _e ( 'Server Software' , 'woocommerce' ) ?> </td>
< td >< ? php
echo $_SERVER [ 'SERVER_SOFTWARE' ];
?> </td>
</ tr >
< tr class = " alternate " >
< td >< ? php _e ( 'WP Max Upload Size' , 'woocommerce' ); ?> </td>
< td >< ? php
echo wp_convert_bytes_to_hr ( wp_max_upload_size () );
?> </td>
</ tr >
< tr >
< td >< ? php _e ( 'Server upload_max_filesize' , 'woocommerce' ) ?> </td>
< td >< ? php
if ( function_exists ( 'phpversion' ))
echo wp_convert_bytes_to_hr ( woocommerce_let_to_num ( ini_get ( 'upload_max_filesize' ) ) );
?> </td>
</ tr >
< tr class = " alternate " >
< td >< ? php _e ( 'Server post_max_size' , 'woocommerce' ) ?> </td>
< td >< ? php
if ( function_exists ( 'phpversion' ))
echo wp_convert_bytes_to_hr ( woocommerce_let_to_num ( ini_get ( 'post_max_size' ) ) );
?> </td>
</ tr >
< tr >
< td >< ? php _e ( 'WP Memory Limit' , 'woocommerce' ) ?> </td>
< td >< ? php
echo wp_convert_bytes_to_hr ( woocommerce_let_to_num ( WP_MEMORY_LIMIT ) );
?> </td>
</ tr >
< tr class = " alternate " >
< td >< ? php _e ( 'WP Debug Mode' , 'woocommerce' ) ?> </td>
< td >< ? php if ( defined ( 'WP_DEBUG' ) && WP_DEBUG ) echo '<mark class="yes">' . __ ( 'Yes' , 'woocommerce' ) . '</mark>' ; else echo '<mark class="no">' . __ ( 'No' , 'woocommerce' ) . '</mark>' ; ?> </td>
</ tr >
< tr >
< td >< ? php _e ( 'WC Logging' , 'woocommerce' ) ?> </td>
< td >< ? php
if ( @ fopen ( $woocommerce -> plugin_path () . '/logs/paypal.txt' , 'a' ) )
echo '<mark class="yes">' . __ ( 'Log directory is writable.' , 'woocommerce' ) . '</mark>' ;
else
echo '<mark class="error">' . __ ( 'Log directory (<code>woocommerce/logs/</code>) is not writable. Logging will not be possible.' , 'woocommerce' ) . '</mark>' ;
?> </td>
</ tr >
</ tbody >
< thead >
< tr >
< th colspan = " 2 " >< ? php _e ( 'PHP Sessions' , 'woocommerce' ); ?> </th>
</ tr >
</ thead >
< tbody >
< tr class = " alternate " >
< td >< ? php _e ( 'Session save path' , 'woocommerce' ) ?> </td>
< td >< ? php
$save_path = session_save_path ();
if ( ! is_dir ( $save_path ) ) {
echo '<mark class="error">' . sprintf ( __ ( '<code>%s</code> does not exist - contact your host to resolve the problem.' , 'woocommerce' ), $save_path ) . '</mark>' ;
} elseif ( ! is_writeable ( $save_path ) ) {
echo '<mark class="error">' . sprintf ( __ ( '<code>%s</code> is not writable - contact your host to resolve the problem.' , 'woocommerce' ), $save_path ) . '</mark>' ;
} else {
echo '<mark class="yes">' . sprintf ( __ ( '<code>%s</code> is writable.' , 'woocommerce' ), $save_path ) . '</mark>' ;
}
?> </td>
</ tr >
</ tbody >
< thead >
< tr >
< th colspan = " 2 " >< ? php _e ( 'Remote Posting/IPN' , 'woocommerce' ); ?> </th>
</ tr >
</ thead >
< tbody >
< tr class = " alternate " >
< td >< ? php _e ( 'fsockopen/Curl' , 'woocommerce' ) ?> </td>
< td >< ? php
if ( function_exists ( 'fsockopen' ) || function_exists ( 'curl_init' ) )
echo '<mark class="yes">' . __ ( 'Your server has fsockopen or Curl enabled.' , 'woocommerce' ) . '</mark>' ;
else
echo '<mark class="error">' . __ ( 'Your server does not have fsockopen or Curl enabled - PayPal IPN and other scripts which communicate with other servers will not work. Contact your hosting provider.' , 'woocommerce' ) . '</mark>' ; ?> </td>
</ tr >
< tr >
< td >< ? php _e ( 'WP Remote Post Check' , 'woocommerce' ) ?> </td>
< td >< ? php
$params = array (
'sslverify' => false ,
'timeout' => 30 ,
'user-agent' => 'WooCommerce/' . $woocommerce -> version
);
$response = wp_remote_post ( 'https://www.paypal.com/cgi-bin/webscr' , $params );
if ( ! is_wp_error ( $response ) && $response [ 'response' ][ 'code' ] >= 200 && $response [ 'response' ][ 'code' ] < 300 )
echo '<mark class="yes">' . __ ( 'wp_remote_post() was successful - PayPal IPN is working.' , 'woocommerce' ) . '</mark>' ;
else
echo '<mark class="error">' . __ ( 'wp_remote_post() failed. PayPal IPN won\'t work with your server. Contact your hosting provider. Error: ' , 'woocommerce' ) . $response -> get_error_message () . '</mark>' ;
?> </td>
</ tr >
</ tbody >
< thead class = " tools " >
< tr >
< th colspan = " 2 " >< ? php _e ( 'Tools' , 'woocommerce' ); ?> </th>
</ tr >
</ thead >
< tbody class = " tools " >
< tr class = " alternate " >
< td >< ? php _e ( 'Transients' , 'woocommerce' ) ?> </td>
< td >
< p >
< a href = " <?php echo wp_nonce_url( admin_url('tools.php?page=woocommerce_debug&action=clear_transients'), 'debug_action' ); ?> " class = " button " >< ? php _e ( 'Clear Transients' , 'woocommerce' ) ?> </a>
< span class = " description " >< ? php _e ( 'This tool will clear the product/shop transients cache.' , 'woocommerce' ); ?> </span>
</ p >
</ td >
</ tr >
< tr >
< td >< ? php _e ( 'Capabilities' , 'woocommerce' ) ?> </td>
< td >
< p >
< a href = " <?php echo wp_nonce_url( admin_url('tools.php?page=woocommerce_debug&action=reset_roles'), 'debug_action' ); ?> " class = " button " >< ? php _e ( 'Reset Capabilities' , 'woocommerce' ) ?> </a>
< span class = " description " >< ? php _e ( 'This tool will reset the admin, customer and shop_manager roles to default. Use this if your users cannot access all of the WooCommerce admin pages.' , 'woocommerce' ); ?> </span>
</ p >
</ td >
</ tr >
</ tbody >
</ table >
</ div >
< script type = " text/javascript " >
jQuery ( 'a.debug-report' ) . click ( function (){
if ( ! jQuery ( '#debug-report' ) . val () ) {
// Generate report - user can paste into forum
var report = '`' ;
jQuery ( 'thead:not(".tools"), tbody:not(".tools")' , '.wc_status_table' ) . each ( function (){
$this = jQuery ( this );
if ( $this . is ( 'thead' ) ) {
report = report + " \n ============================================================================================= \n " ;
report = report + " " + jQuery . trim ( $this . text () ) + " \n " ;
report = report + " ============================================================================================= \n " ;
} else {
jQuery ( 'tr' , $this ) . each ( function (){
$this = jQuery ( this );
report = report + $this . find ( 'td:eq(0)' ) . text () + " : \t " ;
report = report + $this . find ( 'td:eq(1)' ) . text () + " \n " ;
});
}
});
report = report + '`' ;
jQuery ( '#debug-report' ) . val ( report );
}
jQuery ( '#debug-report' ) . slideToggle ( '500' , function () {
jQuery ( this ) . select ();
});
return false ;
});
</ script >
< ? php
}