123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250 |
- <?php
- namespace app\admin\service\coupon;
- use app\model\Coupon;
- use app\model\CouponDetail;
- use app\model\Goods;
- use support\Db;
- use support\exception\BusinessException;
- use support\Log;
- class CouponService
- {
- /**
- * @Desc 优惠券自动过期
- * @Author Gorden
- * @Date 2024/8/26 17:58
- *
- * @return void
- */
- public static function checkCouponExpired()
- {
- $couponDetails = Db::select("select * from app_coupon_detail where (coupon_detail_status = 'INIT' OR coupon_detail_status = 'PENDING' OR coupon_detail_status = 'ACTIVED' OR coupon_detail_status = 'WAITING') AND coupon_detail_deadline_datetime != '' AND CAST(UNIX_TIMESTAMP(coupon_detail_deadline_datetime) as SIGNED) < " . time());
- foreach ($couponDetails as $detail) {
- $endTimeUnix = strtotime($detail->coupon_detail_deadline_datetime);
- if ($endTimeUnix < time()) {
- CouponDetail::where('coupon_detail_id', $detail->coupon_detail_id)->update(['coupon_detail_status' => 'EXPIRED']);
- echo $detail->coupon_detail_id . "已过期\n";
- }
- }
- }
- /**
- * @Desc
- * @Author Gorden
- * @Date 2024/9/18 11:44
- *
- * @return void
- */
- public static function sendPeriodCoupon()
- {
- Db::beginTransaction();
- try {
- $coupons = Coupon::where('coupon_is_period', 'Y')->where('coupon_status', 'ACTIVED')->get()->toArray();
- // dump("周期全",$coupons);
- foreach ($coupons as $coupon) {
- if (!empty($coupon['coupon_validdate_end']) && time() > strtotime($coupon['coupon_validdate_end'])) {
- continue;
- }
- $details = CouponDetail::where('join_detail_coupon_id', $coupon['coupon_id'])
- ->where('join_coupon_detail_member_id', '<>', '')
- ->selectRaw('join_coupon_detail_member_id,COUNT(*) as count')
- ->groupBy('join_coupon_detail_member_id')
- ->get();
- foreach ($details as $item) {
- $detail = CouponDetail::where('join_detail_coupon_id', $coupon['coupon_id'])
- ->where('join_coupon_detail_member_id', $item->join_coupon_detail_member_id)
- ->orderBy('coupon_detail_addtimes', 'DESC')
- ->first();
- if (strtotime($detail->coupon_detail_deadline_datetime) > time()) {
- continue;
- } elseif (empty($coupon['coupon_validdate_end']) && !empty($coupon['coupon_validdate_day'])) {
- $firstDetail = CouponDetail::where('join_detail_coupon_id', $coupon['coupon_id'])
- ->where('join_coupon_detail_member_id', $item->join_coupon_detail_member_id)
- ->orderBy('coupon_detail_addtimes', 'ASC')
- ->first();
- if ((time() - strtotime($firstDetail->coupon_detail_addtimes)) > (3600 * 24 * $coupon['coupon_validdate_day'])) {
- continue;
- }
- }
- $params = [
- 'coupon_detail_gain_datetime' => date('Y-m-d 00:00:00'),
- 'coupon_id' => $coupon['coupon_id'],
- 'member_id' => $detail->join_coupon_detail_member_id,
- 'coupon_detail_period_num' => $detail->coupon_detail_period_num + 1
- ];
- // 超出期数
- if (!empty($coupon['coupon_period_json'])) {
- $periodJson = json_decode($coupon['coupon_period_json'], true);
- if ($periodJson['nbr'] < $params['coupon_detail_period_num']) {
- continue;
- }
- if ($periodJson['unit'] == 'day') {
- $val = $periodJson['val'] - 1;
- if ($val < 1) {
- $params['coupon_detail_deadline_datetime'] = date('Y-m-d 23:59:59');
- } else {
- $params['coupon_detail_deadline_datetime'] = date('Y-m-t 23:59:59', strtotime("+" . $val . " day"));
- }
- } elseif ($periodJson['unit'] == 'week') {
- $val = $periodJson['val'] - 1;
- if ($val < 1) {
- $params['coupon_detail_deadline_datetime'] = date('Y-m-d 23:59:59', strtotime('this week Sunday'));
- } else {
- $params['coupon_detail_deadline_datetime'] = date('Y-m-t 23:59:59', strtotime("+" . $val . ' week', date('Y-m-d', strtotime("+" . $val . " month"))));
- }
- } elseif ($periodJson['unit'] == 'month') {
- $val = $periodJson['val'] - 1;
- if ($val < 1) {
- $params['coupon_detail_deadline_datetime'] = date('Y-m-t 23:59:59');
- } else {
- $params['coupon_detail_deadline_datetime'] = date('Y-m-t 23:59:59', strtotime("+" . $val . " month"));
- }
- }
- }
- if (CouponDetail::whereIn('coupon_detail_status', ['INIT', 'PENDING'])->exists()) {
- // 匹配已发行的优惠券
- $params['chooseCouponNbr'] = 1;
- CouponDetailService::customSendCouponHave($params);
- } else {
- // 写入优惠券
- CouponDetailService::customSendCoupon($params);
- }
- _syslog("周期券", "发放周期券", false, $params, 1001);
- }
- }
- Db::commit();
- } catch (\Exception $e) {
- dump($e->getTrace());
- Db::rollBack();
- }
- }
- public static function couponClassifyInfo($classify, $category, $value, $limit)
- {
- try {
- switch ($classify) {
- case "满减券":
- if (!empty($limit) && $category == 'NORMAL') {
- return "满" . $limit . '减' . $value;
- } elseif (!empty($limit) && !empty($value) && $category == 'PIECE') {
- return "满" . intval($limit) . '件减' . $value;
- }
- break;
- case "立减券":
- return "立减" . $value;
- break;
- case "抵用券":
- return "抵用券";
- break;
- case "折扣券":
- if (!empty($limit) && $category == 'NORMAL') {
- return "满" . $limit . '打' . ($value / 10) . '折';
- } else if (!empty($limit) && !empty($value) && $category == 'PIECE') {
- return "满" . intval($limit) . '件打' . ($value / 10) . '折';
- } else {
- return $value / 10 . '折';
- }
- break;
- case "赠品券":
- return "赠品券";
- break;
- case "福利券":
- return '抵扣' . $value;
- break;
- case "年卡":
- return "年卡";
- break;
- case "季卡":
- return "季卡";
- break;
- case "月卡":
- return "月卡";
- break;
- }
- } catch (\Exception $e) {
- }
- }
- /**
- * @Desc
- * @Author Gorden
- * @Date 2024/9/28 14:00
- *
- * @param $params
- * join_sheet_goods_id 关联测产品
- * member_id 接收人
- * @return void
- * @throws BusinessException
- */
- public static function autoSendCouponByGoods($params)
- {
- try {
- $gettype = $params['gettype'] ?? '';
- $goods = Goods::where('goods_id', $params['join_sheet_goods_id'])->select('goods_attribute_json')->first();
- if (!empty($goods) && !empty($goods->goods_attribute_json)) {
- $goodsAttributeJson = json_decode($goods->goods_attribute_json, true);
- if (!empty($goodsAttributeJson['coupon'])) {
- foreach ($goodsAttributeJson['coupon'] as $key => $coupon) {
- $couponModel = Coupon::where('coupon_id', $key)->select('coupon_id', 'coupon_validdate_day', 'coupon_validdate_end', 'coupon_is_period', 'coupon_number')->first();
- if (empty($couponModel)) {
- continue;
- }
- // 券是否过期
- if (!empty($couponModel->coupon_validdate_end) && strtotime($couponModel->coupon_validdate_end) < time()) {
- continue;
- }
- // 发周期券
- if ($couponModel->coupon_is_period == 'Y') {
- // 发券参数
- $couponSendParams = ['gettype' => $gettype, 'coupon_id' => $key, 'member_id' => $params['member_id']];
- Log::info("发周期券参数", $couponSendParams);
- CouponDetailService::sendPeriodCoupon($couponSendParams);
- continue;
- }
- $couponResidue = 'all';
- if ($couponModel->coupon_number != 0) {
- $couponResidue = CouponDetail::where('join_detail_coupon_id', $key)->whereIn('coupon_detail_status', ['INIT', 'PENDING'])->count();
- // 超出优惠券设置的数量
- if ($couponResidue < $coupon['num']) {
- continue;
- }
- }
- $endDate = '';
- if (!empty($couponModel->coupon_validdate_end)) {
- $endDate = $couponModel->coupon_validdate_end;
- } elseif ($couponModel->coupon_validdate_day > 0) {
- $endDate = date('Y-m-d H:i:s', time() + ($couponModel->coupon_validdate_day * 24 * 3600) - 1);
- }
- // 发券参数
- $couponSendParams = [
- 'gettype' => $gettype,
- 'coupon_id' => $key,
- 'chooseCouponNbr' => $coupon['num'],
- 'member_id' => $params['member_id'],
- 'coupon_detail_gain_datetime' => date('Y-m-d H:i:s'),
- 'coupon_detail_deadline_datetime' => $endDate,
- ];
- Log::info("发普通券参数", $couponSendParams);
- if ($couponResidue != 'all' && $couponResidue - $coupon['num'] >= 0) {
- CouponDetailService::customSendCouponHave($couponSendParams);
- } else {
- for ($i = 0; $i < $coupon['num']; $i++) {
- CouponDetailService::customSendCoupon($couponSendParams);
- }
- }
- }
- }
- }
- }catch (\Exception $e){
- Log::info("优惠券发放失败:".$e->getMessage());
- throw new BusinessException("优惠券发放失败");
- }
- }
- }
|