106 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
 | 
						|
namespace app\repository;
 | 
						|
 | 
						|
use app\exception\RepositoryException;
 | 
						|
 | 
						|
use app\model\Account;
 | 
						|
use app\service\Repository;
 | 
						|
use app\traits\account\ApplyStaffTrait;
 | 
						|
use app\traits\account\BusinessFlowTrait;
 | 
						|
use app\traits\CommentTrait;
 | 
						|
use app\traits\CouponBillTrait;
 | 
						|
use app\traits\CouponTrait;
 | 
						|
use think\db\exception\DataNotFoundException;
 | 
						|
use think\db\exception\DbException;
 | 
						|
use think\db\exception\ModelNotFoundException;
 | 
						|
use think\Model;
 | 
						|
 | 
						|
/**
 | 
						|
 * 账户域 相关操作(客户账号)
 | 
						|
 *
 | 
						|
 * Class AccountRepository
 | 
						|
 * @package app\repository
 | 
						|
 * @method self getInstance(Model $model = null) static
 | 
						|
 */
 | 
						|
class AccountRepository extends Repository
 | 
						|
{
 | 
						|
    use CommentTrait;
 | 
						|
    use BusinessFlowTrait;
 | 
						|
    use CouponTrait;
 | 
						|
    use CouponBillTrait;
 | 
						|
    use ApplyStaffTrait;
 | 
						|
    /**
 | 
						|
     * 获取指定账户记录By手机号
 | 
						|
     *
 | 
						|
     * @param  string  $phone
 | 
						|
     * @param  array  $fields
 | 
						|
     * @return Model|null
 | 
						|
     * @throws DataNotFoundException
 | 
						|
     * @throws DbException
 | 
						|
     * @throws ModelNotFoundException
 | 
						|
     */
 | 
						|
    public function infoByPhone(string $phone, array $fields = []): ?Model
 | 
						|
    {
 | 
						|
        $where[] = ['mobile', '=', $phone];
 | 
						|
        return $this->findOneByWhere($where, $fields);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 获取指定账户记录By用户名
 | 
						|
     *
 | 
						|
     * @param  string  $username
 | 
						|
     * @param  array  $fields
 | 
						|
     * @return Model|null
 | 
						|
     * @throws DataNotFoundException
 | 
						|
     * @throws DbException
 | 
						|
     * @throws ModelNotFoundException
 | 
						|
     */
 | 
						|
    public function infoByUsername(string $username, array $fields = []): ?Model
 | 
						|
    {
 | 
						|
        $where[] = ['username', '=', $username];
 | 
						|
        return $this->findOneByWhere($where, $fields);
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * 通过微信小程序的openID查询
 | 
						|
     *
 | 
						|
     * @param  string  $openID
 | 
						|
     * @return array|Model|null
 | 
						|
     * @throws DataNotFoundException
 | 
						|
     * @throws DbException
 | 
						|
     * @throws ModelNotFoundException
 | 
						|
     */
 | 
						|
    public function findByOpenID(string $openID)
 | 
						|
    {
 | 
						|
        return $this->model->where('open_id', $openID)->find();
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * 修改密码
 | 
						|
     *
 | 
						|
     * @param  int  $accountId
 | 
						|
     * @param  string  $oldPwd
 | 
						|
     * @param  string  $newPwd
 | 
						|
     * @return bool
 | 
						|
     * @throws RepositoryException
 | 
						|
     */
 | 
						|
    public function modifyPwd(int $accountId, string $oldPwd, string $newPwd): bool
 | 
						|
    {
 | 
						|
        if (!$user = $this->findById($accountId)) {
 | 
						|
            throw new RepositoryException('用户不存在');
 | 
						|
        }
 | 
						|
 | 
						|
        if ($user['password'] != md5($oldPwd)) {
 | 
						|
            throw new RepositoryException('原密码错误');
 | 
						|
        }
 | 
						|
 | 
						|
        $user->password = md5($newPwd);
 | 
						|
 | 
						|
        return $user->save();
 | 
						|
    }
 | 
						|
 | 
						|
} |