| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314 |
- <?php
- namespace app\controller\api;
- use app\extra\basic\Base;
- use app\extra\dyLife\Crypt;
- use app\extra\dyMini\Pay;
- use app\middleware\AuthMiddleware;
- use app\model\saas\SaasComplaint;
- use app\model\saas\SaasOrder;
- use app\model\saas\SaasOrderPrice;
- use app\service\saas\OrderService;
- use DI\Attribute\Inject;
- use LinFly\Annotation\Attributes\Route\Controller;
- use LinFly\Annotation\Attributes\Route\GetMapping;
- use LinFly\Annotation\Attributes\Route\Middleware;
- use LinFly\Annotation\Attributes\Route\PostMapping;
- use support\Request;
- use support\Response;
- #[Controller("/dy/order"),Middleware(AuthMiddleware::class)]
- class Order extends Base
- {
- #[Inject]
- protected SaasOrder $model;
- #[Inject]
- protected OrderService $service;
- #[GetMapping('list')]
- public function getDataList(Request $request): Response
- {
- try {
- $param = $request->all();
- if (!empty($param['size'])) {
- $param['pageSize'] = $param['size'];
- }
- $param['openid'] = $request->user['openid'];
- $data = $this->service->setModel()->getList($param,['product' => function($query){
- $query->field("product_id,product_name");
- }]);
- return successTrans("success.data",pageFormat($data));
- } catch (\Throwable $th) {
- return error($th->getMessage());
- }
- }
- #[PostMapping("del")]
- public function delOrderData(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "order.require" => trans("empty.require"),
- "type.require" => trans("empty.require"),
- ],$request->method());
- if (!is_array($param)) return error($param);
- $order = $this->model->where("order_sn",$param['order'])->with(['product','poi'])->findOrEmpty();
- if ($order->isEmpty()) return errorTrans("empty.data");
- if ($order['openid'] <> $request->user['openid']) return errorTrans("empty.data");
- switch ($param['type']) {
- case "del": // 删除订单
- if ($order['status'] <> 5) return error("该订单不支持删除");
- $state = $order->delete();
- break;
- case "cancel": // 取消订单
- if ($order['status'] <> 0) return error("该订单不支持取消");
- $order->status = 5;
- $state = $order->save();
- break;
- default:
- $state = false;
- break;
- }
- if (!$state) return errorTrans("error.data");
- return successTrans("success.data");
- } catch (\Throwable $throwable) {
- return error($throwable->getMessage());
- }
- }
- #[PostMapping("refund")]
- public function orderRefund(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "order.require" => trans("empty.require"),
- "refund.require" => trans("empty.require"),
- ],$request->method());
- if (!is_array($param)) return error($param);
- $order = $this->model->where("order_sn",$param['order'])->with(['product','poi'])->findOrEmpty();
- if ($order->isEmpty()) return errorTrans("empty.data");
- if ($order['openid'] <> $request->user['openid']) return errorTrans("empty.data");
- if ($order['status'] <> 1) return error("当前订单不支持退款");
- $reason = explode(",",$param['refund']);
- $payParam = [
- "order_sn" => $order['order_sn'],
- "total" => $order['pay_money'],
- "reason" => $reason[0]??'不想要了',
- "out_refund_no" => $order['pay_sn'],
- "notify_url" => "https://tran.jsshuita.cn/notify/refund"
- ];
- $byteAuthorization = (new Pay)->config([
- "appid" => sConf("wechat.mini_appid"),
- "secret" => sConf("wechat.mini_secret"),
- "salt" => sConf("wechat.mch_salt"),
- ])->createRefund($payParam);
- if (!$byteAuthorization) return error("发起退款失败");
- $order->status = 4;
- $order->refund_apply = getDateFull();
- $state = $order->save();
- if (!$state) return errorTrans("error.data");
- return successTrans("提交申请成功");
- } catch (\Throwable $throwable) {
- return error($throwable->getMessage());
- }
- }
- #[GetMapping('detail')]
- public function getDataDetail(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "order.require" => trans("empty.require")
- ],$request->method());
- if (!is_array($param)) return error($param);
- $order = $this->model->where("out_order_no",$param['order'])->with(['product','poi'])->findOrEmpty();
- if ($order->isEmpty()) return errorTrans("empty.data");
- $order['end_time'] = timeDiff(strtotime("+30 minutes",strtotime($order['create_at'])),time());
- return $this->encode("ok",$order->toArray());
- } catch (\Throwable $th) {
- return error($th->getMessage());
- }
- }
- #[GetMapping("confirm")]
- public function confirmOrder(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "order.require" => trans("empty.require")
- ],$request->method());
- if (!is_array($param)) return error($param);
- $order = $this->model->where("order_sn",$param['order'])->with(['product','poi'])->findOrEmpty();
- if ($order->isEmpty()) return errorTrans("empty.data");
- if ($order['status'] <> 0) return errorTrans("empty.data");
- return $this->encode("ok",$order->toArray());
- } catch (\Throwable $throwable) {
- return error($throwable->getMessage());
- }
- }
- /**
- * 差价支付
- * @param Request $request
- * @return Response
- */
- #[PostMapping("pricePay")]
- public function orderPricePay(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "order.require" => trans("empty.require")
- ],$request->method());
- if (!is_array($param)) return error($param);
- $order = (new SaasOrderPrice)->where("order_sn",$param['order'])->findOrEmpty();
- $payParam = [
- "order_sn" => $order['order_sn'],
- "total" => $order['price'],
- "name" => $order['name'],
- "notify_url" => "https://tran.jsshuita.cn/notify/price"
- ];
- $byteAuthorization = (new Pay)->config([
- "appid" => sConf("wechat.mini_appid"),
- "secret" => sConf("wechat.mini_secret"),
- "salt" => sConf("wechat.mch_salt"),
- ])->createOrder($payParam);
- return success("ok",['pay' => $byteAuthorization]);
- } catch (\Throwable $throwable) {
- return error($throwable->getMessage());
- }
- }
- /**
- * 发起支付
- * @param Request $request
- * @return Response
- */
- #[PostMapping("toPay")]
- public function orderPay(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "order.require" => trans("empty.require"),
- "mobile.default" => ""
- ],$request->method());
- if (!is_array($param)) return error($param);
- $order = $this->model->where("order_sn",$param['order'])->with(['product','poi'])->findOrEmpty();
- $payParam = [
- "order_sn" => $order['order_sn'],
- "total" => $order['price'],
- "name" => $order['product']['product_name'],
- "notify_url" => "https://tran.jsshuita.cn/notify/douyin"
- ];
- $byteAuthorization = (new Pay)->config([
- "appid" => sConf("wechat.mini_appid"),
- "secret" => sConf("wechat.mini_secret"),
- "salt" => sConf("wechat.mch_salt"),
- ])->createOrder($payParam);
- if (!empty($param['mobile'])) {
- $order->mobile = $param['mobile'];
- $order->save();
- }
- return success("ok",['pay' => $byteAuthorization]);
- } catch (\Throwable $throwable) {
- return error($throwable->getMessage());
- }
- }
- /**
- * 交易组件获取手机号码
- * @param Request $request
- * @return Response
- */
- #[PostMapping("mobile")]
- public function getOrderMobile(Request $request): Response
- {
- try {
- $param = $request->post();
- $mobile = [];
- if (!empty($param['code'])) {
- $mobileStr = (new Crypt)->config($this->getDyConfig())->token()->getMobile($param['code']);
- if (!empty($mobileStr)) {
- $mobile = $this->decrypt2code(sConf('wechat.min_private_key'), $mobileStr);
- }
- }
- $mobileStr = "";
- if (!empty($mobile['purePhoneNumber'])) {
- $mobileStr = $mobile['purePhoneNumber'];
- }
- return success("ok",['mobile' => $mobileStr]);
- } catch (\Throwable $throwable) {
- return error($throwable->getMessage());
- }
- }
- /**
- * 订单投诉
- * @param Request $request
- * @return Response
- */
- #[PostMapping("complaint")]
- public function setOrderComplaint(Request $request): Response
- {
- try {
- $param = $this->_valid([
- "content.require" => trans("empty.require"),
- "mobile.default" => "",
- "order.require" => trans("empty.require"),
- "text.require" => trans("empty.require"),
- "poi_id.require" => trans("empty.require"),
- ],$request->method());
- if (!is_array($param)) return error($param);
- $order = (new SaasOrder)->where("out_order_no",$param['order'])->findOrEmpty();
- if ($order->isEmpty()) return error("该笔交易不存在");
- if ($order['openid'] <> $request->user['openid']) return error("非法操作");
- $state = (new SaasComplaint)->insertGetId([
- "openid" => $request->user['openid'],
- "poi_id" => $param['poi_id'],
- "content" => $param['content'],
- "question" => $param['text'],
- "order_sn" => $order['order'],
- "mobile" => $param['mobile']??$order['mobile'],
- ]);
- if (!$state) return error("提交失败");
- return success("提交成功,请耐心等待");
- } catch (\Throwable $throwable) {
- return error($throwable->getMessage());
- }
- }
- protected function decrypt2code($private_key, $ciphertext_str) {
- // 解码 base64 密文
- $ciphertext = base64_decode($ciphertext_str);
- // 使用私钥解密
- openssl_private_decrypt($ciphertext, $plaintext, $private_key, OPENSSL_PKCS1_PADDING);
- if ($plaintext === false) {
- return [];
- }
- return json_decode($plaintext,true);
- }
- protected function decrypt($encrypted_data, $session_key, $iv) {
- $data = base64_decode($encrypted_data);
- $key = base64_decode($session_key);
- $iv_decoded = base64_decode($iv);
- // 使用 AES-256-CBC 模式解密
- $decrypted = openssl_decrypt($data, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv_decoded);
- return $decrypted;
- }
- }
|