Compare commits
2 Commits
c214cfed0d
...
102b7e1846
| Author | SHA1 | Date | |
|---|---|---|---|
| 102b7e1846 | |||
| a8852873d2 |
9
README.md
Normal file
9
README.md
Normal file
@@ -0,0 +1,9 @@
|
||||
# 核销接口
|
||||
|
||||
[TOC]
|
||||
|
||||
## 文档说明
|
||||
|
||||
| 版本号 | 发行说明 |
|
||||
| ------ | ------------------ |
|
||||
| 1.0.1 | 第一版本发布 |
|
||||
16
app/Api/Controllers/IndexController.php
Normal file
16
app/Api/Controllers/IndexController.php
Normal file
@@ -0,0 +1,16 @@
|
||||
<?php
|
||||
|
||||
namespace App\Api\Controllers;
|
||||
|
||||
class IndexController extends Controller
|
||||
{
|
||||
|
||||
public function index()
|
||||
{
|
||||
return $this->respond('200', [
|
||||
'code' => 200,
|
||||
'message' => 'Json Api is ready',
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -1,6 +1,8 @@
|
||||
<?php
|
||||
|
||||
Route::group(['prefix' => 'V1'], function () {
|
||||
Route::get('/', 'IndexController@index');
|
||||
|
||||
Route::post('user/get', 'UserController@index');
|
||||
Route::post('user/check', 'UserController@check');
|
||||
|
||||
@@ -22,5 +24,4 @@ Route::group(['prefix' => 'V1'], function () {
|
||||
Route::post('unionpay/index', 'UnionPayController@index');
|
||||
Route::post('unionpay/query', 'UnionPayController@query');
|
||||
|
||||
|
||||
});
|
||||
|
||||
@@ -17,6 +17,22 @@ class TestController
|
||||
|
||||
public function index(Request $request)
|
||||
{
|
||||
$this->user = User::find(6);
|
||||
$ret = [
|
||||
'redemptionCode' => 'YSD201029312435',
|
||||
'outletId' => '2008030929274',
|
||||
];
|
||||
|
||||
$ret = [
|
||||
'mobile' => '15663876870',
|
||||
'orderid' => '202008105236478',
|
||||
'activityId' => 'ysd202010272',
|
||||
'outletId' => '2008241014458',
|
||||
|
||||
];
|
||||
|
||||
return $this->success($ret);
|
||||
dd();
|
||||
$user_id = $request->user_id;
|
||||
$data = $request->data;
|
||||
$this->user = User::find(3);
|
||||
@@ -74,7 +90,7 @@ class TestController
|
||||
*/
|
||||
public function grant(Request $request)
|
||||
{
|
||||
$this->user = User::find(3);
|
||||
$this->user = User::find(299);
|
||||
|
||||
$data = $this->jiami($request->all());
|
||||
|
||||
|
||||
@@ -101,7 +101,7 @@ class Activity extends Model
|
||||
|
||||
try {
|
||||
// $code = 'YSD' . date('ymd') . mt_rand(100000, 999999);
|
||||
$code = '66406' . date('ymd') . mt_rand(100000, 999999);
|
||||
$code = '66406' . date('ymdH') . mt_rand(1000000, 9999999);
|
||||
if ($this->type == SELF::TYPE_EXTEND) {
|
||||
$start_at = now();
|
||||
$end_at = now()->addDays($this->days);
|
||||
|
||||
35
bootstrap/cache/packages.php
vendored
35
bootstrap/cache/packages.php
vendored
@@ -1,13 +1,13 @@
|
||||
<?php return array (
|
||||
'aslong/sms' =>
|
||||
'barryvdh/laravel-debugbar' =>
|
||||
array (
|
||||
'providers' =>
|
||||
array (
|
||||
0 => 'AsLong\\Sms\\ServiceProvider',
|
||||
0 => 'Barryvdh\\Debugbar\\ServiceProvider',
|
||||
),
|
||||
'aliases' =>
|
||||
array (
|
||||
'Sms' => 'AsLong\\Sms\\Facades\\Sms',
|
||||
'Debugbar' => 'Barryvdh\\Debugbar\\Facade',
|
||||
),
|
||||
),
|
||||
'encore/laravel-admin' =>
|
||||
@@ -21,17 +21,6 @@
|
||||
'Admin' => 'Encore\\Admin\\Facades\\Admin',
|
||||
),
|
||||
),
|
||||
'facade/ignition' =>
|
||||
array (
|
||||
'providers' =>
|
||||
array (
|
||||
0 => 'Facade\\Ignition\\IgnitionServiceProvider',
|
||||
),
|
||||
'aliases' =>
|
||||
array (
|
||||
'Flare' => 'Facade\\Ignition\\Facades\\Flare',
|
||||
),
|
||||
),
|
||||
'fideloper/proxy' =>
|
||||
array (
|
||||
'providers' =>
|
||||
@@ -82,24 +71,6 @@
|
||||
0 => 'Carbon\\Laravel\\ServiceProvider',
|
||||
),
|
||||
),
|
||||
'nunomaduro/collision' =>
|
||||
array (
|
||||
'providers' =>
|
||||
array (
|
||||
0 => 'NunoMaduro\\Collision\\Adapters\\Laravel\\CollisionServiceProvider',
|
||||
),
|
||||
),
|
||||
'overtrue/laravel-wechat' =>
|
||||
array (
|
||||
'providers' =>
|
||||
array (
|
||||
0 => 'Overtrue\\LaravelWeChat\\ServiceProvider',
|
||||
),
|
||||
'aliases' =>
|
||||
array (
|
||||
'EasyWeChat' => 'Overtrue\\LaravelWeChat\\Facade',
|
||||
),
|
||||
),
|
||||
'simplesoftwareio/simple-qrcode' =>
|
||||
array (
|
||||
'providers' =>
|
||||
|
||||
62
bootstrap/cache/services.php
vendored
62
bootstrap/cache/services.php
vendored
@@ -23,24 +23,21 @@
|
||||
19 => 'Illuminate\\Translation\\TranslationServiceProvider',
|
||||
20 => 'Illuminate\\Validation\\ValidationServiceProvider',
|
||||
21 => 'Illuminate\\View\\ViewServiceProvider',
|
||||
22 => 'AsLong\\Sms\\ServiceProvider',
|
||||
22 => 'Barryvdh\\Debugbar\\ServiceProvider',
|
||||
23 => 'Encore\\Admin\\AdminServiceProvider',
|
||||
24 => 'Facade\\Ignition\\IgnitionServiceProvider',
|
||||
25 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider',
|
||||
26 => 'Intervention\\Image\\ImageServiceProvider',
|
||||
27 => 'Encore\\WangEditor\\WangEditorServiceProvider',
|
||||
28 => 'Laravel\\Tinker\\TinkerServiceProvider',
|
||||
29 => 'Maatwebsite\\Excel\\ExcelServiceProvider',
|
||||
30 => 'Carbon\\Laravel\\ServiceProvider',
|
||||
31 => 'NunoMaduro\\Collision\\Adapters\\Laravel\\CollisionServiceProvider',
|
||||
32 => 'Overtrue\\LaravelWeChat\\ServiceProvider',
|
||||
33 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider',
|
||||
34 => 'App\\Providers\\AppServiceProvider',
|
||||
35 => 'App\\Providers\\AuthServiceProvider',
|
||||
36 => 'App\\Providers\\EventServiceProvider',
|
||||
37 => 'App\\Providers\\RouteServiceProvider',
|
||||
38 => 'App\\Api\\ApiServiceProvider',
|
||||
39 => 'App\\Merchant\\MerchantServiceProvider',
|
||||
24 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider',
|
||||
25 => 'Intervention\\Image\\ImageServiceProvider',
|
||||
26 => 'Encore\\WangEditor\\WangEditorServiceProvider',
|
||||
27 => 'Laravel\\Tinker\\TinkerServiceProvider',
|
||||
28 => 'Maatwebsite\\Excel\\ExcelServiceProvider',
|
||||
29 => 'Carbon\\Laravel\\ServiceProvider',
|
||||
30 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider',
|
||||
31 => 'App\\Providers\\AppServiceProvider',
|
||||
32 => 'App\\Providers\\AuthServiceProvider',
|
||||
33 => 'App\\Providers\\EventServiceProvider',
|
||||
34 => 'App\\Providers\\RouteServiceProvider',
|
||||
35 => 'App\\Api\\ApiServiceProvider',
|
||||
36 => 'App\\Merchant\\MerchantServiceProvider',
|
||||
),
|
||||
'eager' =>
|
||||
array (
|
||||
@@ -54,24 +51,21 @@
|
||||
7 => 'Illuminate\\Pagination\\PaginationServiceProvider',
|
||||
8 => 'Illuminate\\Session\\SessionServiceProvider',
|
||||
9 => 'Illuminate\\View\\ViewServiceProvider',
|
||||
10 => 'AsLong\\Sms\\ServiceProvider',
|
||||
10 => 'Barryvdh\\Debugbar\\ServiceProvider',
|
||||
11 => 'Encore\\Admin\\AdminServiceProvider',
|
||||
12 => 'Facade\\Ignition\\IgnitionServiceProvider',
|
||||
13 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider',
|
||||
14 => 'Intervention\\Image\\ImageServiceProvider',
|
||||
15 => 'Encore\\WangEditor\\WangEditorServiceProvider',
|
||||
16 => 'Laravel\\Tinker\\TinkerServiceProvider',
|
||||
17 => 'Maatwebsite\\Excel\\ExcelServiceProvider',
|
||||
18 => 'Carbon\\Laravel\\ServiceProvider',
|
||||
19 => 'NunoMaduro\\Collision\\Adapters\\Laravel\\CollisionServiceProvider',
|
||||
20 => 'Overtrue\\LaravelWeChat\\ServiceProvider',
|
||||
21 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider',
|
||||
22 => 'App\\Providers\\AppServiceProvider',
|
||||
23 => 'App\\Providers\\AuthServiceProvider',
|
||||
24 => 'App\\Providers\\EventServiceProvider',
|
||||
25 => 'App\\Providers\\RouteServiceProvider',
|
||||
26 => 'App\\Api\\ApiServiceProvider',
|
||||
27 => 'App\\Merchant\\MerchantServiceProvider',
|
||||
12 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider',
|
||||
13 => 'Intervention\\Image\\ImageServiceProvider',
|
||||
14 => 'Encore\\WangEditor\\WangEditorServiceProvider',
|
||||
15 => 'Laravel\\Tinker\\TinkerServiceProvider',
|
||||
16 => 'Maatwebsite\\Excel\\ExcelServiceProvider',
|
||||
17 => 'Carbon\\Laravel\\ServiceProvider',
|
||||
18 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider',
|
||||
19 => 'App\\Providers\\AppServiceProvider',
|
||||
20 => 'App\\Providers\\AuthServiceProvider',
|
||||
21 => 'App\\Providers\\EventServiceProvider',
|
||||
22 => 'App\\Providers\\RouteServiceProvider',
|
||||
23 => 'App\\Api\\ApiServiceProvider',
|
||||
24 => 'App\\Merchant\\MerchantServiceProvider',
|
||||
),
|
||||
'deferred' =>
|
||||
array (
|
||||
|
||||
3658
composer.lock
generated
3658
composer.lock
generated
File diff suppressed because it is too large
Load Diff
@@ -2,143 +2,10 @@
|
||||
|
||||
namespace XuanChen\Sinopec;
|
||||
|
||||
use App\Models\Activity;
|
||||
use App\Models\User;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
/**
|
||||
* 中石化接口
|
||||
*/
|
||||
class Sinopec
|
||||
{
|
||||
|
||||
/**
|
||||
* Notes: 发券接口
|
||||
* @Author: 玄尘
|
||||
* @Date : 2020/6/28 15:07
|
||||
* @param $activityId 活动编号
|
||||
* @param $outletId 网点编号
|
||||
* @param $mobile 手机号
|
||||
*/
|
||||
public static function Grant($activityId, $outletId, $mobile)
|
||||
{
|
||||
$model = config('xuanchen_coupon.rules.ysd.model');
|
||||
|
||||
return (new $model)->setActivityId($activityId)
|
||||
->setOutletId($outletId)
|
||||
->setMobile($mobile)
|
||||
->grant();
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Notes: 查询接口
|
||||
* @Author: 玄尘
|
||||
* @Date : 2020/7/21 11:58
|
||||
* @param $redemptionCode
|
||||
*/
|
||||
public static function Query($redemptionCode, $outletId)
|
||||
{
|
||||
if (!$redemptionCode) {
|
||||
return '查询失败,未获取到券码';
|
||||
}
|
||||
|
||||
$model = self::getModelByCode($redemptionCode);
|
||||
if (is_string($model)) {
|
||||
return $model;
|
||||
}
|
||||
|
||||
return $model->setCode($redemptionCode)
|
||||
->setOutletId($outletId)
|
||||
->detail();
|
||||
}
|
||||
|
||||
/**
|
||||
* Notes: 卡券作废
|
||||
* @Author: 玄尘
|
||||
* @Date : 2020/9/2 16:54
|
||||
* @param $redemptionCode
|
||||
* @param $outletId
|
||||
* @return string
|
||||
*/
|
||||
public static function Destroy($redemptionCode, $outletId)
|
||||
{
|
||||
try {
|
||||
$model = self::getModelByCode($redemptionCode);
|
||||
if (is_string($model)) {
|
||||
return $model;
|
||||
}
|
||||
|
||||
return $model->setCode($redemptionCode)
|
||||
->setOutletId($outletId)
|
||||
->destroy();
|
||||
} catch (\Exception $e) {
|
||||
return $e->getMessage();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Notes: 根据券码 获取class
|
||||
* @Author: 玄尘
|
||||
* @Date : 2020/7/21 12:00
|
||||
* @param $code
|
||||
* @return string
|
||||
*/
|
||||
public static function getModelByCode($code)
|
||||
{
|
||||
$rules = config('xuanchen_coupon.rules');
|
||||
if (!$rules) {
|
||||
return '系统出错,未找到配置文件';
|
||||
}
|
||||
|
||||
$model = '';
|
||||
foreach ($rules as $rule) {
|
||||
if (preg_match($rule['pattern'], $code, $matches)) {
|
||||
$model = $rule['model'];
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (!$model) {
|
||||
throw new \Exception('卡券核销失败。未查到卡券所属');
|
||||
}
|
||||
|
||||
return new $model;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Notes: description
|
||||
* @Author: 玄尘
|
||||
* @Date : 2020/8/21 13:33
|
||||
* @param \App\Models\User $user 渠道
|
||||
* @param string $redemptionCode 要核销的券码
|
||||
* @param float $total 订单金额
|
||||
* @param string $outletId 网点id
|
||||
* @param string $orderid 订单id
|
||||
* @return string
|
||||
*/
|
||||
public static function Redemption(User $user, string $redemptionCode, float $total, string $outletId, string $orderid = '')
|
||||
{
|
||||
|
||||
try {
|
||||
$model = self::getModelByCode($redemptionCode);
|
||||
if (is_string($model)) {
|
||||
return $model;
|
||||
}
|
||||
|
||||
return $model->setUser($user)
|
||||
->setCode($redemptionCode)
|
||||
->setTotal($total)
|
||||
->setOutletId($outletId)
|
||||
->setOrderId($orderid)
|
||||
->start();
|
||||
|
||||
} catch (\Exception $e) {
|
||||
return $e->getMessage();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user