310 lines
11 KiB
PHP
310 lines
11 KiB
PHP
<?php
|
||
// +----------------------------------------------------------------------
|
||
// | likeadmin快速开发前后端分离管理后台(PHP版)
|
||
// +----------------------------------------------------------------------
|
||
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
||
// | 开源版本可自由商用,可去除界面版权logo
|
||
// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
|
||
// | github下载:https://github.com/likeshop-github/likeadmin
|
||
// | 访问官网:https://www.likeadmin.cn
|
||
// | likeadmin团队 版权所有 拥有最终解释权
|
||
// +----------------------------------------------------------------------
|
||
// | author: likeadminTeam
|
||
// +----------------------------------------------------------------------
|
||
namespace app\adminapi\logic\user;
|
||
|
||
use app\common\enum\user\AccountLogEnum;
|
||
use app\common\enum\user\UserTerminalEnum;
|
||
use app\common\logic\AccountLogLogic;
|
||
use app\common\logic\BaseLogic;
|
||
use app\common\model\contract\Contract;
|
||
use app\common\model\dict\DictData;
|
||
use app\common\model\user\User;
|
||
use app\common\service\ConfigService;
|
||
use think\facade\Config;
|
||
use think\facade\Db;
|
||
|
||
/**
|
||
* 用户逻辑层
|
||
* Class UserLogic
|
||
* @package app\adminapi\logic\user
|
||
*/
|
||
class UserLogic extends BaseLogic
|
||
{
|
||
|
||
/**
|
||
* @notes 用户详情
|
||
* @param int $userId
|
||
* @return array
|
||
* @author 段誉
|
||
* @date 2022/9/22 16:32
|
||
*/
|
||
public static function detail(int $userId): array
|
||
{
|
||
// $field = [
|
||
// 'id', 'sn', 'account', 'nickname', 'avatar', 'real_name',
|
||
// 'sex', 'mobile', 'create_time', 'login_time', 'channel',
|
||
// 'user_money',
|
||
// ];
|
||
|
||
$user = User::where(['id' => $userId])
|
||
->findOrEmpty();
|
||
|
||
$user['channel'] = UserTerminalEnum::getTermInalDesc($user['channel']);
|
||
// $user->sex = $user->getData('sex');
|
||
$user['qualification']=json_decode($user->qualification,true);
|
||
$user['deposit_date'] = date('Y-m-d', $user['deposit_date']);
|
||
if($user->is_contract==1){
|
||
$user['contract']=Contract::where(['type'=>2,'party_b'=>$userId])->with(['party_a_info','contractType'])->find();
|
||
}
|
||
return $user->toArray();
|
||
}
|
||
|
||
|
||
/**
|
||
* @notes 更新用户信息
|
||
* @param array $params
|
||
* @return User
|
||
* @author 段誉
|
||
* @date 2022/9/22 16:38
|
||
*/
|
||
public static function setUserInfo(array $params)
|
||
{
|
||
return User::update([
|
||
'id' => $params['id'],
|
||
'nickname' => $params['nickname'],
|
||
'account' => $params['account'],
|
||
'mobile' => $params['account'],
|
||
'id_card' => $params['id_card'],
|
||
'channel' => 0,
|
||
'sex' => $params['sex'],
|
||
'province' => $params['province'],
|
||
'city' => $params['city'],
|
||
'area' => $params['area'],
|
||
'street' => $params['street'],
|
||
'village' => $params['village'],
|
||
'brigade' => $params['brigade'],
|
||
'address' => $params['address'],
|
||
'qualification' => json_encode($params['qualification']),
|
||
'company_id' => $params['company_id'],
|
||
'deposit' => $params['deposit'],
|
||
'deposit_date' => strtotime($params['deposit_date']),
|
||
'user_information_count' => $params['user_information_count'],
|
||
'register_num' => $params['register_num'],
|
||
'merchant_num' => $params['merchant_num'],
|
||
'trade_amount' => $params['trade_amount'],
|
||
]);
|
||
}
|
||
|
||
public static function editUser($params)
|
||
{
|
||
return User::update([
|
||
'id' => $params['id'],
|
||
'nickname' => $params['nickname'],
|
||
'account' => $params['account'],
|
||
'mobile' => $params['account'],
|
||
'id_card' => $params['id_card'],
|
||
'avatar' => $params['avatar'],
|
||
'channel' => 0,
|
||
'sex' => $params['sex'],
|
||
'province' => $params['province'],
|
||
'city' => $params['city'],
|
||
'area' => $params['area'],
|
||
'street' => $params['street'],
|
||
'village' => $params['village'],
|
||
'brigade' => $params['brigade'],
|
||
'address' => $params['address'],
|
||
'qualification' => json_encode($params['qualification']),
|
||
'company_id' => $params['company_id'],
|
||
'deposit' => $params['deposit'],
|
||
'deposit_date' => strtotime($params['deposit_date']),
|
||
'user_information_count' => $params['user_information_count'],
|
||
'register_num' => $params['register_num'],
|
||
'merchant_num' => $params['merchant_num'],
|
||
'trade_amount' => $params['trade_amount'],
|
||
'group_id' => $params['group_id'],
|
||
'update_time' => time()
|
||
]);
|
||
}
|
||
|
||
/**
|
||
* @notes 调整用户余额
|
||
* @param array $params
|
||
* @return bool|string
|
||
* @author 段誉
|
||
* @date 2023/2/23 14:25
|
||
*/
|
||
public static function adjustUserMoney(array $params)
|
||
{
|
||
Db::startTrans();
|
||
try {
|
||
$user = User::find($params['user_id']);
|
||
if (AccountLogEnum::INC == $params['action']) {
|
||
//调整可用余额
|
||
$user->user_money += $params['num'];
|
||
$user->save();
|
||
//记录日志
|
||
AccountLogLogic::add(
|
||
$user->id,
|
||
AccountLogEnum::UM_INC_ADMIN,
|
||
AccountLogEnum::INC,
|
||
$params['num'],
|
||
'',
|
||
$params['remark'] ?? ''
|
||
);
|
||
} else {
|
||
$user->user_money -= $params['num'];
|
||
$user->save();
|
||
//记录日志
|
||
AccountLogLogic::add(
|
||
$user->id,
|
||
AccountLogEnum::UM_DEC_ADMIN,
|
||
AccountLogEnum::DEC,
|
||
$params['num'],
|
||
'',
|
||
$params['remark'] ?? ''
|
||
);
|
||
}
|
||
|
||
Db::commit();
|
||
return true;
|
||
|
||
} catch (\Exception $e) {
|
||
Db::rollback();
|
||
return $e->getMessage();
|
||
}
|
||
}
|
||
|
||
public static function addUser($params)
|
||
{
|
||
// 手机号已被使用
|
||
$mobileUser = User::where(['account' => $params['account']])->find();
|
||
if (!empty($mobileUser)) {
|
||
self::setError('手机号已被注册');
|
||
return false;
|
||
}
|
||
// $count = User::where('company_id', $params['company_id'])->count();
|
||
// $value = DictData::where('id', 28)->value('value');
|
||
// if ($count >= $value) {
|
||
// self::setError('你创建的账号已达上限');
|
||
// return false;
|
||
// }
|
||
$group_id = $params['group_id'];
|
||
// 每个公司市场部长只有1个
|
||
// if($group_id == 16) {
|
||
// $marketManger = User::where(['group_id' =>$group_id,'company_id'=>$params['company_id']])->findOrEmpty();
|
||
// if (!$marketManger->isEmpty()) {
|
||
// self::setError('公司已创建市场部长账号');
|
||
// return false;
|
||
// }
|
||
// }
|
||
// 每个公司服务部长只有1个
|
||
// if($group_id == 14) {
|
||
// $marketManger = User::where(['group_id' =>$group_id,'company_id'=>$params['company_id']])->findOrEmpty();
|
||
// if (!$marketManger->isEmpty()) {
|
||
// self::setError('公司已创建服务部长账号');
|
||
// return false;
|
||
// }
|
||
// }
|
||
$userSn = User::createUserSn();
|
||
$passwordSalt = Config::get('project.unique_identification');
|
||
$password = create_password(123456, $passwordSalt);
|
||
if ($params['avatar'] != '') {
|
||
$avatar = $params['avatar'];
|
||
} else {
|
||
$avatar = ConfigService::get('default_image', 'user_avatar');
|
||
}
|
||
|
||
|
||
User::create([
|
||
'sn' => $userSn,
|
||
'avatar' => $avatar,
|
||
'is_captain' => $group_id == 2? 1: 0,
|
||
'nickname' => $params['nickname'],
|
||
'account' => $params['account'],
|
||
'mobile' => $params['account'],
|
||
'id_card' => $params['id_card'],
|
||
'password' => $password,
|
||
'channel' => 0,
|
||
'sex' => $params['sex'],
|
||
'province' => $params['province'],
|
||
'city' => $params['city'],
|
||
'area' => $params['area'],
|
||
'street' => $params['street'],
|
||
'village' => $params['village'],
|
||
'brigade' => $params['brigade'],
|
||
'address' => $params['address'],
|
||
'qualification' => json_encode($params['qualification']),
|
||
'company_id' => $params['company_id'],
|
||
'group_id' => $group_id,
|
||
'deposit' => $params['deposit'],
|
||
'deposit_date' => strtotime($params['deposit_date']),
|
||
'user_information_count' => $params['user_information_count'],
|
||
'register_num' => $params['register_num'],
|
||
'merchant_num' => $params['merchant_num'],
|
||
'trade_amount' => $params['trade_amount'],
|
||
'invite_code' => generate_rand_code(10),
|
||
]);
|
||
return true;
|
||
}
|
||
|
||
public static function getUserByInviteCode($inviteCode)
|
||
{
|
||
return User::where('invite_code', $inviteCode)->findOrEmpty();
|
||
}
|
||
|
||
public static function getUser($where)
|
||
{
|
||
return User::where($where)->findOrEmpty();
|
||
}
|
||
|
||
public static function shareProfit($bridgeUser, $villageUser, $streetUser, $orderMoney, $orderNo)
|
||
{
|
||
try {
|
||
Db::startTrans();
|
||
|
||
$proportion = 0.03; // 分润比例
|
||
|
||
if (!empty($bridgeUser)) {
|
||
// 小队
|
||
self::userProfit($bridgeUser, $orderMoney, $proportion, $orderNo);
|
||
}
|
||
|
||
if (!empty($villageUser)) {
|
||
// 村
|
||
self::userProfit($villageUser, $orderMoney, $proportion, $orderNo);
|
||
}
|
||
|
||
if (!empty($streetUser)) {
|
||
// 镇
|
||
$proportion = 0.01; // 分润比例
|
||
self::userProfit($streetUser, $orderMoney, $proportion, $orderNo);
|
||
}
|
||
|
||
Db::commit();
|
||
} catch (\Exception $e) {
|
||
Db::rollback();
|
||
}
|
||
}
|
||
|
||
public static function userProfit($user, $orderMoney, $proportion, $orderNo)
|
||
{
|
||
$money = bcdiv(bcmul($orderMoney, $proportion, 2), 100, 2);
|
||
$arr = [$user['id'], AccountLogEnum::UM_INC_TASK, AccountLogEnum::INC, $money, $orderNo, '平台推广' . '获得劳务费' . $money . '元', ['company_id' => 0, 'proportion' => $proportion], 1];
|
||
self::addUserAccountLog($arr);
|
||
}
|
||
|
||
/**成员分润
|
||
* @param $data
|
||
*/
|
||
private static function addUserAccountLog($data)
|
||
{
|
||
User::where('id', $data[0])->update(['user_money'=>Db::raw('user_money+' . $data[3])]);
|
||
return AccountLogLogic::add($data[0], $data[1], $data[2], $data[3], $data[4], $data[5], $data[6], $data[7]);
|
||
}
|
||
|
||
public static function firstOrderLog($userId, $orderMoney, $orderNo)
|
||
{
|
||
return Db::name('user_invite_first_order_log')->insert(['user_id' => $userId, 'order_money' => bcdiv($orderMoney, 100, 2), 'order_no' => $orderNo, 'create_time' => time()]);
|
||
}
|
||
} |