WokerTask/app/adminapi/logic/user/UserLogic.php

310 lines
11 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?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()]);
}
}