AlipayThirdGoodsJob.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. <?php
  2. namespace app\jobs;
  3. use app\models\AlipayGoodsLog;
  4. use app\models\Attr;
  5. use app\models\AttrGroup;
  6. use app\models\Goods;
  7. use app\models\GoodsPic;
  8. use app\models\StoreAliMini;
  9. use app\modules\admin\models\AlipayThirdForm;
  10. use app\utils\Alipay\alipaySdk\aop\request\AlipayMarketingImageEnhanceUploadRequest;
  11. use app\utils\Alipay\alipaySdk\aop\request\AlipayOpenAppItemCreateRequest;
  12. use app\utils\Alipay\alipaySdk\aop\request\AlipayOpenAppItemModifyRequest;
  13. use yii\base\BaseObject;
  14. use yii\queue\JobInterface;
  15. /**
  16. * 支付宝商品添加
  17. */
  18. class AlipayThirdGoodsJob extends BaseObject implements JobInterface
  19. {
  20. public $id;
  21. public $goods_id;
  22. public $out_item_id;
  23. public $category_id;
  24. public $store_id;
  25. public function execute($queue)
  26. {
  27. try {
  28. $id = $this->id;
  29. $store_id = $this->store_id;
  30. $goods_id = $this->goods_id;
  31. $out_item_id = $this->out_item_id;
  32. $category_id = $this->category_id;
  33. $store_mini = StoreAliMini::findOne($id);
  34. if (empty($goods_id) && strpos($out_item_id, 'cyy_') === 0) {
  35. $goods_id = str_replace('cyy_', '', $out_item_id);
  36. }
  37. if (empty($goods_id)) {
  38. throw new \Exception('非本商城商品,不可操作');
  39. }
  40. $is_edit = 0;
  41. $request = new AlipayOpenAppItemCreateRequest();
  42. //判断是否添加过商品
  43. $alipayGoodsLog = AlipayGoodsLog::get($id, $goods_id);
  44. if ($alipayGoodsLog) {
  45. $is_edit = 1;
  46. $request = new AlipayOpenAppItemModifyRequest();
  47. }
  48. $form = new AlipayThirdForm();
  49. $goodsInfo = Goods::findOne(['id' => $goods_id, 'store_id' => $store_id]);
  50. $marketingImageResult = $form->uploadMarketingImage($id, $goodsInfo->cover_pic);
  51. if ($marketingImageResult['code']) {
  52. throw new \Exception('添加主图失败' . $marketingImageResult['msg']);
  53. }
  54. $goods_pic_list = GoodsPic::find()->where(['goods_id' => $goods_id, 'is_delete' => 0])
  55. ->select('pic_url')->limit(3)->column();
  56. $image_list = [];
  57. foreach ($goods_pic_list as $goods_pic_item) {
  58. $marketingPicListImageResult = $form->uploadMarketingImage($id, $goods_pic_item, AlipayMarketingImageEnhanceUploadRequest::ITEM_IMAGE_LIST);
  59. if (!$marketingPicListImageResult['code']) {
  60. $image_list[] = $marketingPicListImageResult['data']['image_id'];
  61. }
  62. }
  63. $sale_status = 'AVAILABLE';
  64. if (!intval($goodsInfo->status)) {
  65. $sale_status = 'DELISTING';
  66. }
  67. if (intval($goodsInfo->is_delete)) {
  68. $sale_status = 'FREEZE';
  69. }
  70. $sku_list = [];
  71. if (intval($goodsInfo->use_attr)) {
  72. Goods::skuAttr($goodsInfo);
  73. $goods_attr = json_decode($goodsInfo->attr, true);
  74. foreach ($goods_attr as $goods_attr_index => $goods_attr_item) {
  75. $sku_list[$goods_attr_index]['sale_status'] = intval($goodsInfo->is_delete) ? $sale_status : 'DELISTING';
  76. if ($goods_attr_item['num'] > 0) {
  77. $sku_list[$goods_attr_index]['sale_status'] = $sale_status;
  78. }
  79. $sku_attr_list = [];
  80. foreach ($goods_attr_item['attr_list'] as $attr_item) {
  81. $attr_name_arr = Attr::find()->alias('a')->leftJoin(['ag' => AttrGroup::tableName()], 'a.attr_group_id = ag.id')
  82. ->where(['a.id' => $attr_item['attr_id']])->select('a.attr_name, ag.attr_group_name')
  83. ->asArray()->one();
  84. $sku_attr_list[] = [
  85. 'attr_key' => $attr_name_arr['attr_group_name'],
  86. 'attr_value' => $attr_name_arr['attr_name']
  87. ];
  88. }
  89. $sku_list[$goods_attr_index]['sku_attrs'] = $sku_attr_list;
  90. $sku_list[$goods_attr_index]['sale_price'] = bcmul($goods_attr_item['price'], 100);
  91. $sku_list[$goods_attr_index]['out_sku_id'] = $goods_attr_item['cyy_skuId'];
  92. $thumb_img = '';
  93. $marketingAttrImageResult = $form->uploadMarketingImage($id, $goods_attr_item['pic'], AlipayMarketingImageEnhanceUploadRequest::ITEM_SKU_THUMB_IMG);
  94. if (!$marketingAttrImageResult['code']) {
  95. $thumb_img = $marketingAttrImageResult['data']['image_id'];
  96. }
  97. $sku_list[$goods_attr_index]['thumb_img'] = $thumb_img;
  98. $sku_list[$goods_attr_index]['stock_num'] = $goods_attr_item['num'];
  99. $sku_list[$goods_attr_index]['barcode'] = $goods_attr_item['no'];
  100. $sku_list[$goods_attr_index]['original_price'] = bcmul($goods_attr_item['original_price'], 100);
  101. $sku_list[$goods_attr_index]['sku_type'] = 'SALE';
  102. }
  103. }
  104. $data = [
  105. 'title' => $goodsInfo->name,
  106. 'path' => "alipays://platformapi/startApp?appId={$store_mini->auth_app_id}page=goods/goods/goods?id=" . $goodsInfo->id,
  107. 'head_img' => $marketingImageResult['data']['image_id'],
  108. 'category_id' => $category_id,//test
  109. 'out_item_id' => 'cyy_' . $goodsInfo->id,
  110. 'sale_price' => bcmul($goodsInfo->price, 100),
  111. 'original_price' => bcmul($goodsInfo->original_price, 100),
  112. 'sale_status' => $sale_status, //可售卖: AVAILABLE; 已下架: DELISTING; 冻结: FREEZE
  113. 'item_type' => '1',
  114. 'desc' => '',
  115. 'direct_path' => "alipays://platformapi/startApp?appId={$store_mini->auth_app_id}page=goods/goods/goods?id=" . $goodsInfo->id,
  116. 'image_list' => $image_list,
  117. 'price_unit' => '元',
  118. 'stock_num' => $goodsInfo->goods_num,
  119. 'skus' => $sku_list,
  120. 'barcode' => $goodsInfo->goods_no,
  121. 'item_details_page_model' => 1
  122. ];
  123. if (empty(trim($category_id))) {
  124. unset($data['category_id']);
  125. }
  126. if (intval($goodsInfo->use_attr)) {
  127. unset($data['sale_price'], $data['original_price'], $data['sale_status'], $data['stock_num']);
  128. } else {
  129. unset($data['skus']);
  130. }
  131. if (!$is_edit) {
  132. unset($data['direct_path']);
  133. } else {
  134. unset($data['item_details_page_model']);
  135. }
  136. \Yii::error($data);
  137. $form->biz_content = json_encode($data);
  138. $result = $form->miniCommon($request, 0, $id);
  139. if (!empty($result->code) && $result->code == 10000) {
  140. AlipayGoodsLog::add($id, $goods_id, $result->item_id);
  141. return [
  142. 'code' => 0,
  143. 'msg' => "成功",
  144. 'data' => $result
  145. ];
  146. } else {
  147. throw new \Exception($result->sub_msg);
  148. }
  149. } catch (\Exception $e) {
  150. debug_log($e->getMessage(), 'alipay_goods.log');
  151. return [
  152. 'code' => 1,
  153. 'msg' => $e->getMessage()
  154. ];
  155. }
  156. }
  157. }