V2boardInstall.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  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. try {
  39. $this->info("__ ______ ____ _ ");
  40. $this->info("\ \ / /___ \| __ ) ___ __ _ _ __ __| | ");
  41. $this->info(" \ \ / / __) | _ \ / _ \ / _` | '__/ _` | ");
  42. $this->info(" \ V / / __/| |_) | (_) | (_| | | | (_| | ");
  43. $this->info(" \_/ |_____|____/ \___/ \__,_|_| \__,_| ");
  44. if (\File::exists(base_path() . '/.env')) {
  45. abort(500, 'V2board 已安装,如需重新安装请删除目录下.env文件');
  46. }
  47. if (!copy(base_path() . '/.env.example', base_path() . '/.env')) {
  48. abort(500, '复制环境文件失败,请检查目录权限');
  49. }
  50. $this->saveToEnv([
  51. 'APP_KEY' => 'base64:' . base64_encode(Encrypter::generateKey('AES-256-CBC')),
  52. 'DB_HOST' => $this->ask('请输入数据库地址(默认:localhost)', 'localhost'),
  53. 'DB_DATABASE' => $this->ask('请输入数据库名'),
  54. 'DB_USERNAME' => $this->ask('请输入数据库用户名'),
  55. 'DB_PASSWORD' => $this->ask('请输入数据库密码')
  56. ]);
  57. \Artisan::call('config:clear');
  58. \Artisan::call('config:cache');
  59. try {
  60. DB::connection()->getPdo();
  61. } catch (\Exception $e) {
  62. abort(500, '数据库连接失败');
  63. }
  64. $file = \File::get(base_path() . '/database/install.sql');
  65. if (!$file) {
  66. abort(500, '数据库文件不存在');
  67. }
  68. $sql = str_replace("\n", "", $file);
  69. $sql = preg_split("/;/", $sql);
  70. if (!is_array($sql)) {
  71. abort(500, '数据库文件格式有误');
  72. }
  73. $this->info('正在导入数据库请稍等...');
  74. foreach ($sql as $item) {
  75. try {
  76. DB::select(DB::raw($item));
  77. } catch (\Exception $e) {
  78. }
  79. }
  80. $this->info('数据库导入完成');
  81. $email = '';
  82. while (!$email) {
  83. $email = $this->ask('请输入管理员邮箱?');
  84. }
  85. $password = '';
  86. while (!$password) {
  87. $password = $this->ask('请输入管理员密码?');
  88. }
  89. if (!$this->registerAdmin($email, $password)) {
  90. abort(500, '管理员账号注册失败,请重试');
  91. }
  92. $this->info('一切就绪');
  93. $this->info('访问 http(s)://你的站点/admin 进入管理面板');
  94. } catch (\Exception $e) {
  95. $this->error($e->getMessage());
  96. }
  97. }
  98. private function registerAdmin($email, $password)
  99. {
  100. $user = new User();
  101. $user->email = $email;
  102. if (strlen($password) < 8) {
  103. abort(500, '管理员密码长度最小为8位字符');
  104. }
  105. $user->password = password_hash($password, PASSWORD_DEFAULT);
  106. $user->uuid = Helper::guid(true);
  107. $user->token = Helper::guid();
  108. $user->is_admin = 1;
  109. return $user->save();
  110. }
  111. private function saveToEnv($data = [])
  112. {
  113. function set_env_var($key, $value)
  114. {
  115. if (! is_bool(strpos($value, ' '))) {
  116. $value = '"' . $value . '"';
  117. }
  118. $key = strtoupper($key);
  119. $envPath = app()->environmentFilePath();
  120. $contents = file_get_contents($envPath);
  121. preg_match("/^{$key}=[^\r\n]*/m", $contents, $matches);
  122. $oldValue = count($matches) ? $matches[0] : '';
  123. if ($oldValue) {
  124. $contents = str_replace("{$oldValue}", "{$key}={$value}", $contents);
  125. } else {
  126. $contents = $contents . "\n{$key}={$value}\n";
  127. }
  128. $file = fopen($envPath, 'w');
  129. fwrite($file, $contents);
  130. return fclose($file);
  131. }
  132. foreach($data as $key => $value) {
  133. set_env_var($key, $value);
  134. }
  135. return true;
  136. }
  137. }