6
0
Fork 0

调整物流订阅推送

release
vine_liutk 2021-12-18 13:06:48 +08:00
parent 8135c6942e
commit fb366523f4
9 changed files with 1463 additions and 1324 deletions

View File

@ -5,6 +5,8 @@ namespace App\Endpoint\Callback\Http\Controllers;
use App\Services\Kuaidi100Service; use App\Services\Kuaidi100Service;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Arr; use Illuminate\Support\Arr;
use Illuminate\Support\Facades\DB;
use Throwable;
class Kuaidi100Controller extends Controller class Kuaidi100Controller extends Controller
{ {
@ -13,14 +15,21 @@ class Kuaidi100Controller extends Controller
* @param \Illuminate\Http\Request $request * @param \Illuminate\Http\Request $request
* @return void * @return void
*/ */
public function callback(Request $request, Kuaidi100Service $kuaidi100Service) public function notify(Request $request, Kuaidi100Service $kuaidi100Service)
{ {
$data = $request->all(); $data = $request->all();
//校验回调签名 //校验回调签名
if ($kuaidi100Service->unPollSign(Arr::get($data, 'sign', ''), Arr::get($data, 'param', []))) { // if ($kuaidi100Service->unPollSign(Arr::get($data, 'sign', ''), Arr::get($data, 'param', []))) {
dd(132465); try {
DB::beginTransaction();
$kuaidi100Service->callback($request->input('param', []));
DB::commit();
} catch (Throwable $th) {
DB::rollBack();
report($th);
} }
// }
return response()->json([ return response()->json([
'result'=>true, 'result'=>true,
'returnCode'=>'200', 'returnCode'=>'200',

View File

@ -4,6 +4,7 @@ use App\Endpoint\Callback\Http\Controllers\Kuaidi100Controller;
use App\Endpoint\Callback\Http\Controllers\WeChatPayController; use App\Endpoint\Callback\Http\Controllers\WeChatPayController;
use Illuminate\Support\Facades\Route; use Illuminate\Support\Facades\Route;
Route::post('kuaidi100', [Kuaidi100Controller::class, 'callback']); //快递100物流推送
Route::post('kuaidi100', [Kuaidi100Controller::class, 'notify']);
// 微信支付通知 // 微信支付通知
Route::post('wxpay/paid-notify', [WeChatPayController::class, 'paidNotify'])->name('wxpay.paid_notify'); Route::post('wxpay/paid-notify', [WeChatPayController::class, 'paidNotify'])->name('wxpay.paid_notify');

View File

@ -2,10 +2,24 @@
namespace App\Models; namespace App\Models;
use App\Casts\JsonArray;
use Dcat\Admin\Traits\HasDateTimeFormatter;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
class KuaidiLog extends Model class KuaidiLog extends Model
{ {
use HasFactory; use HasFactory;
use HasDateTimeFormatter;
protected $casts = [
'info'=>JsonArray::class,
];
protected $fillable = [
'number',
'company',
'code',
'info',
];
} }

View File

@ -2,6 +2,7 @@
namespace App\Models; namespace App\Models;
use Carbon\Carbon;
use Dcat\Admin\Traits\HasDateTimeFormatter; use Dcat\Admin\Traits\HasDateTimeFormatter;
use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Model;
@ -11,10 +12,39 @@ class OrderPackage extends Model
use HasFactory; use HasFactory;
use HasDateTimeFormatter; use HasDateTimeFormatter;
public const STATUS_WAIT = 1;//揽收
public const STATUS_ONTHEWAY = 0;//途中
public const STATUS_DISTRIBUTE = 5;//派送
public const STATUS_CHECK = 3;//签收
public const STATUS_QUESTION = 2;//疑难:问题包裹
public const STATUS_REFUND = 4;//退签
public const STATUS_REFUSE = 6;//拒签
public const STATUS_OTHER = 10;//其他
public const STATUS_AUTOCHECK = 11;//自动签收
public static $kuaidi100StatusMap = [
'wait' => self::STATUS_WAIT,
'on_the_way' => self::STATUS_ONTHEWAY,
'distribute' => self::STATUS_DISTRIBUTE,
'check' => self::STATUS_CHECK,
'refund' => self::STATUS_REFUND,
'refuse' => self::STATUS_REFUSE,
'questions'=> self::STATUS_QUESTION,
];
protected $attributes = [
'status' => self::STATUS_WAIT,
'is_failed'=> false,
];
protected $casts = [ protected $casts = [
'is_failed' => 'bool', 'is_failed' => 'bool',
]; ];
protected $fillable = [
'remarks', 'status', 'is_failed', 'checked_at',
];
/** /**
* 订单 * 订单
* *
@ -33,4 +63,26 @@ class OrderPackage extends Model
{ {
return $this->hasMany(OrderPackageProduct::class, 'order_package_id'); return $this->hasMany(OrderPackageProduct::class, 'order_package_id');
} }
public function orderProducts()
{
return $this->belongsToMany(OrderProduct::class, 'order_package_products', 'order_package_id', 'order_product_id');
}
/**
* 更新包裹物流状态
*/
public function updatePackageStatus(int $status, ?Carbon $time = null)
{
//如果是签收或者自动签收,填入签收时间; 并填入包裹商品里面的售后有效期;
$this->status = $status;
if ($status == self::STATUS_CHECK || $status == self::STATUS_AUTOCHECK) {
$this->checked_at = $time ?? now();
$this->orderProducts()->update([
'after_expire_at'=>$this->checked_at->addDays(7),
]);
}
$this->save();
}
} }

File diff suppressed because it is too large Load Diff

View File

@ -18,6 +18,7 @@ use App\Models\ProductSku;
use App\Models\ShippingAddress; use App\Models\ShippingAddress;
use App\Models\User; use App\Models\User;
use App\Models\UserCoupon; use App\Models\UserCoupon;
use Illuminate\Support\Arr;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
class OrderService class OrderService
@ -697,13 +698,23 @@ class OrderService
$package->consignee_address = $order->consignee_address; $package->consignee_address = $order->consignee_address;
$package->shipping_company = $params['shipping_company']; $package->shipping_company = $params['shipping_company'];
$package->shipping_code = Arr::get(Kuaidi100Service::$codeArr, $package->shipping_company, '');
$package->shipping_number = $params['shipping_number']; $package->shipping_number = $params['shipping_number'];
//保存发货单 //保存发货单
$package->save(); $package->save();
//保存发货单商品 //保存发货单商品
$package->packageProducts()->saveMany(array_map(function ($value) { OrderPackageProduct::insert(array_map(function ($value) use ($package) {
return new OrderPackageProduct($value); return array_merge($value, [
'order_package_id' => $package->id,
'created_at' => $package->created_at,
'updated_at' => $package->created_at,
]);
}, $packageProducts)); }, $packageProducts));
if (config('settings.kuaidi100_is_use')) {
$kuaidi100Service = new Kuaidi100Service();
$kuaidi100Service->poll($package->shipping_number, $package->shipping_code, $package->consignee_telephone);
}
//更新订单状态 //更新订单状态
if (!OrderProduct::where('order_id', $order->id)->where('remain_quantity', '>', 0)->exists()) { if (!OrderProduct::where('order_id', $order->id)->where('remain_quantity', '>', 0)->exists()) {

View File

@ -22,11 +22,10 @@ return [
// 快递100是否开启 // 快递100是否开启
'kuaidi100_is_use' => true, 'kuaidi100_is_use' => true,
'kuaidi100_callback'=> '', 'kuaidi100_callback'=> env('APP_URL', '').'/callback/kuaidi100',
'kuaidi100_app_key'=> 'BTvgbjti4727', 'kuaidi100_app_key'=> 'BTvgbjti4727',
'kuaidi100_customer'=> '064109188EC4D85DA655DFC342144C6A', 'kuaidi100_customer'=> '064109188EC4D85DA655DFC342144C6A',
'kuaidi100_secret'=> '1bd287d1981749f2a30ea74cac0ab99c', 'kuaidi100_secret'=> '1bd287d1981749f2a30ea74cac0ab99c',
'kuaidi100_userid'=> 'ec0b6ec7729d4f22824cfd3c519dd45b', 'kuaidi100_userid'=> 'ec0b6ec7729d4f22824cfd3c519dd45b',
]; ];

View File

@ -21,12 +21,15 @@ class CreateOrderPackagesTable extends Migration
$table->string('consignee_zone')->nullable()->comment('收货人所在地区'); $table->string('consignee_zone')->nullable()->comment('收货人所在地区');
$table->string('consignee_address')->nullable()->comment('收货人详细地址'); $table->string('consignee_address')->nullable()->comment('收货人详细地址');
$table->string('shipping_company')->nullable()->comment('快递公司'); $table->string('shipping_company')->nullable()->comment('快递公司');
$table->string('shipping_code')->nullable()->comment('快递编码');
$table->string('shipping_number')->nullable()->comment('快递单号'); $table->string('shipping_number')->nullable()->comment('快递单号');
$table->unsignedTinyInteger('is_failed')->default(0)->comment('是否作废'); $table->unsignedTinyInteger('is_failed')->default(0)->comment('是否作废');
$table->unsignedTinyInteger('status')->default(0)->comment('快递状态:0在途1揽收2疑难3签收4退签5派件6退回'); $table->unsignedTinyInteger('status')->default(0)->comment('快递状态:0在途1揽收2疑难3签收4退签5派件14拒签');
$table->timestamp('inspected_at')->nullable()->comment('签收时间'); $table->timestamp('checked_at')->nullable()->comment('签收时间');
$table->string('remarks')->nullable()->comment('备注'); $table->string('remarks')->nullable()->comment('备注');
$table->timestamps(); $table->timestamps();
$table->index('shipping_number');
}); });
} }

View File

@ -15,13 +15,12 @@ class CreateKuaidiLogsTable extends Migration
{ {
Schema::create('kuaidi_logs', function (Blueprint $table) { Schema::create('kuaidi_logs', function (Blueprint $table) {
$table->id(); $table->id();
$table->string('shipping_number')->comment('快递单号'); $table->string('number')->comment('快递单号');
$table->string('shipping_company')->comment('快递公司'); $table->string('code')->nullable()->comment('快递编码');
$table->string('shipping_code')->nullable()->comment('快递公司编号'); $table->json('info')->nullable()->comment('物流情况明细');
$table->json('shipping_info')->nullable()->comment('物流情况明细');
$table->timestamps(); $table->timestamps();
$table->index('shipping_number'); $table->index('number');
}); });
} }