/** * Add feedback * * @param mixed $writerID * @param mixed $score * @param mixed $feedback * @param mixed $activityID * @param mixed $activityType * @return int|null|string|void */ public function addFeedback($writerID, $score, $feedback, $activityID, $activityType = BuckysFeedback::ACTIVITY_TYPE_TRADE) { global $db; if (!is_numeric($activityID) || !is_numeric($writerID) || !is_numeric($score) || $feedback == '') { return; } // failed //If you left feedback already, then return if ($this->hasFeedback($writerID, $activityID, $activityType)) { return; } //exists $param = ['activityID' => $activityID, 'activityType' => $activityType, 'writerID' => $writerID, 'score' => $score, 'comment' => $feedback, 'createdDate' => date('Y-m-d H:i:s')]; $otherUserID = null; switch ($activityType) { case BuckysFeedback::ACTIVITY_TYPE_TRADE: $tradeIns = new BuckysTrade(); $tradeData = $tradeIns->getTradeByID($activityID); if (!$tradeData) { return; } //no such trade if ($tradeData['sellerID'] == $writerID) { $otherUserID = $param['receiverID'] = $tradeData['buyerID']; $param['itemID'] = $tradeData['buyerItemID']; } else { if ($tradeData['buyerID'] == $writerID) { $otherUserID = $param['receiverID'] = $tradeData['sellerID']; $param['itemID'] = $tradeData['sellerItemID']; } else { return; //no rights } } break; case BuckysFeedback::ACTIVITY_TYPE_SHOP: $shopOrderIns = new BuckysShopOrder(); $orderData = $shopOrderIns->getOrderByID($activityID); if (!$orderData || $orderData['buyerID'] != $writerID) { return; } //no such trade $otherUserID = $param['receiverID'] = $orderData['sellerID']; $param['itemID'] = $orderData['productID']; break; default: return; //no such cases break; } $newID = $db->insertFromArray(TABLE_FEEDBACK, $param); if ($newID && $otherUserID) { //Update TradeUser Table for rating calculation $this->_updateRanking($otherUserID); } //Create notification $tradeNotificationIns = new BuckysTradeNotification(); $tradeNotificationIns->createNotification($otherUserID, $writerID, BuckysTradeNotification::ACTION_TYPE_FEEDBACK, $newID); return $newID; }
/** * Save feedback; */ function saveFeedback() { $userID = buckys_is_logged_in(); if (!$userID) { //You should be logged in return; } else { $feedbackIns = new BuckysFeedback(); $orderIns = new BuckysShopOrder(); $orderID = get_secure_integer($_REQUEST['orderID']); $score = get_secure_string($_REQUEST['score']); $feedback = get_secure_string($_REQUEST['feedback']); $orderData = $orderIns->getOrderByID($orderID); $feedbackID = null; if ($orderData['buyerID'] == $userID) { $feedbackID = $feedbackIns->addFeedback($userID, $score, $feedback, $orderID, BuckysFeedback::ACTIVITY_TYPE_SHOP); } if (!$feedbackID) { echo json_encode(['success' => 0, 'msg' => "You do not have permission."]); } else { echo json_encode(['success' => 1, 'msg' => "You have left feedback successfully."]); } } }