V2boardInstall.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. <?php
  2. namespace App\Console\Commands;
  3. use Illuminate\Console\Command;
  4. use Illuminate\Encryption\Encrypter;
  5. use App\Models\User;
  6. use App\Utils\Helper;
  7. use Illuminate\Support\Facades\DB;
  8. class V2boardInstall extends Command
  9. {
  10. /**
  11. * The name and signature of the console command.
  12. *
  13. * @var string
  14. */
  15. protected $signature = 'v2board:install';
  16. /**
  17. * The console command description.
  18. *
  19. * @var string
  20. */
  21. protected $description = 'v2board 安装';
  22. /**
  23. * Create a new command instance.
  24. *
  25. * @return void
  26. */
  27. public function __construct()
  28. {
  29. parent::__construct();
  30. }
  31. /**
  32. * Execute the console command.
  33. *
  34. * @return mixed
  35. */
  36. public function handle()
  37. {
  38. if (\File::exists(base_path() . '/.lock')) {
  39. abort(500, 'V2board 已安装,如需重新安装请删除目录下.lock文件');
  40. }
  41. if (!\File::exists(base_path() . '/.env')) {
  42. if (!copy(base_path() . '/.env.example', base_path() . '/.env')) {
  43. abort(500, '复制环境文件失败,请检查目录权限');
  44. }
  45. }
  46. $this->saveToEnv([
  47. 'APP_KEY' => 'base64:' . base64_encode(Encrypter::generateKey('AES-256-CBC')),
  48. 'DB_HOST' => $this->ask('请输入数据库地址(默认:localhost)', 'localhost'),
  49. 'DB_DATABASE' => $this->ask('请输入数据库名'),
  50. 'DB_USERNAME' => $this->ask('请输入数据库用户名'),
  51. 'DB_PASSWORD' => $this->ask('请输入数据库密码')
  52. ]);
  53. \Artisan::call('config:clear');
  54. \Artisan::call('config:cache');
  55. try {
  56. DB::connection()->getPdo();
  57. } catch (\Exception $e) {
  58. abort(500, '数据库连接失败');
  59. }
  60. $file = \File::get(base_path() . '/database/install.sql');
  61. if (!$file) {
  62. abort(500, '数据库文件不存在');
  63. }
  64. $sql = str_replace("\n", "", $file);
  65. $sql = preg_split("/;/", $sql);
  66. if (!is_array($sql)) {
  67. abort(500, '数据库文件格式有误');
  68. }
  69. $this->info('正在导入数据库请稍等...');
  70. foreach ($sql as $item) {
  71. try {
  72. DB::select(DB::raw($item));
  73. } catch (\Exception $e) {
  74. }
  75. }
  76. $email = '';
  77. while (!$email) {
  78. $email = $this->ask('请输入管理员邮箱?');
  79. }
  80. $password = '';
  81. while (!$password) {
  82. $password = $this->ask('请输入管理员密码?');
  83. }
  84. if (!$this->registerAdmin($email, $password)) {
  85. abort(500, '管理员账号注册失败,请重试');
  86. }
  87. $this->info('一切就绪');
  88. \File::put(base_path() . '/.lock', time());
  89. }
  90. private function registerAdmin($email, $password)
  91. {
  92. $user = new User();
  93. $user->email = $email;
  94. if (strlen($password) < 8) {
  95. abort(500, '管理员密码长度最小为8位字符');
  96. }
  97. $user->password = password_hash($password, PASSWORD_DEFAULT);
  98. $user->v2ray_uuid = Helper::guid(true);
  99. $user->token = Helper::guid();
  100. $user->is_admin = 1;
  101. return $user->save();
  102. }
  103. private function saveToEnv($data = [])
  104. {
  105. function set_env_var($key, $value)
  106. {
  107. if (! is_bool(strpos($value, ' '))) {
  108. $value = '"' . $value . '"';
  109. }
  110. $key = strtoupper($key);
  111. $envPath = app()->environmentFilePath();
  112. $contents = file_get_contents($envPath);
  113. preg_match("/^{$key}=[^\r\n]*/m", $contents, $matches);
  114. $oldValue = count($matches) ? $matches[0] : '';
  115. if ($oldValue) {
  116. $contents = str_replace("{$oldValue}", "{$key}={$value}", $contents);
  117. } else {
  118. $contents = $contents . "\n{$key}={$value}\n";
  119. }
  120. $file = fopen($envPath, 'w');
  121. fwrite($file, $contents);
  122. return fclose($file);
  123. }
  124. foreach($data as $key => $value) {
  125. set_env_var($key, $value);
  126. }
  127. return true;
  128. }
  129. }