Info.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. /**
  3. * 用户管理
  4. * @author system
  5. * @version 1.0
  6. * @date 2017-03-23 12:56:46
  7. *
  8. */
  9. namespace App\Services\User;
  10. use App\Services\Base\BaseProcess;
  11. use App\Models\UserInfoModel;
  12. class Info extends BaseProcess {
  13. /**
  14. * 模型
  15. *
  16. * @var object
  17. *
  18. */
  19. private $_objModel;
  20. /**
  21. * 初始化
  22. *
  23. * @access public
  24. *
  25. */
  26. public function __construct()
  27. {
  28. if( ! $this->_objModel) $this->_objModel = new UserInfoModel();
  29. }
  30. public function model() {
  31. return $this->_objModel;
  32. }
  33. public function search(array $search,array $orderby=['id'=>'desc'],$pagesize=PAGE_NUMS)
  34. {
  35. $currentQuery = $this->_objModel;
  36. if(isset($search['keyword']) && ! empty($search['keyword'])) {
  37. $keywords = '%' . $search['keyword'] . '%';
  38. $currentQuery = $currentQuery->where(function ($query) use ($keywords) {
  39. $query->where('id' , 'like', $keywords)
  40. ->orwhere('username', 'like', $keywords)
  41. ->orwhere('real_name', 'like', $keywords)
  42. ->orwhere('password', 'like', $keywords)
  43. ->orwhere('email', 'like', $keywords)
  44. ->orwhere('mobile', 'like', $keywords)
  45. ->orwhere('avatar', 'like', $keywords)
  46. ->orwhere('address', 'like', $keywords);
  47. });
  48. }
  49. if($orderby && is_array($orderby)){
  50. foreach ($orderby AS $field => $value){
  51. $currentQuery = $currentQuery -> orderBy($field, $value);
  52. }
  53. }
  54. $currentQuery = $currentQuery->paginate($pagesize);
  55. return $currentQuery;
  56. }
  57. public function getAll($where,$orderby=null) {
  58. //条件
  59. $currentQuery = $this->_objModel;
  60. if($where && is_array($where)){
  61. foreach ($where AS $field => $value){
  62. $currentQuery= $currentQuery -> where($field, $value);
  63. }
  64. }
  65. //排序
  66. if($orderby && is_array($orderby)){
  67. foreach ($orderby AS $field => $value){
  68. $currentQuery = $currentQuery -> orderBy($field, $value);
  69. }
  70. }
  71. return $currentQuery->get();
  72. }
  73. public function find($id) {
  74. return $this->_objModel->find($id);
  75. }
  76. /**
  77. * 添加
  78. * @param unknown $data
  79. */
  80. public function create($data)
  81. {
  82. return $this->_objModel->create($data);
  83. }
  84. /**
  85. * 更新
  86. * @param unknown $id
  87. * @param unknown $data
  88. */
  89. public function update($id,$data)
  90. {
  91. $obj = $this->_objModel->find($id);
  92. if(!$obj) {
  93. $this->setMsg("没有找到要修改的数据");
  94. return false;
  95. }
  96. $ok = $obj->update($data);
  97. return $ok;
  98. }
  99. public function updateStatus($id,$status) {
  100. $data = $this->_objModel->find($id);
  101. $data->status = $status;
  102. return $data->save();
  103. }
  104. /**
  105. * 删除
  106. * @param unknown $id
  107. */
  108. public function destroy($id)
  109. {
  110. return $this->_objModel->destroy($id);
  111. }
  112. }