Compare commits

...

2 Commits

Author SHA1 Message Date
102b7e1846 调整接口 2020-11-04 14:42:27 +08:00
a8852873d2 无意义 2020-10-30 16:35:21 +08:00
10 changed files with 2269 additions and 1733 deletions

2
README
View File

@@ -1,2 +0,0 @@
核销系统 增加发券 开发分支

9
README.md Normal file
View File

@@ -0,0 +1,9 @@
# 核销接口
[TOC]
## 文档说明
| 版本号 | 发行说明 |
| ------ | ------------------ |
| 1.0.1 | 第一版本发布 |

View 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',
]);
}
}

View File

@@ -1,6 +1,8 @@
<?php <?php
Route::group(['prefix' => 'V1'], function () { Route::group(['prefix' => 'V1'], function () {
Route::get('/', 'IndexController@index');
Route::post('user/get', 'UserController@index'); Route::post('user/get', 'UserController@index');
Route::post('user/check', 'UserController@check'); Route::post('user/check', 'UserController@check');
@@ -22,5 +24,4 @@ Route::group(['prefix' => 'V1'], function () {
Route::post('unionpay/index', 'UnionPayController@index'); Route::post('unionpay/index', 'UnionPayController@index');
Route::post('unionpay/query', 'UnionPayController@query'); Route::post('unionpay/query', 'UnionPayController@query');
}); });

View File

@@ -17,6 +17,22 @@ class TestController
public function index(Request $request) 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; $user_id = $request->user_id;
$data = $request->data; $data = $request->data;
$this->user = User::find(3); $this->user = User::find(3);
@@ -74,7 +90,7 @@ class TestController
*/ */
public function grant(Request $request) public function grant(Request $request)
{ {
$this->user = User::find(3); $this->user = User::find(299);
$data = $this->jiami($request->all()); $data = $this->jiami($request->all());

View File

@@ -101,7 +101,7 @@ class Activity extends Model
try { try {
// $code = 'YSD' . date('ymd') . mt_rand(100000, 999999); // $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) { if ($this->type == SELF::TYPE_EXTEND) {
$start_at = now(); $start_at = now();
$end_at = now()->addDays($this->days); $end_at = now()->addDays($this->days);

View File

@@ -1,13 +1,13 @@
<?php return array ( <?php return array (
'aslong/sms' => 'barryvdh/laravel-debugbar' =>
array ( array (
'providers' => 'providers' =>
array ( array (
0 => 'AsLong\\Sms\\ServiceProvider', 0 => 'Barryvdh\\Debugbar\\ServiceProvider',
), ),
'aliases' => 'aliases' =>
array ( array (
'Sms' => 'AsLong\\Sms\\Facades\\Sms', 'Debugbar' => 'Barryvdh\\Debugbar\\Facade',
), ),
), ),
'encore/laravel-admin' => 'encore/laravel-admin' =>
@@ -21,17 +21,6 @@
'Admin' => 'Encore\\Admin\\Facades\\Admin', 'Admin' => 'Encore\\Admin\\Facades\\Admin',
), ),
), ),
'facade/ignition' =>
array (
'providers' =>
array (
0 => 'Facade\\Ignition\\IgnitionServiceProvider',
),
'aliases' =>
array (
'Flare' => 'Facade\\Ignition\\Facades\\Flare',
),
),
'fideloper/proxy' => 'fideloper/proxy' =>
array ( array (
'providers' => 'providers' =>
@@ -82,24 +71,6 @@
0 => 'Carbon\\Laravel\\ServiceProvider', 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' => 'simplesoftwareio/simple-qrcode' =>
array ( array (
'providers' => 'providers' =>

View File

@@ -23,24 +23,21 @@
19 => 'Illuminate\\Translation\\TranslationServiceProvider', 19 => 'Illuminate\\Translation\\TranslationServiceProvider',
20 => 'Illuminate\\Validation\\ValidationServiceProvider', 20 => 'Illuminate\\Validation\\ValidationServiceProvider',
21 => 'Illuminate\\View\\ViewServiceProvider', 21 => 'Illuminate\\View\\ViewServiceProvider',
22 => 'AsLong\\Sms\\ServiceProvider', 22 => 'Barryvdh\\Debugbar\\ServiceProvider',
23 => 'Encore\\Admin\\AdminServiceProvider', 23 => 'Encore\\Admin\\AdminServiceProvider',
24 => 'Facade\\Ignition\\IgnitionServiceProvider', 24 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider',
25 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider', 25 => 'Intervention\\Image\\ImageServiceProvider',
26 => 'Intervention\\Image\\ImageServiceProvider', 26 => 'Encore\\WangEditor\\WangEditorServiceProvider',
27 => 'Encore\\WangEditor\\WangEditorServiceProvider', 27 => 'Laravel\\Tinker\\TinkerServiceProvider',
28 => 'Laravel\\Tinker\\TinkerServiceProvider', 28 => 'Maatwebsite\\Excel\\ExcelServiceProvider',
29 => 'Maatwebsite\\Excel\\ExcelServiceProvider', 29 => 'Carbon\\Laravel\\ServiceProvider',
30 => 'Carbon\\Laravel\\ServiceProvider', 30 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider',
31 => 'NunoMaduro\\Collision\\Adapters\\Laravel\\CollisionServiceProvider', 31 => 'App\\Providers\\AppServiceProvider',
32 => 'Overtrue\\LaravelWeChat\\ServiceProvider', 32 => 'App\\Providers\\AuthServiceProvider',
33 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider', 33 => 'App\\Providers\\EventServiceProvider',
34 => 'App\\Providers\\AppServiceProvider', 34 => 'App\\Providers\\RouteServiceProvider',
35 => 'App\\Providers\\AuthServiceProvider', 35 => 'App\\Api\\ApiServiceProvider',
36 => 'App\\Providers\\EventServiceProvider', 36 => 'App\\Merchant\\MerchantServiceProvider',
37 => 'App\\Providers\\RouteServiceProvider',
38 => 'App\\Api\\ApiServiceProvider',
39 => 'App\\Merchant\\MerchantServiceProvider',
), ),
'eager' => 'eager' =>
array ( array (
@@ -54,24 +51,21 @@
7 => 'Illuminate\\Pagination\\PaginationServiceProvider', 7 => 'Illuminate\\Pagination\\PaginationServiceProvider',
8 => 'Illuminate\\Session\\SessionServiceProvider', 8 => 'Illuminate\\Session\\SessionServiceProvider',
9 => 'Illuminate\\View\\ViewServiceProvider', 9 => 'Illuminate\\View\\ViewServiceProvider',
10 => 'AsLong\\Sms\\ServiceProvider', 10 => 'Barryvdh\\Debugbar\\ServiceProvider',
11 => 'Encore\\Admin\\AdminServiceProvider', 11 => 'Encore\\Admin\\AdminServiceProvider',
12 => 'Facade\\Ignition\\IgnitionServiceProvider', 12 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider',
13 => 'Fideloper\\Proxy\\TrustedProxyServiceProvider', 13 => 'Intervention\\Image\\ImageServiceProvider',
14 => 'Intervention\\Image\\ImageServiceProvider', 14 => 'Encore\\WangEditor\\WangEditorServiceProvider',
15 => 'Encore\\WangEditor\\WangEditorServiceProvider', 15 => 'Laravel\\Tinker\\TinkerServiceProvider',
16 => 'Laravel\\Tinker\\TinkerServiceProvider', 16 => 'Maatwebsite\\Excel\\ExcelServiceProvider',
17 => 'Maatwebsite\\Excel\\ExcelServiceProvider', 17 => 'Carbon\\Laravel\\ServiceProvider',
18 => 'Carbon\\Laravel\\ServiceProvider', 18 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider',
19 => 'NunoMaduro\\Collision\\Adapters\\Laravel\\CollisionServiceProvider', 19 => 'App\\Providers\\AppServiceProvider',
20 => 'Overtrue\\LaravelWeChat\\ServiceProvider', 20 => 'App\\Providers\\AuthServiceProvider',
21 => 'SimpleSoftwareIO\\QrCode\\QrCodeServiceProvider', 21 => 'App\\Providers\\EventServiceProvider',
22 => 'App\\Providers\\AppServiceProvider', 22 => 'App\\Providers\\RouteServiceProvider',
23 => 'App\\Providers\\AuthServiceProvider', 23 => 'App\\Api\\ApiServiceProvider',
24 => 'App\\Providers\\EventServiceProvider', 24 => 'App\\Merchant\\MerchantServiceProvider',
25 => 'App\\Providers\\RouteServiceProvider',
26 => 'App\\Api\\ApiServiceProvider',
27 => 'App\\Merchant\\MerchantServiceProvider',
), ),
'deferred' => 'deferred' =>
array ( array (

3658
composer.lock generated

File diff suppressed because it is too large Load Diff

View File

@@ -2,143 +2,10 @@
namespace XuanChen\Sinopec; namespace XuanChen\Sinopec;
use App\Models\Activity;
use App\Models\User;
use Illuminate\Support\Facades\DB;
/** /**
* 中石化接口 * 中石化接口
*/ */
class Sinopec 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();
}
}
} }