@@ -16,16 +16,16 @@ discard block |
||
| 16 | 16 | * @return int |
| 17 | 17 | */ |
| 18 | 18 | function wp_session_cache_expire() { |
| 19 | - $wp_session = WP_Session::get_instance(); |
|
| 19 | + $wp_session = WP_Session::get_instance(); |
|
| 20 | 20 | |
| 21 | - return $wp_session->cache_expiration(); |
|
| 21 | + return $wp_session->cache_expiration(); |
|
| 22 | 22 | } |
| 23 | 23 | |
| 24 | 24 | /** |
| 25 | 25 | * Alias of wp_session_write_close() |
| 26 | 26 | */ |
| 27 | 27 | function wp_session_commit() { |
| 28 | - wp_session_write_close(); |
|
| 28 | + wp_session_write_close(); |
|
| 29 | 29 | } |
| 30 | 30 | |
| 31 | 31 | /** |
@@ -34,9 +34,9 @@ discard block |
||
| 34 | 34 | * @param string $data |
| 35 | 35 | */ |
| 36 | 36 | function wp_session_decode( $data ) { |
| 37 | - $wp_session = WP_Session::get_instance(); |
|
| 37 | + $wp_session = WP_Session::get_instance(); |
|
| 38 | 38 | |
| 39 | - return $wp_session->json_in( $data ); |
|
| 39 | + return $wp_session->json_in( $data ); |
|
| 40 | 40 | } |
| 41 | 41 | |
| 42 | 42 | /** |
@@ -45,9 +45,9 @@ discard block |
||
| 45 | 45 | * @return string |
| 46 | 46 | */ |
| 47 | 47 | function wp_session_encode() { |
| 48 | - $wp_session = WP_Session::get_instance(); |
|
| 48 | + $wp_session = WP_Session::get_instance(); |
|
| 49 | 49 | |
| 50 | - return $wp_session->json_out(); |
|
| 50 | + return $wp_session->json_out(); |
|
| 51 | 51 | } |
| 52 | 52 | |
| 53 | 53 | /** |
@@ -58,11 +58,11 @@ discard block |
||
| 58 | 58 | * @return bool |
| 59 | 59 | */ |
| 60 | 60 | function wp_session_regenerate_id( $delete_old_session = false ) { |
| 61 | - $wp_session = WP_Session::get_instance(); |
|
| 61 | + $wp_session = WP_Session::get_instance(); |
|
| 62 | 62 | |
| 63 | - $wp_session->regenerate_id( $delete_old_session ); |
|
| 63 | + $wp_session->regenerate_id( $delete_old_session ); |
|
| 64 | 64 | |
| 65 | - return true; |
|
| 65 | + return true; |
|
| 66 | 66 | } |
| 67 | 67 | |
| 68 | 68 | /** |
@@ -73,13 +73,13 @@ discard block |
||
| 73 | 73 | * @return bool |
| 74 | 74 | */ |
| 75 | 75 | function wp_session_start() { |
| 76 | - $wp_session = WP_Session::get_instance(); |
|
| 77 | - do_action( 'wp_session_start' ); |
|
| 76 | + $wp_session = WP_Session::get_instance(); |
|
| 77 | + do_action( 'wp_session_start' ); |
|
| 78 | 78 | |
| 79 | - return $wp_session->session_started(); |
|
| 79 | + return $wp_session->session_started(); |
|
| 80 | 80 | } |
| 81 | 81 | if ( ! defined( 'WP_CLI' ) || false === WP_CLI ) { |
| 82 | - add_action( 'plugins_loaded', 'wp_session_start' ); |
|
| 82 | + add_action( 'plugins_loaded', 'wp_session_start' ); |
|
| 83 | 83 | } |
| 84 | 84 | |
| 85 | 85 | /** |
@@ -88,35 +88,35 @@ discard block |
||
| 88 | 88 | * @return int |
| 89 | 89 | */ |
| 90 | 90 | function wp_session_status() { |
| 91 | - $wp_session = WP_Session::get_instance(); |
|
| 91 | + $wp_session = WP_Session::get_instance(); |
|
| 92 | 92 | |
| 93 | - if ( $wp_session->session_started() ) { |
|
| 94 | - return PHP_SESSION_ACTIVE; |
|
| 95 | - } |
|
| 93 | + if ( $wp_session->session_started() ) { |
|
| 94 | + return PHP_SESSION_ACTIVE; |
|
| 95 | + } |
|
| 96 | 96 | |
| 97 | - return PHP_SESSION_NONE; |
|
| 97 | + return PHP_SESSION_NONE; |
|
| 98 | 98 | } |
| 99 | 99 | |
| 100 | 100 | /** |
| 101 | 101 | * Unset all session variables. |
| 102 | 102 | */ |
| 103 | 103 | function wp_session_unset() { |
| 104 | - $wp_session = WP_Session::get_instance(); |
|
| 104 | + $wp_session = WP_Session::get_instance(); |
|
| 105 | 105 | |
| 106 | - $wp_session->reset(); |
|
| 106 | + $wp_session->reset(); |
|
| 107 | 107 | } |
| 108 | 108 | |
| 109 | 109 | /** |
| 110 | 110 | * Write session data and end session |
| 111 | 111 | */ |
| 112 | 112 | function wp_session_write_close() { |
| 113 | - $wp_session = WP_Session::get_instance(); |
|
| 113 | + $wp_session = WP_Session::get_instance(); |
|
| 114 | 114 | |
| 115 | - $wp_session->write_data(); |
|
| 116 | - do_action( 'wp_session_commit' ); |
|
| 115 | + $wp_session->write_data(); |
|
| 116 | + do_action( 'wp_session_commit' ); |
|
| 117 | 117 | } |
| 118 | 118 | if ( ! defined( 'WP_CLI' ) || false === WP_CLI ) { |
| 119 | - add_action( 'shutdown', 'wp_session_write_close' ); |
|
| 119 | + add_action( 'shutdown', 'wp_session_write_close' ); |
|
| 120 | 120 | } |
| 121 | 121 | |
| 122 | 122 | /** |
@@ -127,24 +127,24 @@ discard block |
||
| 127 | 127 | * of a scheduled task or cron job. |
| 128 | 128 | */ |
| 129 | 129 | function wp_session_cleanup() { |
| 130 | - if ( defined( 'WP_SETUP_CONFIG' ) ) { |
|
| 131 | - return; |
|
| 132 | - } |
|
| 133 | - |
|
| 134 | - if ( ! defined( 'WP_INSTALLING' ) ) { |
|
| 135 | - /** |
|
| 136 | - * Determine the size of each batch for deletion. |
|
| 137 | - * |
|
| 138 | - * @param int |
|
| 139 | - */ |
|
| 140 | - $batch_size = apply_filters( 'wp_session_delete_batch_size', 1000 ); |
|
| 141 | - |
|
| 142 | - // Delete a batch of old sessions |
|
| 143 | - WP_Session_Utils::delete_old_sessions( $batch_size ); |
|
| 144 | - } |
|
| 145 | - |
|
| 146 | - // Allow other plugins to hook in to the garbage collection process. |
|
| 147 | - do_action( 'wp_session_cleanup' ); |
|
| 130 | + if ( defined( 'WP_SETUP_CONFIG' ) ) { |
|
| 131 | + return; |
|
| 132 | + } |
|
| 133 | + |
|
| 134 | + if ( ! defined( 'WP_INSTALLING' ) ) { |
|
| 135 | + /** |
|
| 136 | + * Determine the size of each batch for deletion. |
|
| 137 | + * |
|
| 138 | + * @param int |
|
| 139 | + */ |
|
| 140 | + $batch_size = apply_filters( 'wp_session_delete_batch_size', 1000 ); |
|
| 141 | + |
|
| 142 | + // Delete a batch of old sessions |
|
| 143 | + WP_Session_Utils::delete_old_sessions( $batch_size ); |
|
| 144 | + } |
|
| 145 | + |
|
| 146 | + // Allow other plugins to hook in to the garbage collection process. |
|
| 147 | + do_action( 'wp_session_cleanup' ); |
|
| 148 | 148 | } |
| 149 | 149 | add_action( 'wp_session_garbage_collection', 'wp_session_cleanup' ); |
| 150 | 150 | |
@@ -152,8 +152,8 @@ discard block |
||
| 152 | 152 | * Register the garbage collector as a twice daily event. |
| 153 | 153 | */ |
| 154 | 154 | function wp_session_register_garbage_collection() { |
| 155 | - if ( ! wp_next_scheduled( 'wp_session_garbage_collection' ) ) { |
|
| 156 | - wp_schedule_event( time(), 'hourly', 'wp_session_garbage_collection' ); |
|
| 157 | - } |
|
| 155 | + if ( ! wp_next_scheduled( 'wp_session_garbage_collection' ) ) { |
|
| 156 | + wp_schedule_event( time(), 'hourly', 'wp_session_garbage_collection' ); |
|
| 157 | + } |
|
| 158 | 158 | } |
| 159 | 159 | add_action( 'wp', 'wp_session_register_garbage_collection' ); |
@@ -33,10 +33,10 @@ discard block |
||
| 33 | 33 | * |
| 34 | 34 | * @param string $data |
| 35 | 35 | */ |
| 36 | -function wp_session_decode( $data ) { |
|
| 36 | +function wp_session_decode($data) { |
|
| 37 | 37 | $wp_session = WP_Session::get_instance(); |
| 38 | 38 | |
| 39 | - return $wp_session->json_in( $data ); |
|
| 39 | + return $wp_session->json_in($data); |
|
| 40 | 40 | } |
| 41 | 41 | |
| 42 | 42 | /** |
@@ -57,10 +57,10 @@ discard block |
||
| 57 | 57 | * |
| 58 | 58 | * @return bool |
| 59 | 59 | */ |
| 60 | -function wp_session_regenerate_id( $delete_old_session = false ) { |
|
| 60 | +function wp_session_regenerate_id($delete_old_session = false) { |
|
| 61 | 61 | $wp_session = WP_Session::get_instance(); |
| 62 | 62 | |
| 63 | - $wp_session->regenerate_id( $delete_old_session ); |
|
| 63 | + $wp_session->regenerate_id($delete_old_session); |
|
| 64 | 64 | |
| 65 | 65 | return true; |
| 66 | 66 | } |
@@ -74,12 +74,12 @@ discard block |
||
| 74 | 74 | */ |
| 75 | 75 | function wp_session_start() { |
| 76 | 76 | $wp_session = WP_Session::get_instance(); |
| 77 | - do_action( 'wp_session_start' ); |
|
| 77 | + do_action('wp_session_start'); |
|
| 78 | 78 | |
| 79 | 79 | return $wp_session->session_started(); |
| 80 | 80 | } |
| 81 | -if ( ! defined( 'WP_CLI' ) || false === WP_CLI ) { |
|
| 82 | - add_action( 'plugins_loaded', 'wp_session_start' ); |
|
| 81 | +if (!defined('WP_CLI') || false === WP_CLI) { |
|
| 82 | + add_action('plugins_loaded', 'wp_session_start'); |
|
| 83 | 83 | } |
| 84 | 84 | |
| 85 | 85 | /** |
@@ -90,7 +90,7 @@ discard block |
||
| 90 | 90 | function wp_session_status() { |
| 91 | 91 | $wp_session = WP_Session::get_instance(); |
| 92 | 92 | |
| 93 | - if ( $wp_session->session_started() ) { |
|
| 93 | + if ($wp_session->session_started()) { |
|
| 94 | 94 | return PHP_SESSION_ACTIVE; |
| 95 | 95 | } |
| 96 | 96 | |
@@ -113,10 +113,10 @@ discard block |
||
| 113 | 113 | $wp_session = WP_Session::get_instance(); |
| 114 | 114 | |
| 115 | 115 | $wp_session->write_data(); |
| 116 | - do_action( 'wp_session_commit' ); |
|
| 116 | + do_action('wp_session_commit'); |
|
| 117 | 117 | } |
| 118 | -if ( ! defined( 'WP_CLI' ) || false === WP_CLI ) { |
|
| 119 | - add_action( 'shutdown', 'wp_session_write_close' ); |
|
| 118 | +if (!defined('WP_CLI') || false === WP_CLI) { |
|
| 119 | + add_action('shutdown', 'wp_session_write_close'); |
|
| 120 | 120 | } |
| 121 | 121 | |
| 122 | 122 | /** |
@@ -127,33 +127,33 @@ discard block |
||
| 127 | 127 | * of a scheduled task or cron job. |
| 128 | 128 | */ |
| 129 | 129 | function wp_session_cleanup() { |
| 130 | - if ( defined( 'WP_SETUP_CONFIG' ) ) { |
|
| 130 | + if (defined('WP_SETUP_CONFIG')) { |
|
| 131 | 131 | return; |
| 132 | 132 | } |
| 133 | 133 | |
| 134 | - if ( ! defined( 'WP_INSTALLING' ) ) { |
|
| 134 | + if (!defined('WP_INSTALLING')) { |
|
| 135 | 135 | /** |
| 136 | 136 | * Determine the size of each batch for deletion. |
| 137 | 137 | * |
| 138 | 138 | * @param int |
| 139 | 139 | */ |
| 140 | - $batch_size = apply_filters( 'wp_session_delete_batch_size', 1000 ); |
|
| 140 | + $batch_size = apply_filters('wp_session_delete_batch_size', 1000); |
|
| 141 | 141 | |
| 142 | 142 | // Delete a batch of old sessions |
| 143 | - WP_Session_Utils::delete_old_sessions( $batch_size ); |
|
| 143 | + WP_Session_Utils::delete_old_sessions($batch_size); |
|
| 144 | 144 | } |
| 145 | 145 | |
| 146 | 146 | // Allow other plugins to hook in to the garbage collection process. |
| 147 | - do_action( 'wp_session_cleanup' ); |
|
| 147 | + do_action('wp_session_cleanup'); |
|
| 148 | 148 | } |
| 149 | -add_action( 'wp_session_garbage_collection', 'wp_session_cleanup' ); |
|
| 149 | +add_action('wp_session_garbage_collection', 'wp_session_cleanup'); |
|
| 150 | 150 | |
| 151 | 151 | /** |
| 152 | 152 | * Register the garbage collector as a twice daily event. |
| 153 | 153 | */ |
| 154 | 154 | function wp_session_register_garbage_collection() { |
| 155 | - if ( ! wp_next_scheduled( 'wp_session_garbage_collection' ) ) { |
|
| 156 | - wp_schedule_event( time(), 'hourly', 'wp_session_garbage_collection' ); |
|
| 155 | + if (!wp_next_scheduled('wp_session_garbage_collection')) { |
|
| 156 | + wp_schedule_event(time(), 'hourly', 'wp_session_garbage_collection'); |
|
| 157 | 157 | } |
| 158 | 158 | } |
| 159 | -add_action( 'wp', 'wp_session_register_garbage_collection' ); |
|
| 159 | +add_action('wp', 'wp_session_register_garbage_collection'); |
|
@@ -6,134 +6,134 @@ |
||
| 6 | 6 | * THIS CLASS SHOULD NEVER BE INSTANTIATED |
| 7 | 7 | */ |
| 8 | 8 | class WP_Session_Utils { |
| 9 | - /** |
|
| 10 | - * Count the total sessions in the database. |
|
| 11 | - * |
|
| 12 | - * @global wpdb $wpdb |
|
| 13 | - * |
|
| 14 | - * @return int |
|
| 15 | - */ |
|
| 16 | - public static function count_sessions() { |
|
| 17 | - global $wpdb; |
|
| 18 | - |
|
| 19 | - $query = "SELECT COUNT(*) FROM $wpdb->options WHERE option_name LIKE '_wp_session_expires_%'"; |
|
| 20 | - |
|
| 21 | - /** |
|
| 22 | - * Filter the query in case tables are non-standard. |
|
| 23 | - * |
|
| 24 | - * @param string $query Database count query |
|
| 25 | - */ |
|
| 26 | - $query = apply_filters( 'wp_session_count_query', $query ); |
|
| 27 | - |
|
| 28 | - $sessions = $wpdb->get_var( $query ); |
|
| 29 | - |
|
| 30 | - return absint( $sessions ); |
|
| 31 | - } |
|
| 32 | - |
|
| 33 | - /** |
|
| 34 | - * Create a new, random session in the database. |
|
| 35 | - * |
|
| 36 | - * @param null|string $date |
|
| 37 | - */ |
|
| 38 | - public static function create_dummy_session( $date = null ) { |
|
| 39 | - // Generate our date |
|
| 40 | - if ( null !== $date ) { |
|
| 41 | - $time = strtotime( $date ); |
|
| 42 | - |
|
| 43 | - if ( false === $time ) { |
|
| 44 | - $date = null; |
|
| 45 | - } else { |
|
| 46 | - $expires = date( 'U', strtotime( $date ) ); |
|
| 47 | - } |
|
| 48 | - } |
|
| 49 | - |
|
| 50 | - // If null was passed, or if the string parsing failed, fall back on a default |
|
| 51 | - if ( null === $date ) { |
|
| 52 | - /** |
|
| 53 | - * Filter the expiration of the session in the database |
|
| 54 | - * |
|
| 55 | - * @param int |
|
| 56 | - */ |
|
| 57 | - $expires = time() + (int) apply_filters( 'wp_session_expiration', 30 * 60 ); |
|
| 58 | - } |
|
| 59 | - |
|
| 60 | - $session_id = self::generate_id(); |
|
| 61 | - |
|
| 62 | - // Store the session |
|
| 63 | - add_option( "_wp_session_{$session_id}", array(), '', 'no' ); |
|
| 64 | - add_option( "_wp_session_expires_{$session_id}", $expires, '', 'no' ); |
|
| 65 | - } |
|
| 66 | - |
|
| 67 | - /** |
|
| 68 | - * Delete old sessions from the database. |
|
| 69 | - * |
|
| 70 | - * @param int $limit Maximum number of sessions to delete. |
|
| 71 | - * |
|
| 72 | - * @global wpdb $wpdb |
|
| 73 | - * |
|
| 74 | - * @return int Sessions deleted. |
|
| 75 | - */ |
|
| 76 | - public static function delete_old_sessions( $limit = 1000 ) { |
|
| 77 | - global $wpdb; |
|
| 78 | - |
|
| 79 | - $limit = absint( $limit ); |
|
| 80 | - $keys = $wpdb->get_results( "SELECT option_name, option_value FROM $wpdb->options WHERE option_name LIKE '_wp_session_expires_%' ORDER BY option_value ASC LIMIT 0, {$limit}" ); |
|
| 81 | - |
|
| 82 | - $now = time(); |
|
| 83 | - $expired = array(); |
|
| 84 | - $count = 0; |
|
| 85 | - |
|
| 86 | - foreach( $keys as $expiration ) { |
|
| 87 | - $key = $expiration->option_name; |
|
| 88 | - $expires = $expiration->option_value; |
|
| 89 | - |
|
| 90 | - if ( $now > $expires ) { |
|
| 91 | - $session_id = preg_replace("/[^A-Za-z0-9_]/", '', substr( $key, 20 ) ); |
|
| 92 | - |
|
| 93 | - $expired[] = $key; |
|
| 94 | - $expired[] = "_wp_session_{$session_id}"; |
|
| 95 | - |
|
| 96 | - $count += 1; |
|
| 97 | - } |
|
| 98 | - } |
|
| 99 | - |
|
| 100 | - // Delete expired sessions |
|
| 101 | - if ( ! empty( $expired ) ) { |
|
| 102 | - $placeholders = array_fill( 0, count( $expired ), '%s' ); |
|
| 103 | - $format = implode( ', ', $placeholders ); |
|
| 104 | - $query = "DELETE FROM $wpdb->options WHERE option_name IN ($format)"; |
|
| 105 | - |
|
| 106 | - $prepared = $wpdb->prepare( $query, $expired ); |
|
| 107 | - $wpdb->query( $prepared ); |
|
| 108 | - } |
|
| 109 | - |
|
| 110 | - return $count; |
|
| 111 | - } |
|
| 112 | - |
|
| 113 | - /** |
|
| 114 | - * Remove all sessions from the database, regardless of expiration. |
|
| 115 | - * |
|
| 116 | - * @global wpdb $wpdb |
|
| 117 | - * |
|
| 118 | - * @return int Sessions deleted |
|
| 119 | - */ |
|
| 120 | - public static function delete_all_sessions() { |
|
| 121 | - global $wpdb; |
|
| 122 | - |
|
| 123 | - $count = $wpdb->query( "DELETE FROM $wpdb->options WHERE option_name LIKE '_wp_session_%'" ); |
|
| 124 | - |
|
| 125 | - return (int) ( $count / 2 ); |
|
| 126 | - } |
|
| 127 | - |
|
| 128 | - /** |
|
| 129 | - * Generate a new, random session ID. |
|
| 130 | - * |
|
| 131 | - * @return string |
|
| 132 | - */ |
|
| 133 | - public static function generate_id() { |
|
| 134 | - require_once( ABSPATH . 'wp-includes/class-phpass.php' ); |
|
| 135 | - $hash = new PasswordHash( 8, false ); |
|
| 136 | - |
|
| 137 | - return md5( $hash->get_random_bytes( 32 ) ); |
|
| 138 | - } |
|
| 9 | + /** |
|
| 10 | + * Count the total sessions in the database. |
|
| 11 | + * |
|
| 12 | + * @global wpdb $wpdb |
|
| 13 | + * |
|
| 14 | + * @return int |
|
| 15 | + */ |
|
| 16 | + public static function count_sessions() { |
|
| 17 | + global $wpdb; |
|
| 18 | + |
|
| 19 | + $query = "SELECT COUNT(*) FROM $wpdb->options WHERE option_name LIKE '_wp_session_expires_%'"; |
|
| 20 | + |
|
| 21 | + /** |
|
| 22 | + * Filter the query in case tables are non-standard. |
|
| 23 | + * |
|
| 24 | + * @param string $query Database count query |
|
| 25 | + */ |
|
| 26 | + $query = apply_filters( 'wp_session_count_query', $query ); |
|
| 27 | + |
|
| 28 | + $sessions = $wpdb->get_var( $query ); |
|
| 29 | + |
|
| 30 | + return absint( $sessions ); |
|
| 31 | + } |
|
| 32 | + |
|
| 33 | + /** |
|
| 34 | + * Create a new, random session in the database. |
|
| 35 | + * |
|
| 36 | + * @param null|string $date |
|
| 37 | + */ |
|
| 38 | + public static function create_dummy_session( $date = null ) { |
|
| 39 | + // Generate our date |
|
| 40 | + if ( null !== $date ) { |
|
| 41 | + $time = strtotime( $date ); |
|
| 42 | + |
|
| 43 | + if ( false === $time ) { |
|
| 44 | + $date = null; |
|
| 45 | + } else { |
|
| 46 | + $expires = date( 'U', strtotime( $date ) ); |
|
| 47 | + } |
|
| 48 | + } |
|
| 49 | + |
|
| 50 | + // If null was passed, or if the string parsing failed, fall back on a default |
|
| 51 | + if ( null === $date ) { |
|
| 52 | + /** |
|
| 53 | + * Filter the expiration of the session in the database |
|
| 54 | + * |
|
| 55 | + * @param int |
|
| 56 | + */ |
|
| 57 | + $expires = time() + (int) apply_filters( 'wp_session_expiration', 30 * 60 ); |
|
| 58 | + } |
|
| 59 | + |
|
| 60 | + $session_id = self::generate_id(); |
|
| 61 | + |
|
| 62 | + // Store the session |
|
| 63 | + add_option( "_wp_session_{$session_id}", array(), '', 'no' ); |
|
| 64 | + add_option( "_wp_session_expires_{$session_id}", $expires, '', 'no' ); |
|
| 65 | + } |
|
| 66 | + |
|
| 67 | + /** |
|
| 68 | + * Delete old sessions from the database. |
|
| 69 | + * |
|
| 70 | + * @param int $limit Maximum number of sessions to delete. |
|
| 71 | + * |
|
| 72 | + * @global wpdb $wpdb |
|
| 73 | + * |
|
| 74 | + * @return int Sessions deleted. |
|
| 75 | + */ |
|
| 76 | + public static function delete_old_sessions( $limit = 1000 ) { |
|
| 77 | + global $wpdb; |
|
| 78 | + |
|
| 79 | + $limit = absint( $limit ); |
|
| 80 | + $keys = $wpdb->get_results( "SELECT option_name, option_value FROM $wpdb->options WHERE option_name LIKE '_wp_session_expires_%' ORDER BY option_value ASC LIMIT 0, {$limit}" ); |
|
| 81 | + |
|
| 82 | + $now = time(); |
|
| 83 | + $expired = array(); |
|
| 84 | + $count = 0; |
|
| 85 | + |
|
| 86 | + foreach( $keys as $expiration ) { |
|
| 87 | + $key = $expiration->option_name; |
|
| 88 | + $expires = $expiration->option_value; |
|
| 89 | + |
|
| 90 | + if ( $now > $expires ) { |
|
| 91 | + $session_id = preg_replace("/[^A-Za-z0-9_]/", '', substr( $key, 20 ) ); |
|
| 92 | + |
|
| 93 | + $expired[] = $key; |
|
| 94 | + $expired[] = "_wp_session_{$session_id}"; |
|
| 95 | + |
|
| 96 | + $count += 1; |
|
| 97 | + } |
|
| 98 | + } |
|
| 99 | + |
|
| 100 | + // Delete expired sessions |
|
| 101 | + if ( ! empty( $expired ) ) { |
|
| 102 | + $placeholders = array_fill( 0, count( $expired ), '%s' ); |
|
| 103 | + $format = implode( ', ', $placeholders ); |
|
| 104 | + $query = "DELETE FROM $wpdb->options WHERE option_name IN ($format)"; |
|
| 105 | + |
|
| 106 | + $prepared = $wpdb->prepare( $query, $expired ); |
|
| 107 | + $wpdb->query( $prepared ); |
|
| 108 | + } |
|
| 109 | + |
|
| 110 | + return $count; |
|
| 111 | + } |
|
| 112 | + |
|
| 113 | + /** |
|
| 114 | + * Remove all sessions from the database, regardless of expiration. |
|
| 115 | + * |
|
| 116 | + * @global wpdb $wpdb |
|
| 117 | + * |
|
| 118 | + * @return int Sessions deleted |
|
| 119 | + */ |
|
| 120 | + public static function delete_all_sessions() { |
|
| 121 | + global $wpdb; |
|
| 122 | + |
|
| 123 | + $count = $wpdb->query( "DELETE FROM $wpdb->options WHERE option_name LIKE '_wp_session_%'" ); |
|
| 124 | + |
|
| 125 | + return (int) ( $count / 2 ); |
|
| 126 | + } |
|
| 127 | + |
|
| 128 | + /** |
|
| 129 | + * Generate a new, random session ID. |
|
| 130 | + * |
|
| 131 | + * @return string |
|
| 132 | + */ |
|
| 133 | + public static function generate_id() { |
|
| 134 | + require_once( ABSPATH . 'wp-includes/class-phpass.php' ); |
|
| 135 | + $hash = new PasswordHash( 8, false ); |
|
| 136 | + |
|
| 137 | + return md5( $hash->get_random_bytes( 32 ) ); |
|
| 138 | + } |
|
| 139 | 139 | } |
| 140 | 140 | \ No newline at end of file |
@@ -23,11 +23,11 @@ discard block |
||
| 23 | 23 | * |
| 24 | 24 | * @param string $query Database count query |
| 25 | 25 | */ |
| 26 | - $query = apply_filters( 'wp_session_count_query', $query ); |
|
| 26 | + $query = apply_filters('wp_session_count_query', $query); |
|
| 27 | 27 | |
| 28 | - $sessions = $wpdb->get_var( $query ); |
|
| 28 | + $sessions = $wpdb->get_var($query); |
|
| 29 | 29 | |
| 30 | - return absint( $sessions ); |
|
| 30 | + return absint($sessions); |
|
| 31 | 31 | } |
| 32 | 32 | |
| 33 | 33 | /** |
@@ -35,33 +35,33 @@ discard block |
||
| 35 | 35 | * |
| 36 | 36 | * @param null|string $date |
| 37 | 37 | */ |
| 38 | - public static function create_dummy_session( $date = null ) { |
|
| 38 | + public static function create_dummy_session($date = null) { |
|
| 39 | 39 | // Generate our date |
| 40 | - if ( null !== $date ) { |
|
| 41 | - $time = strtotime( $date ); |
|
| 40 | + if (null !== $date) { |
|
| 41 | + $time = strtotime($date); |
|
| 42 | 42 | |
| 43 | - if ( false === $time ) { |
|
| 43 | + if (false === $time) { |
|
| 44 | 44 | $date = null; |
| 45 | 45 | } else { |
| 46 | - $expires = date( 'U', strtotime( $date ) ); |
|
| 46 | + $expires = date('U', strtotime($date)); |
|
| 47 | 47 | } |
| 48 | 48 | } |
| 49 | 49 | |
| 50 | 50 | // If null was passed, or if the string parsing failed, fall back on a default |
| 51 | - if ( null === $date ) { |
|
| 51 | + if (null === $date) { |
|
| 52 | 52 | /** |
| 53 | 53 | * Filter the expiration of the session in the database |
| 54 | 54 | * |
| 55 | 55 | * @param int |
| 56 | 56 | */ |
| 57 | - $expires = time() + (int) apply_filters( 'wp_session_expiration', 30 * 60 ); |
|
| 57 | + $expires = time() + (int)apply_filters('wp_session_expiration', 30 * 60); |
|
| 58 | 58 | } |
| 59 | 59 | |
| 60 | 60 | $session_id = self::generate_id(); |
| 61 | 61 | |
| 62 | 62 | // Store the session |
| 63 | - add_option( "_wp_session_{$session_id}", array(), '', 'no' ); |
|
| 64 | - add_option( "_wp_session_expires_{$session_id}", $expires, '', 'no' ); |
|
| 63 | + add_option("_wp_session_{$session_id}", array(), '', 'no'); |
|
| 64 | + add_option("_wp_session_expires_{$session_id}", $expires, '', 'no'); |
|
| 65 | 65 | } |
| 66 | 66 | |
| 67 | 67 | /** |
@@ -73,22 +73,22 @@ discard block |
||
| 73 | 73 | * |
| 74 | 74 | * @return int Sessions deleted. |
| 75 | 75 | */ |
| 76 | - public static function delete_old_sessions( $limit = 1000 ) { |
|
| 76 | + public static function delete_old_sessions($limit = 1000) { |
|
| 77 | 77 | global $wpdb; |
| 78 | 78 | |
| 79 | - $limit = absint( $limit ); |
|
| 80 | - $keys = $wpdb->get_results( "SELECT option_name, option_value FROM $wpdb->options WHERE option_name LIKE '_wp_session_expires_%' ORDER BY option_value ASC LIMIT 0, {$limit}" ); |
|
| 79 | + $limit = absint($limit); |
|
| 80 | + $keys = $wpdb->get_results("SELECT option_name, option_value FROM $wpdb->options WHERE option_name LIKE '_wp_session_expires_%' ORDER BY option_value ASC LIMIT 0, {$limit}"); |
|
| 81 | 81 | |
| 82 | 82 | $now = time(); |
| 83 | 83 | $expired = array(); |
| 84 | 84 | $count = 0; |
| 85 | 85 | |
| 86 | - foreach( $keys as $expiration ) { |
|
| 86 | + foreach ($keys as $expiration) { |
|
| 87 | 87 | $key = $expiration->option_name; |
| 88 | 88 | $expires = $expiration->option_value; |
| 89 | 89 | |
| 90 | - if ( $now > $expires ) { |
|
| 91 | - $session_id = preg_replace("/[^A-Za-z0-9_]/", '', substr( $key, 20 ) ); |
|
| 90 | + if ($now > $expires) { |
|
| 91 | + $session_id = preg_replace("/[^A-Za-z0-9_]/", '', substr($key, 20)); |
|
| 92 | 92 | |
| 93 | 93 | $expired[] = $key; |
| 94 | 94 | $expired[] = "_wp_session_{$session_id}"; |
@@ -98,13 +98,13 @@ discard block |
||
| 98 | 98 | } |
| 99 | 99 | |
| 100 | 100 | // Delete expired sessions |
| 101 | - if ( ! empty( $expired ) ) { |
|
| 102 | - $placeholders = array_fill( 0, count( $expired ), '%s' ); |
|
| 103 | - $format = implode( ', ', $placeholders ); |
|
| 101 | + if (!empty($expired)) { |
|
| 102 | + $placeholders = array_fill(0, count($expired), '%s'); |
|
| 103 | + $format = implode(', ', $placeholders); |
|
| 104 | 104 | $query = "DELETE FROM $wpdb->options WHERE option_name IN ($format)"; |
| 105 | 105 | |
| 106 | - $prepared = $wpdb->prepare( $query, $expired ); |
|
| 107 | - $wpdb->query( $prepared ); |
|
| 106 | + $prepared = $wpdb->prepare($query, $expired); |
|
| 107 | + $wpdb->query($prepared); |
|
| 108 | 108 | } |
| 109 | 109 | |
| 110 | 110 | return $count; |
@@ -120,9 +120,9 @@ discard block |
||
| 120 | 120 | public static function delete_all_sessions() { |
| 121 | 121 | global $wpdb; |
| 122 | 122 | |
| 123 | - $count = $wpdb->query( "DELETE FROM $wpdb->options WHERE option_name LIKE '_wp_session_%'" ); |
|
| 123 | + $count = $wpdb->query("DELETE FROM $wpdb->options WHERE option_name LIKE '_wp_session_%'"); |
|
| 124 | 124 | |
| 125 | - return (int) ( $count / 2 ); |
|
| 125 | + return (int)($count / 2); |
|
| 126 | 126 | } |
| 127 | 127 | |
| 128 | 128 | /** |
@@ -131,9 +131,9 @@ discard block |
||
| 131 | 131 | * @return string |
| 132 | 132 | */ |
| 133 | 133 | public static function generate_id() { |
| 134 | - require_once( ABSPATH . 'wp-includes/class-phpass.php' ); |
|
| 135 | - $hash = new PasswordHash( 8, false ); |
|
| 134 | + require_once(ABSPATH . 'wp-includes/class-phpass.php'); |
|
| 135 | + $hash = new PasswordHash(8, false); |
|
| 136 | 136 | |
| 137 | - return md5( $hash->get_random_bytes( 32 ) ); |
|
| 137 | + return md5($hash->get_random_bytes(32)); |
|
| 138 | 138 | } |
| 139 | 139 | } |
| 140 | 140 | \ No newline at end of file |
@@ -1,6 +1,8 @@ |
||
| 1 | 1 | <?php |
| 2 | 2 | // Exit if accessed directly |
| 3 | -if ( ! defined( 'ABSPATH' ) ) exit; |
|
| 3 | +if ( ! defined( 'ABSPATH' ) ) { |
|
| 4 | + exit; |
|
| 5 | +} |
|
| 4 | 6 | |
| 5 | 7 | class WPInv_Item { |
| 6 | 8 | public $ID = 0; |
@@ -1,6 +1,6 @@ discard block |
||
| 1 | 1 | <?php |
| 2 | 2 | // Exit if accessed directly |
| 3 | -if ( ! defined( 'ABSPATH' ) ) exit; |
|
| 3 | +if (!defined('ABSPATH')) exit; |
|
| 4 | 4 | |
| 5 | 5 | class WPInv_Item { |
| 6 | 6 | public $ID = 0; |
@@ -47,26 +47,26 @@ discard block |
||
| 47 | 47 | public $filter; |
| 48 | 48 | |
| 49 | 49 | |
| 50 | - public function __construct( $_id = false, $_args = array() ) { |
|
| 51 | - $item = WP_Post::get_instance( $_id ); |
|
| 52 | - return $this->setup_item( $item ); |
|
| 50 | + public function __construct($_id = false, $_args = array()) { |
|
| 51 | + $item = WP_Post::get_instance($_id); |
|
| 52 | + return $this->setup_item($item); |
|
| 53 | 53 | } |
| 54 | 54 | |
| 55 | - private function setup_item( $item ) { |
|
| 56 | - if( ! is_object( $item ) ) { |
|
| 55 | + private function setup_item($item) { |
|
| 56 | + if (!is_object($item)) { |
|
| 57 | 57 | return false; |
| 58 | 58 | } |
| 59 | 59 | |
| 60 | - if( ! is_a( $item, 'WP_Post' ) ) { |
|
| 60 | + if (!is_a($item, 'WP_Post')) { |
|
| 61 | 61 | return false; |
| 62 | 62 | } |
| 63 | 63 | |
| 64 | - if( 'wpi_item' !== $item->post_type ) { |
|
| 64 | + if ('wpi_item' !== $item->post_type) { |
|
| 65 | 65 | return false; |
| 66 | 66 | } |
| 67 | 67 | |
| 68 | - foreach ( $item as $key => $value ) { |
|
| 69 | - switch ( $key ) { |
|
| 68 | + foreach ($item as $key => $value) { |
|
| 69 | + switch ($key) { |
|
| 70 | 70 | default: |
| 71 | 71 | $this->$key = $value; |
| 72 | 72 | break; |
@@ -76,38 +76,38 @@ discard block |
||
| 76 | 76 | return true; |
| 77 | 77 | } |
| 78 | 78 | |
| 79 | - public function __get( $key ) { |
|
| 80 | - if ( method_exists( $this, 'get_' . $key ) ) { |
|
| 81 | - return call_user_func( array( $this, 'get_' . $key ) ); |
|
| 79 | + public function __get($key) { |
|
| 80 | + if (method_exists($this, 'get_' . $key)) { |
|
| 81 | + return call_user_func(array($this, 'get_' . $key)); |
|
| 82 | 82 | } else { |
| 83 | - return new WP_Error( 'wpinv-item-invalid-property', sprintf( __( 'Can\'t get property %s', 'invoicing' ), $key ) ); |
|
| 83 | + return new WP_Error('wpinv-item-invalid-property', sprintf(__('Can\'t get property %s', 'invoicing'), $key)); |
|
| 84 | 84 | } |
| 85 | 85 | } |
| 86 | 86 | |
| 87 | - public function create( $data = array(), $wp_error = false ) { |
|
| 88 | - if ( $this->ID != 0 ) { |
|
| 87 | + public function create($data = array(), $wp_error = false) { |
|
| 88 | + if ($this->ID != 0) { |
|
| 89 | 89 | return false; |
| 90 | 90 | } |
| 91 | 91 | |
| 92 | 92 | $defaults = array( |
| 93 | 93 | 'post_type' => 'wpi_item', |
| 94 | 94 | 'post_status' => 'draft', |
| 95 | - 'post_title' => __( 'New Invoice Item', 'invoicing' ) |
|
| 95 | + 'post_title' => __('New Invoice Item', 'invoicing') |
|
| 96 | 96 | ); |
| 97 | 97 | |
| 98 | - $args = wp_parse_args( $data, $defaults ); |
|
| 98 | + $args = wp_parse_args($data, $defaults); |
|
| 99 | 99 | |
| 100 | - do_action( 'wpinv_item_pre_create', $args ); |
|
| 100 | + do_action('wpinv_item_pre_create', $args); |
|
| 101 | 101 | |
| 102 | - $id = wp_insert_post( $args, $wp_error ); |
|
| 102 | + $id = wp_insert_post($args, $wp_error); |
|
| 103 | 103 | if ($wp_error && is_wp_error($id)) { |
| 104 | 104 | return $id; |
| 105 | 105 | } |
| 106 | - if ( !$id ) { |
|
| 106 | + if (!$id) { |
|
| 107 | 107 | return false; |
| 108 | 108 | } |
| 109 | 109 | |
| 110 | - $item = WP_Post::get_instance( $id ); |
|
| 110 | + $item = WP_Post::get_instance($id); |
|
| 111 | 111 | |
| 112 | 112 | if (!empty($item) && !empty($data['meta'])) { |
| 113 | 113 | $this->ID = $item->ID; |
@@ -115,47 +115,47 @@ discard block |
||
| 115 | 115 | } |
| 116 | 116 | |
| 117 | 117 | // Set custom id if not set. |
| 118 | - if ( empty( $data['meta']['custom_id'] ) && !$this->get_custom_id() ) { |
|
| 119 | - $this->save_metas( array( 'custom_id' => $id ) ); |
|
| 118 | + if (empty($data['meta']['custom_id']) && !$this->get_custom_id()) { |
|
| 119 | + $this->save_metas(array('custom_id' => $id)); |
|
| 120 | 120 | } |
| 121 | 121 | |
| 122 | - do_action( 'wpinv_item_create', $id, $args ); |
|
| 122 | + do_action('wpinv_item_create', $id, $args); |
|
| 123 | 123 | |
| 124 | - return $this->setup_item( $item ); |
|
| 124 | + return $this->setup_item($item); |
|
| 125 | 125 | } |
| 126 | 126 | |
| 127 | - public function update( $data = array(), $wp_error = false ) { |
|
| 128 | - if ( !$this->ID > 0 ) { |
|
| 127 | + public function update($data = array(), $wp_error = false) { |
|
| 128 | + if (!$this->ID > 0) { |
|
| 129 | 129 | return false; |
| 130 | 130 | } |
| 131 | 131 | |
| 132 | 132 | $data['ID'] = $this->ID; |
| 133 | 133 | |
| 134 | - do_action( 'wpinv_item_pre_update', $data ); |
|
| 134 | + do_action('wpinv_item_pre_update', $data); |
|
| 135 | 135 | |
| 136 | - $id = wp_update_post( $data, $wp_error ); |
|
| 136 | + $id = wp_update_post($data, $wp_error); |
|
| 137 | 137 | if ($wp_error && is_wp_error($id)) { |
| 138 | 138 | return $id; |
| 139 | 139 | } |
| 140 | 140 | |
| 141 | - if ( !$id ) { |
|
| 141 | + if (!$id) { |
|
| 142 | 142 | return false; |
| 143 | 143 | } |
| 144 | 144 | |
| 145 | - $item = WP_Post::get_instance( $id ); |
|
| 145 | + $item = WP_Post::get_instance($id); |
|
| 146 | 146 | if (!empty($item) && !empty($data['meta'])) { |
| 147 | 147 | $this->ID = $item->ID; |
| 148 | 148 | $this->save_metas($data['meta']); |
| 149 | 149 | } |
| 150 | 150 | |
| 151 | 151 | // Set custom id if not set. |
| 152 | - if ( empty( $data['meta']['custom_id'] ) && !$this->get_custom_id() ) { |
|
| 153 | - $this->save_metas( array( 'custom_id' => $id ) ); |
|
| 152 | + if (empty($data['meta']['custom_id']) && !$this->get_custom_id()) { |
|
| 153 | + $this->save_metas(array('custom_id' => $id)); |
|
| 154 | 154 | } |
| 155 | 155 | |
| 156 | - do_action( 'wpinv_item_update', $id, $data ); |
|
| 156 | + do_action('wpinv_item_update', $id, $data); |
|
| 157 | 157 | |
| 158 | - return $this->setup_item( $item ); |
|
| 158 | + return $this->setup_item($item); |
|
| 159 | 159 | } |
| 160 | 160 | |
| 161 | 161 | public function get_ID() { |
@@ -163,119 +163,119 @@ discard block |
||
| 163 | 163 | } |
| 164 | 164 | |
| 165 | 165 | public function get_name() { |
| 166 | - return get_the_title( $this->ID ); |
|
| 166 | + return get_the_title($this->ID); |
|
| 167 | 167 | } |
| 168 | 168 | |
| 169 | 169 | public function get_title() { |
| 170 | - return get_the_title( $this->ID ); |
|
| 170 | + return get_the_title($this->ID); |
|
| 171 | 171 | } |
| 172 | 172 | |
| 173 | 173 | public function get_status() { |
| 174 | - return get_post_status( $this->ID ); |
|
| 174 | + return get_post_status($this->ID); |
|
| 175 | 175 | } |
| 176 | 176 | |
| 177 | 177 | public function get_summary() { |
| 178 | - return get_the_excerpt( $this->ID ); |
|
| 178 | + return get_the_excerpt($this->ID); |
|
| 179 | 179 | } |
| 180 | 180 | |
| 181 | 181 | public function get_price() { |
| 182 | - if ( ! isset( $this->price ) ) { |
|
| 183 | - $this->price = get_post_meta( $this->ID, '_wpinv_price', true ); |
|
| 182 | + if (!isset($this->price)) { |
|
| 183 | + $this->price = get_post_meta($this->ID, '_wpinv_price', true); |
|
| 184 | 184 | |
| 185 | - if ( $this->price ) { |
|
| 186 | - $this->price = wpinv_sanitize_amount( $this->price ); |
|
| 185 | + if ($this->price) { |
|
| 186 | + $this->price = wpinv_sanitize_amount($this->price); |
|
| 187 | 187 | } else { |
| 188 | 188 | $this->price = 0; |
| 189 | 189 | } |
| 190 | 190 | } |
| 191 | 191 | |
| 192 | - return apply_filters( 'wpinv_get_item_price', $this->price, $this->ID ); |
|
| 192 | + return apply_filters('wpinv_get_item_price', $this->price, $this->ID); |
|
| 193 | 193 | } |
| 194 | 194 | |
| 195 | 195 | public function get_vat_rule() { |
| 196 | 196 | global $wpinv_euvat; |
| 197 | 197 | |
| 198 | - if( !isset( $this->vat_rule ) ) { |
|
| 199 | - $this->vat_rule = get_post_meta( $this->ID, '_wpinv_vat_rule', true ); |
|
| 198 | + if (!isset($this->vat_rule)) { |
|
| 199 | + $this->vat_rule = get_post_meta($this->ID, '_wpinv_vat_rule', true); |
|
| 200 | 200 | |
| 201 | - if ( empty( $this->vat_rule ) ) { |
|
| 201 | + if (empty($this->vat_rule)) { |
|
| 202 | 202 | $this->vat_rule = $wpinv_euvat->allow_vat_rules() ? 'digital' : 'physical'; |
| 203 | 203 | } |
| 204 | 204 | } |
| 205 | 205 | |
| 206 | - return apply_filters( 'wpinv_get_item_vat_rule', $this->vat_rule, $this->ID ); |
|
| 206 | + return apply_filters('wpinv_get_item_vat_rule', $this->vat_rule, $this->ID); |
|
| 207 | 207 | } |
| 208 | 208 | |
| 209 | 209 | public function get_vat_class() { |
| 210 | - if( !isset( $this->vat_class ) ) { |
|
| 211 | - $this->vat_class = get_post_meta( $this->ID, '_wpinv_vat_class', true ); |
|
| 210 | + if (!isset($this->vat_class)) { |
|
| 211 | + $this->vat_class = get_post_meta($this->ID, '_wpinv_vat_class', true); |
|
| 212 | 212 | |
| 213 | - if ( empty( $this->vat_class ) ) { |
|
| 213 | + if (empty($this->vat_class)) { |
|
| 214 | 214 | $this->vat_class = '_standard'; |
| 215 | 215 | } |
| 216 | 216 | } |
| 217 | 217 | |
| 218 | - return apply_filters( 'wpinv_get_item_vat_class', $this->vat_class, $this->ID ); |
|
| 218 | + return apply_filters('wpinv_get_item_vat_class', $this->vat_class, $this->ID); |
|
| 219 | 219 | } |
| 220 | 220 | |
| 221 | 221 | public function get_type() { |
| 222 | - if( ! isset( $this->type ) ) { |
|
| 223 | - $this->type = get_post_meta( $this->ID, '_wpinv_type', true ); |
|
| 222 | + if (!isset($this->type)) { |
|
| 223 | + $this->type = get_post_meta($this->ID, '_wpinv_type', true); |
|
| 224 | 224 | |
| 225 | - if ( empty( $this->type ) ) { |
|
| 225 | + if (empty($this->type)) { |
|
| 226 | 226 | $this->type = 'custom'; |
| 227 | 227 | } |
| 228 | 228 | } |
| 229 | 229 | |
| 230 | - return apply_filters( 'wpinv_get_item_type', $this->type, $this->ID ); |
|
| 230 | + return apply_filters('wpinv_get_item_type', $this->type, $this->ID); |
|
| 231 | 231 | } |
| 232 | 232 | |
| 233 | 233 | public function get_custom_id() { |
| 234 | - $custom_id = get_post_meta( $this->ID, '_wpinv_custom_id', true ); |
|
| 234 | + $custom_id = get_post_meta($this->ID, '_wpinv_custom_id', true); |
|
| 235 | 235 | |
| 236 | - return apply_filters( 'wpinv_get_item_custom_id', $custom_id, $this->ID ); |
|
| 236 | + return apply_filters('wpinv_get_item_custom_id', $custom_id, $this->ID); |
|
| 237 | 237 | } |
| 238 | 238 | |
| 239 | 239 | public function get_custom_name() { |
| 240 | - $custom_name = get_post_meta( $this->ID, '_wpinv_custom_name', true ); |
|
| 240 | + $custom_name = get_post_meta($this->ID, '_wpinv_custom_name', true); |
|
| 241 | 241 | |
| 242 | - return apply_filters( 'wpinv_get_item_custom_name', $custom_name, $this->ID ); |
|
| 242 | + return apply_filters('wpinv_get_item_custom_name', $custom_name, $this->ID); |
|
| 243 | 243 | } |
| 244 | 244 | |
| 245 | 245 | public function get_custom_singular_name() { |
| 246 | - $custom_singular_name = get_post_meta( $this->ID, '_wpinv_custom_singular_name', true ); |
|
| 246 | + $custom_singular_name = get_post_meta($this->ID, '_wpinv_custom_singular_name', true); |
|
| 247 | 247 | |
| 248 | - return apply_filters( 'wpinv_get_item_custom_singular_name', $custom_singular_name, $this->ID ); |
|
| 248 | + return apply_filters('wpinv_get_item_custom_singular_name', $custom_singular_name, $this->ID); |
|
| 249 | 249 | } |
| 250 | 250 | |
| 251 | 251 | public function get_editable() { |
| 252 | - $editable = get_post_meta( $this->ID, '_wpinv_editable', true ); |
|
| 252 | + $editable = get_post_meta($this->ID, '_wpinv_editable', true); |
|
| 253 | 253 | |
| 254 | - return apply_filters( 'wpinv_item_get_editable', $editable, $this->ID ); |
|
| 254 | + return apply_filters('wpinv_item_get_editable', $editable, $this->ID); |
|
| 255 | 255 | } |
| 256 | 256 | |
| 257 | 257 | public function get_excerpt() { |
| 258 | - $excerpt = get_the_excerpt( $this->ID ); |
|
| 258 | + $excerpt = get_the_excerpt($this->ID); |
|
| 259 | 259 | |
| 260 | - return apply_filters( 'wpinv_item_get_excerpt', $excerpt, $this->ID ); |
|
| 260 | + return apply_filters('wpinv_item_get_excerpt', $excerpt, $this->ID); |
|
| 261 | 261 | } |
| 262 | 262 | |
| 263 | 263 | public function get_is_recurring() { |
| 264 | - $is_recurring = get_post_meta( $this->ID, '_wpinv_is_recurring', true ); |
|
| 264 | + $is_recurring = get_post_meta($this->ID, '_wpinv_is_recurring', true); |
|
| 265 | 265 | |
| 266 | - return apply_filters( 'wpinv_item_get_is_recurring', $is_recurring, $this->ID ); |
|
| 266 | + return apply_filters('wpinv_item_get_is_recurring', $is_recurring, $this->ID); |
|
| 267 | 267 | |
| 268 | 268 | } |
| 269 | 269 | |
| 270 | - public function get_recurring_period( $full = false ) { |
|
| 271 | - $period = get_post_meta( $this->ID, '_wpinv_recurring_period', true ); |
|
| 270 | + public function get_recurring_period($full = false) { |
|
| 271 | + $period = get_post_meta($this->ID, '_wpinv_recurring_period', true); |
|
| 272 | 272 | |
| 273 | - if ( !in_array( $period, array( 'D', 'W', 'M', 'Y' ) ) ) { |
|
| 273 | + if (!in_array($period, array('D', 'W', 'M', 'Y'))) { |
|
| 274 | 274 | $period = 'D'; |
| 275 | 275 | } |
| 276 | 276 | |
| 277 | - if ( $full ) { |
|
| 278 | - switch( $period ) { |
|
| 277 | + if ($full) { |
|
| 278 | + switch ($period) { |
|
| 279 | 279 | case 'D': |
| 280 | 280 | $period = 'day'; |
| 281 | 281 | break; |
@@ -291,40 +291,40 @@ discard block |
||
| 291 | 291 | } |
| 292 | 292 | } |
| 293 | 293 | |
| 294 | - return apply_filters( 'wpinv_item_recurring_period', $period, $full, $this->ID ); |
|
| 294 | + return apply_filters('wpinv_item_recurring_period', $period, $full, $this->ID); |
|
| 295 | 295 | } |
| 296 | 296 | |
| 297 | 297 | public function get_recurring_interval() { |
| 298 | - $interval = (int)get_post_meta( $this->ID, '_wpinv_recurring_interval', true ); |
|
| 298 | + $interval = (int)get_post_meta($this->ID, '_wpinv_recurring_interval', true); |
|
| 299 | 299 | |
| 300 | - if ( !$interval > 0 ) { |
|
| 300 | + if (!$interval > 0) { |
|
| 301 | 301 | $interval = 1; |
| 302 | 302 | } |
| 303 | 303 | |
| 304 | - return apply_filters( 'wpinv_item_recurring_interval', $interval, $this->ID ); |
|
| 304 | + return apply_filters('wpinv_item_recurring_interval', $interval, $this->ID); |
|
| 305 | 305 | } |
| 306 | 306 | |
| 307 | 307 | public function get_recurring_limit() { |
| 308 | - $limit = get_post_meta( $this->ID, '_wpinv_recurring_limit', true ); |
|
| 308 | + $limit = get_post_meta($this->ID, '_wpinv_recurring_limit', true); |
|
| 309 | 309 | |
| 310 | - return (int)apply_filters( 'wpinv_item_recurring_limit', $limit, $this->ID ); |
|
| 310 | + return (int)apply_filters('wpinv_item_recurring_limit', $limit, $this->ID); |
|
| 311 | 311 | } |
| 312 | 312 | |
| 313 | 313 | public function get_free_trial() { |
| 314 | - $free_trial = get_post_meta( $this->ID, '_wpinv_free_trial', true ); |
|
| 314 | + $free_trial = get_post_meta($this->ID, '_wpinv_free_trial', true); |
|
| 315 | 315 | |
| 316 | - return apply_filters( 'wpinv_item_get_free_trial', $free_trial, $this->ID ); |
|
| 316 | + return apply_filters('wpinv_item_get_free_trial', $free_trial, $this->ID); |
|
| 317 | 317 | } |
| 318 | 318 | |
| 319 | - public function get_trial_period( $full = false ) { |
|
| 320 | - $period = get_post_meta( $this->ID, '_wpinv_trial_period', true ); |
|
| 319 | + public function get_trial_period($full = false) { |
|
| 320 | + $period = get_post_meta($this->ID, '_wpinv_trial_period', true); |
|
| 321 | 321 | |
| 322 | - if ( !in_array( $period, array( 'D', 'W', 'M', 'Y' ) ) ) { |
|
| 322 | + if (!in_array($period, array('D', 'W', 'M', 'Y'))) { |
|
| 323 | 323 | $period = 'D'; |
| 324 | 324 | } |
| 325 | 325 | |
| 326 | - if ( $full ) { |
|
| 327 | - switch( $period ) { |
|
| 326 | + if ($full) { |
|
| 327 | + switch ($period) { |
|
| 328 | 328 | case 'D': |
| 329 | 329 | $period = 'day'; |
| 330 | 330 | break; |
@@ -340,47 +340,47 @@ discard block |
||
| 340 | 340 | } |
| 341 | 341 | } |
| 342 | 342 | |
| 343 | - return apply_filters( 'wpinv_item_trial_period', $period, $full, $this->ID ); |
|
| 343 | + return apply_filters('wpinv_item_trial_period', $period, $full, $this->ID); |
|
| 344 | 344 | } |
| 345 | 345 | |
| 346 | 346 | public function get_trial_interval() { |
| 347 | - $interval = absint( get_post_meta( $this->ID, '_wpinv_trial_interval', true ) ); |
|
| 347 | + $interval = absint(get_post_meta($this->ID, '_wpinv_trial_interval', true)); |
|
| 348 | 348 | |
| 349 | - if ( !$interval > 0 ) { |
|
| 349 | + if (!$interval > 0) { |
|
| 350 | 350 | $interval = 1; |
| 351 | 351 | } |
| 352 | 352 | |
| 353 | - return apply_filters( 'wpinv_item_trial_interval', $interval, $this->ID ); |
|
| 353 | + return apply_filters('wpinv_item_trial_interval', $interval, $this->ID); |
|
| 354 | 354 | } |
| 355 | 355 | |
| 356 | 356 | public function get_the_price() { |
| 357 | - $item_price = wpinv_price( wpinv_format_amount( $this->price ) ); |
|
| 357 | + $item_price = wpinv_price(wpinv_format_amount($this->price)); |
|
| 358 | 358 | |
| 359 | - return apply_filters( 'wpinv_get_the_item_price', $item_price, $this->ID ); |
|
| 359 | + return apply_filters('wpinv_get_the_item_price', $item_price, $this->ID); |
|
| 360 | 360 | } |
| 361 | 361 | |
| 362 | 362 | public function is_recurring() { |
| 363 | 363 | $is_recurring = $this->get_is_recurring(); |
| 364 | 364 | |
| 365 | - return (bool)apply_filters( 'wpinv_is_recurring_item', $is_recurring, $this->ID ); |
|
| 365 | + return (bool)apply_filters('wpinv_is_recurring_item', $is_recurring, $this->ID); |
|
| 366 | 366 | } |
| 367 | 367 | |
| 368 | 368 | public function has_free_trial() { |
| 369 | 369 | $free_trial = $this->is_recurring() && $this->get_free_trial() ? true : false; |
| 370 | 370 | |
| 371 | - return (bool)apply_filters( 'wpinv_item_has_free_trial', $free_trial, $this->ID ); |
|
| 371 | + return (bool)apply_filters('wpinv_item_has_free_trial', $free_trial, $this->ID); |
|
| 372 | 372 | } |
| 373 | 373 | |
| 374 | 374 | public function is_free() { |
| 375 | 375 | $is_free = false; |
| 376 | 376 | |
| 377 | - $price = get_post_meta( $this->ID, '_wpinv_price', true ); |
|
| 377 | + $price = get_post_meta($this->ID, '_wpinv_price', true); |
|
| 378 | 378 | |
| 379 | - if ( (float)$price == 0 ) { |
|
| 379 | + if ((float)$price == 0) { |
|
| 380 | 380 | $is_free = true; |
| 381 | 381 | } |
| 382 | 382 | |
| 383 | - return (bool) apply_filters( 'wpinv_is_free_item', $is_free, $this->ID ); |
|
| 383 | + return (bool)apply_filters('wpinv_is_free_item', $is_free, $this->ID); |
|
| 384 | 384 | |
| 385 | 385 | } |
| 386 | 386 | |
@@ -389,15 +389,15 @@ discard block |
||
| 389 | 389 | |
| 390 | 390 | $is_editable = $editable === 0 || $editable === '0' ? false : true; |
| 391 | 391 | |
| 392 | - return (bool) apply_filters( 'wpinv_item_is_editable', $is_editable, $this->ID ); |
|
| 392 | + return (bool)apply_filters('wpinv_item_is_editable', $is_editable, $this->ID); |
|
| 393 | 393 | } |
| 394 | 394 | |
| 395 | - public function save_metas( $metas = array() ) { |
|
| 396 | - if ( empty( $metas ) ) { |
|
| 395 | + public function save_metas($metas = array()) { |
|
| 396 | + if (empty($metas)) { |
|
| 397 | 397 | return false; |
| 398 | 398 | } |
| 399 | 399 | |
| 400 | - foreach ( $metas as $meta_key => $meta_value ) { |
|
| 400 | + foreach ($metas as $meta_key => $meta_value) { |
|
| 401 | 401 | $meta_key = strpos($meta_key, '_wpinv_') !== 0 ? '_wpinv_' . $meta_key : $meta_key; |
| 402 | 402 | |
| 403 | 403 | $this->update_meta($meta_key, $meta_value); |
@@ -406,66 +406,66 @@ discard block |
||
| 406 | 406 | return true; |
| 407 | 407 | } |
| 408 | 408 | |
| 409 | - public function update_meta( $meta_key = '', $meta_value = '', $prev_value = '' ) { |
|
| 410 | - if ( empty( $meta_key ) ) { |
|
| 409 | + public function update_meta($meta_key = '', $meta_value = '', $prev_value = '') { |
|
| 410 | + if (empty($meta_key)) { |
|
| 411 | 411 | return false; |
| 412 | 412 | } |
| 413 | 413 | |
| 414 | - $meta_value = apply_filters( 'wpinv_update_item_meta_' . $meta_key, $meta_value, $this->ID ); |
|
| 414 | + $meta_value = apply_filters('wpinv_update_item_meta_' . $meta_key, $meta_value, $this->ID); |
|
| 415 | 415 | |
| 416 | - return update_post_meta( $this->ID, $meta_key, $meta_value, $prev_value ); |
|
| 416 | + return update_post_meta($this->ID, $meta_key, $meta_value, $prev_value); |
|
| 417 | 417 | } |
| 418 | 418 | |
| 419 | - public function get_fees( $type = 'fee', $item_id = 0 ) { |
|
| 419 | + public function get_fees($type = 'fee', $item_id = 0) { |
|
| 420 | 420 | global $wpi_session; |
| 421 | 421 | |
| 422 | - $fees = $wpi_session->get( 'wpi_cart_fees' ); |
|
| 422 | + $fees = $wpi_session->get('wpi_cart_fees'); |
|
| 423 | 423 | |
| 424 | - if ( ! wpinv_get_cart_contents() ) { |
|
| 424 | + if (!wpinv_get_cart_contents()) { |
|
| 425 | 425 | // We can only get item type fees when the cart is empty |
| 426 | 426 | $type = 'custom'; |
| 427 | 427 | } |
| 428 | 428 | |
| 429 | - if ( ! empty( $fees ) && ! empty( $type ) && 'all' !== $type ) { |
|
| 430 | - foreach( $fees as $key => $fee ) { |
|
| 431 | - if( ! empty( $fee['type'] ) && $type != $fee['type'] ) { |
|
| 432 | - unset( $fees[ $key ] ); |
|
| 429 | + if (!empty($fees) && !empty($type) && 'all' !== $type) { |
|
| 430 | + foreach ($fees as $key => $fee) { |
|
| 431 | + if (!empty($fee['type']) && $type != $fee['type']) { |
|
| 432 | + unset($fees[$key]); |
|
| 433 | 433 | } |
| 434 | 434 | } |
| 435 | 435 | } |
| 436 | 436 | |
| 437 | - if ( ! empty( $fees ) && ! empty( $item_id ) ) { |
|
| 437 | + if (!empty($fees) && !empty($item_id)) { |
|
| 438 | 438 | // Remove fees that don't belong to the specified Item |
| 439 | - foreach ( $fees as $key => $fee ) { |
|
| 440 | - if ( (int) $item_id !== (int)$fee['custom_id'] ) { |
|
| 441 | - unset( $fees[ $key ] ); |
|
| 439 | + foreach ($fees as $key => $fee) { |
|
| 440 | + if ((int)$item_id !== (int)$fee['custom_id']) { |
|
| 441 | + unset($fees[$key]); |
|
| 442 | 442 | } |
| 443 | 443 | } |
| 444 | 444 | } |
| 445 | 445 | |
| 446 | - if ( ! empty( $fees ) ) { |
|
| 446 | + if (!empty($fees)) { |
|
| 447 | 447 | // Remove fees that belong to a specific item but are not in the cart |
| 448 | - foreach( $fees as $key => $fee ) { |
|
| 449 | - if( empty( $fee['custom_id'] ) ) { |
|
| 448 | + foreach ($fees as $key => $fee) { |
|
| 449 | + if (empty($fee['custom_id'])) { |
|
| 450 | 450 | continue; |
| 451 | 451 | } |
| 452 | 452 | |
| 453 | - if ( !wpinv_item_in_cart( $fee['custom_id'] ) ) { |
|
| 454 | - unset( $fees[ $key ] ); |
|
| 453 | + if (!wpinv_item_in_cart($fee['custom_id'])) { |
|
| 454 | + unset($fees[$key]); |
|
| 455 | 455 | } |
| 456 | 456 | } |
| 457 | 457 | } |
| 458 | 458 | |
| 459 | - return ! empty( $fees ) ? $fees : array(); |
|
| 459 | + return !empty($fees) ? $fees : array(); |
|
| 460 | 460 | } |
| 461 | 461 | |
| 462 | 462 | public function can_purchase() { |
| 463 | 463 | $can_purchase = true; |
| 464 | 464 | |
| 465 | - if ( !current_user_can( 'edit_post', $this->ID ) && $this->post_status != 'publish' ) { |
|
| 465 | + if (!current_user_can('edit_post', $this->ID) && $this->post_status != 'publish') { |
|
| 466 | 466 | $can_purchase = false; |
| 467 | 467 | } |
| 468 | 468 | |
| 469 | - return (bool)apply_filters( 'wpinv_can_purchase_item', $can_purchase, $this ); |
|
| 469 | + return (bool)apply_filters('wpinv_can_purchase_item', $can_purchase, $this); |
|
| 470 | 470 | } |
| 471 | 471 | } |
@@ -1,6 +1,8 @@ |
||
| 1 | 1 | <?php |
| 2 | 2 | // Exit if accessed directly |
| 3 | -if ( ! defined( 'ABSPATH' ) ) exit; |
|
| 3 | +if ( ! defined( 'ABSPATH' ) ) { |
|
| 4 | + exit; |
|
| 5 | +} |
|
| 4 | 6 | |
| 5 | 7 | add_action( 'wpinv_worldpay_cc_form', '__return_false' ); |
| 6 | 8 | |
@@ -1,12 +1,12 @@ discard block |
||
| 1 | 1 | <?php |
| 2 | 2 | // Exit if accessed directly |
| 3 | -if ( ! defined( 'ABSPATH' ) ) exit; |
|
| 3 | +if (!defined('ABSPATH')) exit; |
|
| 4 | 4 | |
| 5 | -add_action( 'wpinv_worldpay_cc_form', '__return_false' ); |
|
| 5 | +add_action('wpinv_worldpay_cc_form', '__return_false'); |
|
| 6 | 6 | |
| 7 | -function wpinv_process_worldpay_payment( $purchase_data ) { |
|
| 8 | - if( ! wp_verify_nonce( $purchase_data['gateway_nonce'], 'wpi-gateway' ) ) { |
|
| 9 | - wp_die( __( 'Nonce verification has failed', 'invoicing' ), __( 'Error', 'invoicing' ), array( 'response' => 403 ) ); |
|
| 7 | +function wpinv_process_worldpay_payment($purchase_data) { |
|
| 8 | + if (!wp_verify_nonce($purchase_data['gateway_nonce'], 'wpi-gateway')) { |
|
| 9 | + wp_die(__('Nonce verification has failed', 'invoicing'), __('Error', 'invoicing'), array('response' => 403)); |
|
| 10 | 10 | } |
| 11 | 11 | |
| 12 | 12 | // Collect payment data |
@@ -24,120 +24,120 @@ discard block |
||
| 24 | 24 | ); |
| 25 | 25 | |
| 26 | 26 | // Record the pending payment |
| 27 | - $invoice = wpinv_get_invoice( $purchase_data['invoice_id'] ); |
|
| 27 | + $invoice = wpinv_get_invoice($purchase_data['invoice_id']); |
|
| 28 | 28 | |
| 29 | - if ( !empty( $invoice ) ) { |
|
| 29 | + if (!empty($invoice)) { |
|
| 30 | 30 | $quantities_enabled = wpinv_item_quantities_enabled(); |
| 31 | 31 | |
| 32 | - $instId = wpinv_get_option( 'worldpay_instId', false ); |
|
| 32 | + $instId = wpinv_get_option('worldpay_instId', false); |
|
| 33 | 33 | $cartId = $invoice->get_number(); |
| 34 | - $testMode = wpinv_is_test_mode( 'worldpay' ) ? 100 : 0; |
|
| 34 | + $testMode = wpinv_is_test_mode('worldpay') ? 100 : 0; |
|
| 35 | 35 | $name = $invoice->get_user_full_name(); |
| 36 | - $address = wp_strip_all_tags( $invoice->get_address(), true ); |
|
| 36 | + $address = wp_strip_all_tags($invoice->get_address(), true); |
|
| 37 | 37 | $postcode = $invoice->zip; |
| 38 | 38 | $tel = $invoice->phone; |
| 39 | 39 | $email = $invoice->get_email(); |
| 40 | 40 | $country = $invoice->country; |
| 41 | - $amount = wpinv_sanitize_amount( $invoice->get_total() ); |
|
| 41 | + $amount = wpinv_sanitize_amount($invoice->get_total()); |
|
| 42 | 42 | $currency = wpinv_get_currency(); |
| 43 | 43 | |
| 44 | 44 | $items = array(); |
| 45 | - foreach ( $invoice->get_cart_details() as $item ) { |
|
| 45 | + foreach ($invoice->get_cart_details() as $item) { |
|
| 46 | 46 | $item_desc = $item['name']; |
| 47 | - $quantity = !empty( $item['quantity'] ) && $item['quantity'] > 0 ? $item['quantity'] : 1; |
|
| 48 | - $item_desc .= ' (' . ( $quantities_enabled ? $quantity . 'x ' : '' ) . wpinv_price( wpinv_format_amount( $item['item_price'] ) ) . ')'; |
|
| 47 | + $quantity = !empty($item['quantity']) && $item['quantity'] > 0 ? $item['quantity'] : 1; |
|
| 48 | + $item_desc .= ' (' . ($quantities_enabled ? $quantity . 'x ' : '') . wpinv_price(wpinv_format_amount($item['item_price'])) . ')'; |
|
| 49 | 49 | |
| 50 | 50 | $items[] = $item_desc; |
| 51 | 51 | } |
| 52 | 52 | |
| 53 | - $desc = implode( ', ', $items ); |
|
| 54 | - if ( wpinv_use_taxes() && $invoice->get_tax() > 0 ) { |
|
| 55 | - $desc .= ', ' . wp_sprintf( __( 'Tax: %s', 'invoicing' ), $invoice->get_tax( true ) ); |
|
| 53 | + $desc = implode(', ', $items); |
|
| 54 | + if (wpinv_use_taxes() && $invoice->get_tax() > 0) { |
|
| 55 | + $desc .= ', ' . wp_sprintf(__('Tax: %s', 'invoicing'), $invoice->get_tax(true)); |
|
| 56 | 56 | } |
| 57 | 57 | |
| 58 | 58 | $extra_params = array(); |
| 59 | 59 | $extra_params['MC_description'] = $desc; |
| 60 | - $extra_params['MC_callback'] = wpinv_get_ipn_url( 'worldpay' ); |
|
| 60 | + $extra_params['MC_callback'] = wpinv_get_ipn_url('worldpay'); |
|
| 61 | 61 | $extra_params['MC_key'] = $invoice->get_key(); |
| 62 | 62 | $extra_params['MC_invoice_id'] = $invoice->ID; |
| 63 | 63 | $extra_params['address1'] = $address; |
| 64 | 64 | $extra_params['town'] = $invoice->city; |
| 65 | 65 | $extra_params['region'] = $invoice->state; |
| 66 | - $extra_params['amountString'] = $invoice->get_total( true ); |
|
| 67 | - $extra_params['countryString'] = wpinv_country_name( $invoice->country ); |
|
| 66 | + $extra_params['amountString'] = $invoice->get_total(true); |
|
| 67 | + $extra_params['countryString'] = wpinv_country_name($invoice->country); |
|
| 68 | 68 | $extra_params['compName'] = $invoice->company; |
| 69 | 69 | |
| 70 | - $extra_params = apply_filters( 'wpinv_worldpay_form_extra_parameters', $extra_params, $invoice ); |
|
| 70 | + $extra_params = apply_filters('wpinv_worldpay_form_extra_parameters', $extra_params, $invoice); |
|
| 71 | 71 | |
| 72 | - $redirect_text = __( 'Redirecting to Worldpay site, click on button if not redirected.', 'invoicing' ); |
|
| 73 | - $redirect_text = apply_filters( 'wpinv_worldpay_redirect_text', $redirect_text, $invoice ); |
|
| 72 | + $redirect_text = __('Redirecting to Worldpay site, click on button if not redirected.', 'invoicing'); |
|
| 73 | + $redirect_text = apply_filters('wpinv_worldpay_redirect_text', $redirect_text, $invoice); |
|
| 74 | 74 | |
| 75 | 75 | // Empty the shopping cart |
| 76 | 76 | wpinv_empty_cart(); |
| 77 | 77 | ?> |
| 78 | 78 | <div class="wpi-worldpay-form" style="padding:20px;font-family:arial,sans-serif;text-align:center;color:#555"> |
| 79 | -<?php do_action( 'wpinv_worldpay_form_before', $invoice ); ?> |
|
| 80 | -<h3><?php echo $redirect_text ;?></h3> |
|
| 79 | +<?php do_action('wpinv_worldpay_form_before', $invoice); ?> |
|
| 80 | +<h3><?php echo $redirect_text; ?></h3> |
|
| 81 | 81 | <form action="<?php echo wpinv_get_worldpay_redirect(); ?>" name="wpi_worldpay_form" method="POST"> |
| 82 | - <input type="hidden" value="<?php echo $amount;?>" name="amount"> |
|
| 83 | - <input type="hidden" value="<?php echo esc_attr( $cartId );?>" name="cartId"> |
|
| 84 | - <input type="hidden" value="<?php echo $currency;?>" name="currency"> |
|
| 85 | - <input type="hidden" value="<?php echo $instId;?>" name="instId"> |
|
| 86 | - <input type="hidden" value="<?php echo $testMode;?>" name="testMode"> |
|
| 87 | - <input type="hidden" value="<?php echo esc_attr( $name );?>" name="name"> |
|
| 88 | - <input type="hidden" value="<?php echo esc_attr( $address );?>" name="address"> |
|
| 89 | - <input type="hidden" value="<?php echo esc_attr( $postcode );?>" name="postcode"> |
|
| 90 | - <input type="hidden" value="<?php echo esc_attr( $tel );?>" name="tel"> |
|
| 91 | - <input type="hidden" value="<?php echo esc_attr( $email );?>" name="email"> |
|
| 92 | - <input type="hidden" value="<?php echo esc_attr( $country );?>" name="country"> |
|
| 93 | - <input type="hidden" value="<?php echo esc_attr( $desc );?>" name="desc"> |
|
| 94 | - <?php foreach ( $extra_params as $param => $value ) { ?> |
|
| 95 | - <?php if ( !empty( $value !== false ) ) { ?> |
|
| 96 | - <input type="hidden" value="<?php echo esc_attr( $value );?>" name="<?php echo esc_attr( $param );?>"> |
|
| 82 | + <input type="hidden" value="<?php echo $amount; ?>" name="amount"> |
|
| 83 | + <input type="hidden" value="<?php echo esc_attr($cartId); ?>" name="cartId"> |
|
| 84 | + <input type="hidden" value="<?php echo $currency; ?>" name="currency"> |
|
| 85 | + <input type="hidden" value="<?php echo $instId; ?>" name="instId"> |
|
| 86 | + <input type="hidden" value="<?php echo $testMode; ?>" name="testMode"> |
|
| 87 | + <input type="hidden" value="<?php echo esc_attr($name); ?>" name="name"> |
|
| 88 | + <input type="hidden" value="<?php echo esc_attr($address); ?>" name="address"> |
|
| 89 | + <input type="hidden" value="<?php echo esc_attr($postcode); ?>" name="postcode"> |
|
| 90 | + <input type="hidden" value="<?php echo esc_attr($tel); ?>" name="tel"> |
|
| 91 | + <input type="hidden" value="<?php echo esc_attr($email); ?>" name="email"> |
|
| 92 | + <input type="hidden" value="<?php echo esc_attr($country); ?>" name="country"> |
|
| 93 | + <input type="hidden" value="<?php echo esc_attr($desc); ?>" name="desc"> |
|
| 94 | + <?php foreach ($extra_params as $param => $value) { ?> |
|
| 95 | + <?php if (!empty($value !== false)) { ?> |
|
| 96 | + <input type="hidden" value="<?php echo esc_attr($value); ?>" name="<?php echo esc_attr($param); ?>"> |
|
| 97 | 97 | <?php } ?> |
| 98 | 98 | <?php } ?> |
| 99 | - <?php do_action( 'wpinv_worldpay_form_parameters', $invoice ); ?> |
|
| 100 | - <input type="submit" name="wpi_worldpay_submit" value="<?php esc_attr_e( 'Pay by Debit/Credit Card (WorldPay)', 'invoicing' ) ;?>"> |
|
| 99 | + <?php do_action('wpinv_worldpay_form_parameters', $invoice); ?> |
|
| 100 | + <input type="submit" name="wpi_worldpay_submit" value="<?php esc_attr_e('Pay by Debit/Credit Card (WorldPay)', 'invoicing'); ?>"> |
|
| 101 | 101 | </form> |
| 102 | 102 | <script type="text/javascript">document.wpi_worldpay_form.submit();</script> |
| 103 | -<?php do_action( 'wpinv_worldpay_form_after', $invoice ); ?> |
|
| 103 | +<?php do_action('wpinv_worldpay_form_after', $invoice); ?> |
|
| 104 | 104 | </div> |
| 105 | 105 | <?php |
| 106 | 106 | } else { |
| 107 | - wpinv_record_gateway_error( __( 'Payment Error', 'invoicing' ), sprintf( __( 'Payment creation failed while processing a worldpay payment. Payment data: %s', 'invoicing' ), json_encode( $payment_data ) ), $invoice ); |
|
| 107 | + wpinv_record_gateway_error(__('Payment Error', 'invoicing'), sprintf(__('Payment creation failed while processing a worldpay payment. Payment data: %s', 'invoicing'), json_encode($payment_data)), $invoice); |
|
| 108 | 108 | // If errors are present, send the user back to the purchase page so they can be corrected |
| 109 | - wpinv_send_back_to_checkout( '?payment-mode=' . $purchase_data['post_data']['wpi-gateway'] ); |
|
| 109 | + wpinv_send_back_to_checkout('?payment-mode=' . $purchase_data['post_data']['wpi-gateway']); |
|
| 110 | 110 | } |
| 111 | 111 | } |
| 112 | -add_action( 'wpinv_gateway_worldpay', 'wpinv_process_worldpay_payment' ); |
|
| 112 | +add_action('wpinv_gateway_worldpay', 'wpinv_process_worldpay_payment'); |
|
| 113 | 113 | |
| 114 | 114 | function wpinv_get_worldpay_redirect() { |
| 115 | - $redirect = wpinv_is_test_mode( 'worldpay' ) ? 'https://secure-test.worldpay.com/wcc/purchase' : 'https://secure.worldpay.com/wcc/purchase'; |
|
| 115 | + $redirect = wpinv_is_test_mode('worldpay') ? 'https://secure-test.worldpay.com/wcc/purchase' : 'https://secure.worldpay.com/wcc/purchase'; |
|
| 116 | 116 | |
| 117 | - return apply_filters( 'wpinv_worldpay_redirect', $redirect ); |
|
| 117 | + return apply_filters('wpinv_worldpay_redirect', $redirect); |
|
| 118 | 118 | } |
| 119 | 119 | |
| 120 | 120 | function wpinv_process_worldpay_ipn() { |
| 121 | - $request = wpinv_get_post_data( 'post' ); |
|
| 121 | + $request = wpinv_get_post_data('post'); |
|
| 122 | 122 | |
| 123 | - if ( !empty( $request['cartId'] ) && !empty( $request['transStatus'] ) && !empty( $request['installation'] ) && isset( $request['testMode'] ) && isset( $request['MC_invoice_id'] ) && isset( $request['MC_key'] ) ) { |
|
| 123 | + if (!empty($request['cartId']) && !empty($request['transStatus']) && !empty($request['installation']) && isset($request['testMode']) && isset($request['MC_invoice_id']) && isset($request['MC_key'])) { |
|
| 124 | 124 | $invoice_id = $request['MC_invoice_id']; |
| 125 | 125 | |
| 126 | - if ( $invoice_id == wpinv_get_invoice_id_by_key( $request['MC_key'] ) && $invoice = wpinv_get_invoice( $invoice_id ) ) { |
|
| 127 | - if ( $request['transStatus'] == 'Y' ) { |
|
| 128 | - wpinv_update_payment_status( $invoice_id, 'publish' ); |
|
| 129 | - wpinv_set_payment_transaction_id( $invoice_id, $request['transId'] ); |
|
| 130 | - wpinv_insert_payment_note( $invoice_id, sprintf( __( 'Worldpay Transaction ID: %s', 'invoicing' ), $request['transId'] ) ); |
|
| 126 | + if ($invoice_id == wpinv_get_invoice_id_by_key($request['MC_key']) && $invoice = wpinv_get_invoice($invoice_id)) { |
|
| 127 | + if ($request['transStatus'] == 'Y') { |
|
| 128 | + wpinv_update_payment_status($invoice_id, 'publish'); |
|
| 129 | + wpinv_set_payment_transaction_id($invoice_id, $request['transId']); |
|
| 130 | + wpinv_insert_payment_note($invoice_id, sprintf(__('Worldpay Transaction ID: %s', 'invoicing'), $request['transId'])); |
|
| 131 | 131 | return; |
| 132 | - } else if ( $request['transStatus'] == 'C' ) { |
|
| 133 | - wpinv_update_payment_status( $invoice_id, 'wpi-failed' ); |
|
| 134 | - wpinv_insert_payment_note( $invoice_id, __( 'Payment transaction failed while processing Worldpay payment, kindly check IPN log.', 'invoicing' ) ); |
|
| 132 | + } else if ($request['transStatus'] == 'C') { |
|
| 133 | + wpinv_update_payment_status($invoice_id, 'wpi-failed'); |
|
| 134 | + wpinv_insert_payment_note($invoice_id, __('Payment transaction failed while processing Worldpay payment, kindly check IPN log.', 'invoicing')); |
|
| 135 | 135 | |
| 136 | - wpinv_record_gateway_error( __( 'IPN Error', 'invoicing' ), sprintf( __( 'Payment transaction failed while processing Worldpay payment. IPN data: %s', 'invoicing' ), json_encode( $request ) ), $invoice_id ); |
|
| 136 | + wpinv_record_gateway_error(__('IPN Error', 'invoicing'), sprintf(__('Payment transaction failed while processing Worldpay payment. IPN data: %s', 'invoicing'), json_encode($request)), $invoice_id); |
|
| 137 | 137 | return; |
| 138 | 138 | } |
| 139 | 139 | } |
| 140 | 140 | } |
| 141 | 141 | return; |
| 142 | 142 | } |
| 143 | -add_action( 'wpinv_verify_worldpay_ipn', 'wpinv_process_worldpay_ipn' ); |
|
| 144 | 143 | \ No newline at end of file |
| 144 | +add_action('wpinv_verify_worldpay_ipn', 'wpinv_process_worldpay_ipn'); |
|
| 145 | 145 | \ No newline at end of file |
@@ -182,7 +182,7 @@ |
||
| 182 | 182 | $string = ""; |
| 183 | 183 | foreach ($array as $key => $value) { |
| 184 | 184 | if ($value) { |
| 185 | - $string .= '<input type="hidden" name="'.$key.'" value="'.$value.'">'; |
|
| 185 | + $string .= '<input type="hidden" name="' . $key . '" value="' . $value . '">'; |
|
| 186 | 186 | } |
| 187 | 187 | } |
| 188 | 188 | return $string; |
@@ -91,13 +91,13 @@ |
||
| 91 | 91 | return $this->_sendRequest(); |
| 92 | 92 | } |
| 93 | 93 | |
| 94 | - /** |
|
| 95 | - * |
|
| 96 | - * |
|
| 97 | - * @param string $response |
|
| 98 | - * |
|
| 99 | - * @return AuthorizeNetARB_Response |
|
| 100 | - */ |
|
| 94 | + /** |
|
| 95 | + * |
|
| 96 | + * |
|
| 97 | + * @param string $response |
|
| 98 | + * |
|
| 99 | + * @return AuthorizeNetARB_Response |
|
| 100 | + */ |
|
| 101 | 101 | protected function _handleResponse($response) |
| 102 | 102 | { |
| 103 | 103 | return new AuthorizeNetARB_Response($response); |
@@ -116,7 +116,7 @@ |
||
| 116 | 116 | */ |
| 117 | 117 | protected function _setPostString() |
| 118 | 118 | { |
| 119 | - $this->_post_string =<<<XML |
|
| 119 | + $this->_post_string = <<<XML |
|
| 120 | 120 | <?xml version="1.0" encoding="utf-8"?> |
| 121 | 121 | <ARB{$this->_request_type} xmlns= "AnetApi/xml/v1/schema/AnetApiSchema.xsd"> |
| 122 | 122 | <merchantAuthentication> |
@@ -64,8 +64,8 @@ discard block |
||
| 64 | 64 | { |
| 65 | 65 | $month = ($month ? $month : date('m')); |
| 66 | 66 | $year = ($year ? $year : date('Y')); |
| 67 | - $firstSettlementDate = substr(date('c',mktime(0, 0, 0, $month, 1, $year)),0,-6); |
|
| 68 | - $lastSettlementDate = substr(date('c',mktime(0, 0, 0, $month+1, 0, $year)),0,-6); |
|
| 67 | + $firstSettlementDate = substr(date('c', mktime(0, 0, 0, $month, 1, $year)), 0, -6); |
|
| 68 | + $lastSettlementDate = substr(date('c', mktime(0, 0, 0, $month + 1, 0, $year)), 0, -6); |
|
| 69 | 69 | return $this->getSettledBatchList(true, $firstSettlementDate, $lastSettlementDate); |
| 70 | 70 | } |
| 71 | 71 | |
@@ -98,8 +98,8 @@ discard block |
||
| 98 | 98 | $month = ($month ? $month : date('m')); |
| 99 | 99 | $day = ($day ? $day : date('d')); |
| 100 | 100 | $year = ($year ? $year : date('Y')); |
| 101 | - $firstSettlementDate = substr(date('c',mktime(0, 0, 0, (int)$month, (int)$day, (int)$year)),0,-6); |
|
| 102 | - $lastSettlementDate = substr(date('c',mktime(0, 0, 0, (int)$month, (int)$day, (int)$year)),0,-6); |
|
| 101 | + $firstSettlementDate = substr(date('c', mktime(0, 0, 0, (int)$month, (int)$day, (int)$year)), 0, -6); |
|
| 102 | + $lastSettlementDate = substr(date('c', mktime(0, 0, 0, (int)$month, (int)$day, (int)$year)), 0, -6); |
|
| 103 | 103 | $response = $this->getSettledBatchList(true, $firstSettlementDate, $lastSettlementDate); |
| 104 | 104 | $batches = $response->xpath("batchList/batch"); |
| 105 | 105 | foreach ($batches as $batch) { |
@@ -187,11 +187,11 @@ discard block |
||
| 187 | 187 | */ |
| 188 | 188 | private function _constructXml($request_type) |
| 189 | 189 | { |
| 190 | - $string = '<?xml version="1.0" encoding="utf-8"?><'.$request_type.' xmlns="AnetApi/xml/v1/schema/AnetApiSchema.xsd"></'.$request_type.'>'; |
|
| 190 | + $string = '<?xml version="1.0" encoding="utf-8"?><' . $request_type . ' xmlns="AnetApi/xml/v1/schema/AnetApiSchema.xsd"></' . $request_type . '>'; |
|
| 191 | 191 | $this->_xml = @new SimpleXMLElement($string); |
| 192 | 192 | $merchant = $this->_xml->addChild('merchantAuthentication'); |
| 193 | - $merchant->addChild('name',$this->_api_login); |
|
| 194 | - $merchant->addChild('transactionKey',$this->_transaction_key); |
|
| 193 | + $merchant->addChild('name', $this->_api_login); |
|
| 194 | + $merchant->addChild('transactionKey', $this->_transaction_key); |
|
| 195 | 195 | } |
| 196 | 196 | |
| 197 | 197 | } |
@@ -51,10 +51,10 @@ discard block |
||
| 51 | 51 | $string = ""; |
| 52 | 52 | $types = $this->__getTypes(); |
| 53 | 53 | foreach ($types as $type) { |
| 54 | - if (preg_match("/struct /",$type)) { |
|
| 55 | - $type = preg_replace("/struct /","class ",$type); |
|
| 56 | - $type = preg_replace("/ (\w+) (\w+);/"," // $1\n public \$$2;",$type); |
|
| 57 | - $string .= $type ."\n"; |
|
| 54 | + if (preg_match("/struct /", $type)) { |
|
| 55 | + $type = preg_replace("/struct /", "class ", $type); |
|
| 56 | + $type = preg_replace("/ (\w+) (\w+);/", " // $1\n public \$$2;", $type); |
|
| 57 | + $string .= $type . "\n"; |
|
| 58 | 58 | } |
| 59 | 59 | } |
| 60 | 60 | return $string; |
@@ -84,13 +84,13 @@ discard block |
||
| 84 | 84 | */ |
| 85 | 85 | public function saveSoapDocumentation($path) |
| 86 | 86 | { |
| 87 | - $string = "<?php\n"; |
|
| 87 | + $string = "<?php\n"; |
|
| 88 | 88 | $string .= "/**\n"; |
| 89 | 89 | $string .= " * Auto generated documentation for the AuthorizeNetSOAP API.\n"; |
| 90 | 90 | $string .= " * Generated " . date("m/d/Y") . "\n"; |
| 91 | 91 | $string .= " */\n"; |
| 92 | 92 | $string .= "class AuthorizeNetSOAP\n"; |
| 93 | - $string .= "{\n" . $this->getSoapMethods() . "\n}\n\n" . $this->getSoapTypes() ."\n\n ?>"; |
|
| 93 | + $string .= "{\n" . $this->getSoapMethods() . "\n}\n\n" . $this->getSoapTypes() . "\n\n ?>"; |
|
| 94 | 94 | return file_put_contents($path, $string); |
| 95 | 95 | } |
| 96 | 96 | |
@@ -76,7 +76,7 @@ |
||
| 76 | 76 | } |
| 77 | 77 | else |
| 78 | 78 | { |
| 79 | - echo "Sorry, an error occurred: " . htmlentities($_GET['response_reason_text']); |
|
| 79 | + echo "Sorry, an error occurred: " . htmlentities($_GET['response_reason_text']); |
|
| 80 | 80 | } |
| 81 | 81 | } |
| 82 | 82 | } |
@@ -57,7 +57,7 @@ discard block |
||
| 57 | 57 | else |
| 58 | 58 | { |
| 59 | 59 | // Redirect to error page. |
| 60 | - $redirect_url = $url . '?response_code='.$response->response_code . '&response_reason_text=' . $response->response_reason_text; |
|
| 60 | + $redirect_url = $url . '?response_code=' . $response->response_code . '&response_reason_text=' . $response->response_reason_text; |
|
| 61 | 61 | } |
| 62 | 62 | // Send the Javascript back to AuthorizeNet, which will redirect user back to your site. |
| 63 | 63 | echo AuthorizeNetDPM::getRelayResponseSnippet($redirect_url); |
@@ -179,54 +179,54 @@ discard block |
||
| 179 | 179 | -moz-box-shadow: inset 3px -3px 3px rgba(0,0,0,.5), inset 0 3px 3px rgba(255,255,255,.5), inset -3px 0 3px rgba(255,255,255,.75); |
| 180 | 180 | box-shadow: inset 3px -3px 3px rgba(0,0,0,.5), inset 0 3px 3px rgba(255,255,255,.5), inset -3px 0 3px rgba(255,255,255,.75); } |
| 181 | 181 | </style> |
| 182 | - <form method="post" action="'.$post_url.'"> |
|
| 183 | - '.$hidden_fields.' |
|
| 182 | + <form method="post" action="'.$post_url . '"> |
|
| 183 | + '.$hidden_fields . ' |
|
| 184 | 184 | <fieldset> |
| 185 | 185 | <div> |
| 186 | 186 | <label>Credit Card Number</label> |
| 187 | - <input type="text" class="text" size="15" name="x_card_num" value="'.($prefill ? '6011000000000012' : '').'"></input> |
|
| 187 | + <input type="text" class="text" size="15" name="x_card_num" value="'.($prefill ? '6011000000000012' : '') . '"></input> |
|
| 188 | 188 | </div> |
| 189 | 189 | <div> |
| 190 | 190 | <label>Exp.</label> |
| 191 | - <input type="text" class="text" size="4" name="x_exp_date" value="'.($prefill ? '04/17' : '').'"></input> |
|
| 191 | + <input type="text" class="text" size="4" name="x_exp_date" value="'.($prefill ? '04/17' : '') . '"></input> |
|
| 192 | 192 | </div> |
| 193 | 193 | <div> |
| 194 | 194 | <label>CCV</label> |
| 195 | - <input type="text" class="text" size="4" name="x_card_code" value="'.($prefill ? '782' : '').'"></input> |
|
| 195 | + <input type="text" class="text" size="4" name="x_card_code" value="'.($prefill ? '782' : '') . '"></input> |
|
| 196 | 196 | </div> |
| 197 | 197 | </fieldset> |
| 198 | 198 | <fieldset> |
| 199 | 199 | <div> |
| 200 | 200 | <label>First Name</label> |
| 201 | - <input type="text" class="text" size="15" name="x_first_name" value="'.($prefill ? 'John' : '').'"></input> |
|
| 201 | + <input type="text" class="text" size="15" name="x_first_name" value="'.($prefill ? 'John' : '') . '"></input> |
|
| 202 | 202 | </div> |
| 203 | 203 | <div> |
| 204 | 204 | <label>Last Name</label> |
| 205 | - <input type="text" class="text" size="14" name="x_last_name" value="'.($prefill ? 'Doe' : '').'"></input> |
|
| 205 | + <input type="text" class="text" size="14" name="x_last_name" value="'.($prefill ? 'Doe' : '') . '"></input> |
|
| 206 | 206 | </div> |
| 207 | 207 | </fieldset> |
| 208 | 208 | <fieldset> |
| 209 | 209 | <div> |
| 210 | 210 | <label>Address</label> |
| 211 | - <input type="text" class="text" size="26" name="x_address" value="'.($prefill ? '123 Main Street' : '').'"></input> |
|
| 211 | + <input type="text" class="text" size="26" name="x_address" value="'.($prefill ? '123 Main Street' : '') . '"></input> |
|
| 212 | 212 | </div> |
| 213 | 213 | <div> |
| 214 | 214 | <label>City</label> |
| 215 | - <input type="text" class="text" size="15" name="x_city" value="'.($prefill ? 'Boston' : '').'"></input> |
|
| 215 | + <input type="text" class="text" size="15" name="x_city" value="'.($prefill ? 'Boston' : '') . '"></input> |
|
| 216 | 216 | </div> |
| 217 | 217 | </fieldset> |
| 218 | 218 | <fieldset> |
| 219 | 219 | <div> |
| 220 | 220 | <label>State</label> |
| 221 | - <input type="text" class="text" size="4" name="x_state" value="'.($prefill ? 'MA' : '').'"></input> |
|
| 221 | + <input type="text" class="text" size="4" name="x_state" value="'.($prefill ? 'MA' : '') . '"></input> |
|
| 222 | 222 | </div> |
| 223 | 223 | <div> |
| 224 | 224 | <label>Zip Code</label> |
| 225 | - <input type="text" class="text" size="9" name="x_zip" value="'.($prefill ? '02142' : '').'"></input> |
|
| 225 | + <input type="text" class="text" size="9" name="x_zip" value="'.($prefill ? '02142' : '') . '"></input> |
|
| 226 | 226 | </div> |
| 227 | 227 | <div> |
| 228 | 228 | <label>Country</label> |
| 229 | - <input type="text" class="text" size="22" name="x_country" value="'.($prefill ? 'US' : '').'"></input> |
|
| 229 | + <input type="text" class="text" size="22" name="x_country" value="'.($prefill ? 'US' : '') . '"></input> |
|
| 230 | 230 | </div> |
| 231 | 231 | </fieldset> |
| 232 | 232 | <input type="submit" value="BUY" class="submit buy"> |
@@ -53,16 +53,14 @@ discard block |
||
| 53 | 53 | { |
| 54 | 54 | // Do your processing here. |
| 55 | 55 | $redirect_url = $url . '?response_code=1&transaction_id=' . $response->transaction_id; |
| 56 | - } |
|
| 57 | - else |
|
| 56 | + } else |
|
| 58 | 57 | { |
| 59 | 58 | // Redirect to error page. |
| 60 | 59 | $redirect_url = $url . '?response_code='.$response->response_code . '&response_reason_text=' . $response->response_reason_text; |
| 61 | 60 | } |
| 62 | 61 | // Send the Javascript back to AuthorizeNet, which will redirect user back to your site. |
| 63 | 62 | echo AuthorizeNetDPM::getRelayResponseSnippet($redirect_url); |
| 64 | - } |
|
| 65 | - else |
|
| 63 | + } else |
|
| 66 | 64 | { |
| 67 | 65 | echo "Error -- not AuthorizeNet. Check your MD5 Setting."; |
| 68 | 66 | } |
@@ -73,8 +71,7 @@ discard block |
||
| 73 | 71 | if ($_GET['response_code'] == 1) |
| 74 | 72 | { |
| 75 | 73 | echo "Thank you for your purchase! Transaction id: " . htmlentities($_GET['transaction_id']); |
| 76 | - } |
|
| 77 | - else |
|
| 74 | + } else |
|
| 78 | 75 | { |
| 79 | 76 | echo "Sorry, an error occurred: " . htmlentities($_GET['response_reason_text']); |
| 80 | 77 | } |