/home/awneajlw/faizastore.com/wp-content/plugins/shopengine/modules/wishlist/route.php
<?php
namespace ShopEngine\Modules\Wishlist;
use ShopEngine\Base\Api;
class Route extends Api {
public function config() {
$this->prefix = 'wishlist';
$this->param = "";
$this->customer_only = true;
}
public function post_add_to_list() {
// Verify nonce for CSRF protection
$nonce = $this->request->get_header('X-WP-Nonce');
if (empty($nonce) || !wp_verify_nonce($nonce, 'wp_rest')) {
return new \WP_Error('rest_forbidden', esc_html__('Invalid nonce.', 'shopengine'), array('status' => 403));
}
$data = $this->request->get_params();
$idd = $data['product_id'];
if(empty($idd)) {
return [
'status' => 'failed',
'message' => esc_html__('Product id not found.', 'shopengine'),
];
}
if(is_user_logged_in()) {
$uid = get_current_user_id();
$content = get_user_meta( $uid, Wishlist::UMK_WISHLIST, true );
$content = empty($content) ? [] : $content;
if(isset($content[$idd])) {
$msg = esc_html__('Successfully removed from wishlist', 'shopengine');
$action = 'removed';
unset($content[$idd]);
} else {
$msg = esc_html__('Successfully added into wishlist', 'shopengine');
$action = 'add';
$content[$idd] = $idd;
}
update_user_meta( $uid, Wishlist::UMK_WISHLIST, $content );
return [
'status' => 'success',
'message' => $msg,
'todo' => $action,
];
}
$cck = empty($_COOKIE[Wishlist::COOKIE_KEY]) ? '' : sanitize_text_field(wp_unslash($_COOKIE[Wishlist::COOKIE_KEY]));
$cck = explode(',', $cck);
$content = array_combine($cck, $cck);
if(isset($content[$idd])) {
$msg = esc_html__('Successfully removed from wishlist', 'shopengine');
$action = 'removed';
unset($content[$idd]);
} else {
$msg = esc_html__('Successfully added into wishlist', 'shopengine');
$action = 'add';
$content[$idd] = $idd;
}
$val = implode(',', $content);
setcookie(Wishlist::COOKIE_KEY, $val, strtotime( '+30 days'), '/' );
return [
'status' => 'success',
'message' => $msg,
'dd' => Wishlist::COOKIE_KEY,
'todo' => $action,
];
}
}