207 lines
6.0 KiB
PHP
207 lines
6.0 KiB
PHP
<?php
|
||
namespace app\devices\model;
|
||
|
||
use think\Model;
|
||
|
||
/**
|
||
* 设备微信登录记录模型类
|
||
*/
|
||
class DeviceWechatLogin extends Model
|
||
{
|
||
// 设置表名
|
||
protected $name = 'device_wechat_login';
|
||
|
||
// 设置主键
|
||
protected $pk = 'id';
|
||
|
||
// 自动写入时间戳
|
||
protected $autoWriteTimestamp = 'int';
|
||
|
||
// 定义时间戳字段名
|
||
protected $createTime = 'createTime';
|
||
|
||
// 定义字段类型
|
||
protected $type = [
|
||
'id' => 'integer',
|
||
'deviceId' => 'integer',
|
||
'companyId' => 'integer',
|
||
'createTime' => 'integer'
|
||
];
|
||
|
||
/**
|
||
* 查询设备关联的微信ID列表
|
||
* @param int $deviceId 设备ID
|
||
* @param int $companyId 公司/租户ID
|
||
* @return array 微信ID列表
|
||
*/
|
||
public static function getDeviceWechatIds($deviceId, $companyId = null)
|
||
{
|
||
$query = self::where('deviceId', $deviceId);
|
||
|
||
// 如果提供了公司ID,则添加对应的条件
|
||
if ($companyId !== null) {
|
||
$query->where('companyId', $companyId);
|
||
}
|
||
|
||
// 提取微信ID
|
||
$records = $query->select();
|
||
$wechatIds = [];
|
||
|
||
foreach ($records as $record) {
|
||
if (!empty($record['wechatId'])) {
|
||
$wechatIds[] = $record['wechatId'];
|
||
}
|
||
}
|
||
|
||
return $wechatIds;
|
||
}
|
||
|
||
/**
|
||
* 根据微信ID查询关联的设备
|
||
* @param string $wechatId 微信ID
|
||
* @param int $companyId 公司/租户ID
|
||
* @return array 设备ID列表
|
||
*/
|
||
public static function getWechatDeviceIds($wechatId, $companyId = null)
|
||
{
|
||
$query = self::where('wechatId', $wechatId);
|
||
|
||
// 如果提供了公司ID,则添加对应的条件
|
||
if ($companyId !== null) {
|
||
$query->where('companyId', $companyId);
|
||
}
|
||
|
||
// 提取设备ID
|
||
$records = $query->select();
|
||
$deviceIds = [];
|
||
|
||
foreach ($records as $record) {
|
||
if (!empty($record['deviceId'])) {
|
||
$deviceIds[] = $record['deviceId'];
|
||
}
|
||
}
|
||
|
||
return $deviceIds;
|
||
}
|
||
|
||
/**
|
||
* 添加设备微信登录记录
|
||
* @param int $deviceId 设备ID
|
||
* @param string $wechatId 微信ID
|
||
* @param int $companyId 公司/租户ID
|
||
* @return int 新增记录ID
|
||
*/
|
||
public static function addRecord($deviceId, $wechatId, $companyId)
|
||
{
|
||
// 检查是否已存在相同记录
|
||
$exists = self::where('deviceId', $deviceId)
|
||
->where('wechatId', $wechatId)
|
||
->where('companyId', $companyId)
|
||
->find();
|
||
|
||
if ($exists) {
|
||
return $exists['id'];
|
||
}
|
||
|
||
// 创建新记录
|
||
$model = new self();
|
||
$model->deviceId = $deviceId;
|
||
$model->wechatId = $wechatId;
|
||
$model->companyId = $companyId;
|
||
$model->save();
|
||
|
||
return $model->id;
|
||
}
|
||
|
||
/**
|
||
* 删除设备微信登录记录
|
||
* @param int $deviceId 设备ID
|
||
* @param string $wechatId 微信ID,为null时删除设备所有记录
|
||
* @param int $companyId 公司/租户ID,为null时不限公司
|
||
* @return bool 删除结果
|
||
*/
|
||
public static function removeRecord($deviceId, $wechatId = null, $companyId = null)
|
||
{
|
||
$query = self::where('deviceId', $deviceId);
|
||
|
||
if ($wechatId !== null) {
|
||
$query->where('wechatId', $wechatId);
|
||
}
|
||
|
||
if ($companyId !== null) {
|
||
$query->where('companyId', $companyId);
|
||
}
|
||
|
||
return $query->delete();
|
||
}
|
||
|
||
/**
|
||
* 关联Device模型
|
||
* @return \think\model\relation\BelongsTo
|
||
*/
|
||
public function device()
|
||
{
|
||
return $this->belongsTo('Device', 'deviceId');
|
||
}
|
||
|
||
/**
|
||
* 获取设备关联的微信账号信息
|
||
* @param int $deviceId 设备ID
|
||
* @param int $companyId 公司/租户ID
|
||
* @return array 微信账号信息列表
|
||
*/
|
||
public static function getDeviceRelatedAccounts($deviceId, $companyId = null)
|
||
{
|
||
// 获取设备关联的微信ID列表
|
||
$wechatIds = self::getDeviceWechatIds($deviceId, $companyId);
|
||
if (empty($wechatIds)) {
|
||
return [];
|
||
}
|
||
|
||
// 查询微信账号信息
|
||
$accounts = \think\Db::name('wechat_account')
|
||
->alias('wa')
|
||
->field([
|
||
'wa.id',
|
||
'wa.wechatId',
|
||
'wa.accountNickname',
|
||
'wa.nickname',
|
||
'wa.accountUserName',
|
||
'wa.avatar',
|
||
'wa.gender',
|
||
'wa.wechatAlive',
|
||
'wa.status',
|
||
'wa.totalFriend',
|
||
'wa.createTime',
|
||
'wa.updateTime'
|
||
])
|
||
->whereIn('wa.wechatId', $wechatIds)
|
||
->where('wa.isDeleted', 0)
|
||
->select();
|
||
|
||
// 处理结果数据
|
||
$result = [];
|
||
foreach ($accounts as $account) {
|
||
// 计算最后活跃时间
|
||
$lastActive = date('Y-m-d H:i:s', max($account['updateTime'], $account['createTime']));
|
||
|
||
// 格式化数据
|
||
$result[] = [
|
||
'id' => $account['id'],
|
||
'wechatId' => $account['wechatId'],
|
||
'nickname' => $account['accountNickname'] ?: $account['nickname'] ?: '未命名微信',
|
||
'accountUserName' => $account['accountUserName'],
|
||
'avatar' => $account['avatar'],
|
||
'gender' => intval($account['gender']),
|
||
'status' => intval($account['status']),
|
||
'statusText' => intval($account['status']) === 1 ? '可加友' : '已停用',
|
||
'wechatAlive' => intval($account['wechatAlive']),
|
||
'wechatAliveText' => intval($account['wechatAlive']) === 1 ? '正常' : '异常',
|
||
'totalFriend' => intval($account['totalFriend']),
|
||
'lastActive' => $lastActive
|
||
];
|
||
}
|
||
|
||
return $result;
|
||
}
|
||
}
|