SysUserLog.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Niucloud-admin 企业快速开发的saas管理平台
  4. // +----------------------------------------------------------------------
  5. // | 官方网址:https://www.niucloud.com
  6. // +----------------------------------------------------------------------
  7. // | niucloud团队 版权所有 开源版本可自由商用
  8. // +----------------------------------------------------------------------
  9. // | Author: Niucloud Team
  10. // +----------------------------------------------------------------------
  11. namespace app\model\sys;
  12. use core\base\BaseModel;
  13. use think\db\Query;
  14. /**
  15. * 系统用户日志模型
  16. * Class SysUserLog
  17. * @package app\model\sys
  18. */
  19. class SysUserLog extends BaseModel
  20. {
  21. /**
  22. * 数据表主键
  23. * @var string
  24. */
  25. protected $pk = 'id';
  26. /**
  27. * 模型名称
  28. * @var string
  29. */
  30. protected $name = 'sys_user_log';
  31. // 设置json类型字段
  32. protected $json = ['params'];
  33. protected $jsonAssoc = true;
  34. /**
  35. * 用户id搜索器
  36. * @param Query $query
  37. * @param $value
  38. * @param $data
  39. */
  40. public function searchUidAttr(Query $query, $value, $data)
  41. {
  42. if ($value) {
  43. $query->where('uid', $value);
  44. }
  45. }
  46. /**
  47. * 用户名搜索器
  48. * @param Query $query
  49. * @param $value
  50. * @param $data
  51. */
  52. public function searchUsernameAttr(Query $query, $value, $data)
  53. {
  54. if ($value) {
  55. $query->whereLike('username', '%' . $value . '%');
  56. }
  57. }
  58. /**
  59. * 请求方式搜索器
  60. * @param Query $query
  61. * @param $value
  62. * @param $data
  63. */
  64. public function searchTypeAttr(Query $query, $value, $data)
  65. {
  66. if ($value) {
  67. $query->where('type', $value);
  68. }
  69. }
  70. /**
  71. * 链接搜索器
  72. * @param Query $query
  73. * @param $value
  74. * @param $data
  75. */
  76. public function searchUrlAttr(Query $query, $value, $data)
  77. {
  78. if ($value) {
  79. $query->whereLike('url', '%' . $value . '%');
  80. }
  81. }
  82. /**
  83. * ip搜索器
  84. * @param Query $query
  85. * @param $value
  86. * @param $data
  87. */
  88. public function searchIpAttr(Query $query, $value, $data)
  89. {
  90. if ($value) {
  91. $query->whereLike('ip', '%' . $value . '%');
  92. }
  93. }
  94. /**
  95. * 创建时间搜索器
  96. * @param $query
  97. * @param $value
  98. * @param $data
  99. */
  100. public function searchCreateTimeAttr($query, $value, $data)
  101. {
  102. $start_time = empty($value[0]) ? 0 : strtotime($value[0]);
  103. $end_time = empty($value[1]) ? 0 : strtotime($value[1]);
  104. if ($start_time > 0 && $end_time > 0) {
  105. $query->whereBetweenTime('create_time', $start_time, $end_time);
  106. } else if ($start_time > 0 && $end_time == 0) {
  107. $query->where([['create_time', '>=', $start_time]]);
  108. } else if ($start_time == 0 && $end_time > 0) {
  109. $query->where([['create_time', '<=', $end_time]]);
  110. }
  111. }
  112. }