AdminToolsController.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. <?php
  2. namespace App\Admin\Controllers\Admin;
  3. use App\Models\User\WxUser;
  4. use App\Models\WxChat;
  5. use App\Wen\Utils\StrUtils;
  6. use Dcat\Admin\Http\Controllers\AdminController;
  7. use Dcat\Admin\Layout\Content;
  8. use Dcat\Admin\Form;
  9. use Dcat\Admin\Traits\HasFormResponse;
  10. use Illuminate\Http\Request;
  11. use Dcat\Admin\Admin;
  12. use Illuminate\Support\Facades\Cache;
  13. use Illuminate\Support\Facades\DB;
  14. class AdminToolsController extends AdminController
  15. {
  16. use HasFormResponse;
  17. public function imgDomainReplaceHandler(Request $request){
  18. $old_str = $request->old_str;
  19. $new_str = $request->new_str;
  20. if(_empty_($old_str)){
  21. return $this->response()->error('请输入旧字符串');
  22. }
  23. if(_empty_($new_str)){
  24. $new_str = '';
  25. }
  26. $admin_user = Admin::user();
  27. if(!($admin_user && $admin_user->isAdministrator())){
  28. return $this->response()->error('你不是超级管理员');
  29. }
  30. DB::beginTransaction();
  31. try {
  32. // todo:
  33. $tables = DB::select('SHOW TABLES');
  34. $tableNames = array_map('current', $tables);
  35. if($tableNames){
  36. foreach ($tableNames as $table_name){
  37. if(StrUtils::startsWith($table_name, 'admin_')){
  38. continue;
  39. }
  40. if(!StrUtils::startsWith($table_name, 'wx_') && !StrUtils::startsWith($table_name, 'mini_')){
  41. continue;
  42. }
  43. $table_info_columns = DB::select( DB::raw('SHOW COLUMNS FROM '.$table_name));
  44. foreach($table_info_columns as $column){
  45. if(in_array($column->Field, ['id', 'deleted_at', 'created_at', 'updated_at']) || StrUtils::endsWith($column->Field, '_id')){
  46. continue;
  47. }
  48. if(strpos($column->Type, 'int') !== false){
  49. continue;
  50. }
  51. if(in_array($column->Field, ['desc', 'right', 'condition', 'key'])){
  52. continue;
  53. }
  54. DB::select("UPDATE ".$table_name." SET ".$column->Field." = REPLACE(".$column->Field.", '".$old_str."', '".$new_str."') WHERE ".$column->Field." LIKE '%".$old_str."%'");
  55. }
  56. }
  57. }
  58. Cache::tags('st')->flush();
  59. DB::commit();
  60. return $this->response()->success('替换成功!')->refresh();
  61. } catch (\Exception $e) {
  62. DB::rollBack();
  63. _logger_(__file__, __line__, $e->getMessage());
  64. return $this->response()->error($e->getMessage());
  65. }
  66. }
  67. public function imgDomainReplaceForm(Content $content)
  68. {
  69. return Form::make('',function (Form $form) {
  70. $form->text('old_str', '旧字符串')->required();
  71. $form->text('new_str', '新字符串');
  72. $form->disableResetButton();
  73. $form->action('admin/tools/img_domain_replace');
  74. });
  75. }
  76. public function chatRecordChangeHandler(Request $request){
  77. $user_1 = (int)($request->user_1);
  78. $user_2 = (int)($request->user_2);
  79. if(_empty_($user_1) || $user_1 <= 0){
  80. return $this->response()->error('账号A参数错误');
  81. }
  82. if(_empty_($user_2) || $user_2 <= 0){
  83. return $this->response()->error('账号B参数错误');
  84. }
  85. $user_model_1 = WxUser::find($user_1);
  86. $user_model_2 = WxUser::find($user_2);
  87. if(!($user_model_1 && $user_model_2)){
  88. return $this->response()->error('账号实际不存在');
  89. }
  90. $admin_user = Admin::user();
  91. if(!($admin_user && $admin_user->isAdministrator())){
  92. return $this->response()->error('你不是超级管理员');
  93. }
  94. DB::beginTransaction();
  95. try {
  96. WxChat::where('user_id', $user_1)->update(['user_id' => $user_2]);
  97. WxChat::where('object_id', $user_1)->update(['object_id' => $user_2]);
  98. DB::commit();
  99. return $this->response()->success('迁移成功!')->refresh();
  100. } catch (\Exception $e) {
  101. DB::rollBack();
  102. _logger_(__file__, __line__, $e->getMessage());
  103. return $this->response()->error($e->getMessage());
  104. }
  105. }
  106. public function chatRecordChangeForm(Content $content)
  107. {
  108. return Form::make('',function (Form $form) {
  109. $form->text('user_1', '账号A')->help('A账号的所有聊天记录转移到B账号')->required();
  110. $form->text('user_2', '账号B')->required();
  111. $form->disableResetButton();
  112. $form->action('admin/tools/chat_record_change');
  113. });
  114. }
  115. public function tools(Content $content)
  116. {
  117. Form::dialog('数据库字符串替换')
  118. ->click('#img-domain-replace') // 绑定点击按钮
  119. ->url('admin/tools/img_domain_replace') // 表单页面链接,此参数会被按钮中的 “data-url” 属性替换。。
  120. ->height('650px;overflow: hidden;') // 指定弹窗高度,可填写百分比,默认 690px
  121. ->success('Dcat.reload()'); // 新增成功后刷新页面
  122. Form::dialog('聊天记录迁移')
  123. ->click('#chat-record-change') // 绑定点击按钮
  124. ->url('admin/tools/chat_record_change') // 表单页面链接,此参数会被按钮中的 “data-url” 属性替换。。
  125. ->height('650px;overflow: hidden;') // 指定弹窗高度,可填写百分比,默认 690px
  126. ->success('Dcat.reload()'); // 新增成功后刷新页面
  127. return $content
  128. ->title('管理员工具箱')
  129. ->description('注意:操作之前先<b style="color: red;">备份数据库</b>,世上没有后悔药,这里面都是属于高危操作,没事少碰,如果没有备份数据库就进行操作,中间出现了的问题,群主不会解答')
  130. ->body(admin_view('admin.pages.admin-tools', [
  131. 'paycode_0' => true,
  132. ]));
  133. }
  134. }