TPlusServerService.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?php
  2. namespace App\Service;
  3. use App\Model\Depart;
  4. use App\Model\Employee;
  5. use App\Model\EmployeeDepartPermission;
  6. use Illuminate\Support\Facades\DB;
  7. class TPlusServerService extends Service
  8. {
  9. /**
  10. * @var TPlusDatabaseServerService
  11. */
  12. protected $databaseService;
  13. /**
  14. * @var string|null
  15. */
  16. protected $error;
  17. /**
  18. * TPlusServerService constructor.
  19. */
  20. public function __construct()
  21. {
  22. $service = new TPlusDatabaseServerService();
  23. $this->databaseService = $service->db ;
  24. $this->error = $service->error;
  25. }
  26. /**
  27. * 获取错误信息
  28. *
  29. * @return string|null
  30. */
  31. public function getError()
  32. {
  33. return $this->error;
  34. }
  35. /**
  36. * 同步人员部门
  37. *
  38. * @param array $data
  39. * @param array $user
  40. * @return array
  41. */
  42. public function synPersonDepart($data, $user)
  43. {
  44. try {
  45. $this->databaseService->table('AA_Department')
  46. ->select('id','idparent as parent_id','name as title','code','disabled as is_use')
  47. ->chunkById(100, function ($data) {
  48. DB::transaction(function () use ($data) {
  49. $dataArray = Collect($data)->map(function ($object) {
  50. return (array)$object;
  51. })->toArray();
  52. $d_id = Depart::whereIn('id', array_column($dataArray,'id'))
  53. ->pluck('id')
  54. ->toArray();
  55. $insert = $update = [];
  56. foreach ($dataArray as $value){
  57. $is_use = $value['is_use'] ? 0 : 1;
  58. if(in_array($value['id'], $d_id)){
  59. $update[] = [
  60. 'id' => $value['id'],
  61. 'parent_id' => $value['parent_id'],
  62. 'title' => $value['title'],
  63. 'code' => $value['code'],
  64. 'is_use' => $is_use
  65. ];
  66. }else{
  67. $insert[] = [
  68. 'id' => $value['id'],
  69. 'parent_id' => $value['parent_id'],
  70. 'title' => $value['title'],
  71. 'code' => $value['code'],
  72. 'is_use' => $is_use
  73. ];
  74. }
  75. }
  76. if(! empty($insert)) Depart::insert($insert);
  77. if(! empty($update)) {
  78. foreach ($update as $value){
  79. Depart::where('id', $value['id'])
  80. ->update($value);
  81. }
  82. }
  83. });
  84. });
  85. $this->databaseService->table('AA_Person')
  86. ->select('id','code as number','name as emp_name','mobilePhoneNo as mobile','iddepartment as depart_id','disabled as state')
  87. ->chunkById(100, function ($data) {
  88. DB::transaction(function () use ($data) {
  89. $dataArray = Collect($data)->map(function ($object) {
  90. return (array)$object;
  91. })->toArray();
  92. $employee_id = Employee::whereIn('id', array_column($dataArray,'id'))
  93. ->pluck('id')
  94. ->toArray();
  95. $insert = $update = $depart_update = [];
  96. foreach ($dataArray as $value){
  97. $state = $value['state'] ? Employee::NOT_USE : Employee::USE;
  98. if(in_array($value['id'], $employee_id)){
  99. $update[] = [
  100. 'id' => $value['id'],
  101. 'number' => $value['number'],
  102. 'emp_name' => $value['emp_name'],
  103. 'mobile' => $value['mobile'],
  104. 'state' => $state
  105. ];
  106. }else{
  107. $insert[] = [
  108. 'id' => $value['id'],
  109. 'number' => $value['number'],
  110. 'emp_name' => $value['emp_name'],
  111. 'mobile' => $value['mobile'],
  112. 'state' => $state
  113. ];
  114. }
  115. $depart_update[] = [
  116. 'employee_id' => $value['id'],
  117. 'depart_id' => $value['depart_id']
  118. ];
  119. }
  120. if(! empty($insert)) Employee::insert($insert);
  121. if(! empty($update)) {
  122. foreach ($update as $value){
  123. Employee::where('id', $value['id'])
  124. ->update($value);
  125. }
  126. }
  127. if(! empty($depart_update)){
  128. EmployeeDepartPermission::whereIn('employee_id',array_column($depart_update,'employee_id'))->delete();
  129. EmployeeDepartPermission::insert($depart_update);
  130. }
  131. });
  132. });
  133. } catch (\Throwable $e) {
  134. return [false, $e->getMessage()];
  135. }
  136. return [true, ''];
  137. }
  138. }