123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- <?php
- namespace app\admin\command;
- use PDO;
- use think\Config;
- use think\console\Command;
- use think\console\Input;
- use think\console\input\Option;
- use think\console\Output;
- use think\Db;
- use think\Exception;
- class Install extends Command
- {
- protected $model = null;
- protected function configure()
- {
- $config = Config::get('database');
- $this
- ->setName('install')
- ->addOption('hostname', 'a', Option::VALUE_OPTIONAL, 'mysql hostname', $config['hostname'])
- ->addOption('hostport', 'o', Option::VALUE_OPTIONAL, 'mysql hostport', $config['hostport'])
- ->addOption('database', 'd', Option::VALUE_OPTIONAL, 'mysql database', $config['database'])
- ->addOption('prefix', 'r', Option::VALUE_OPTIONAL, 'table prefix', $config['prefix'])
- ->addOption('username', 'u', Option::VALUE_OPTIONAL, 'mysql username', $config['username'])
- ->addOption('password', 'p', Option::VALUE_OPTIONAL, 'mysql password', $config['password'])
- ->addOption('force', 'f', Option::VALUE_OPTIONAL, 'force override', false)
- ->setDescription('New installation of FastAdmin');
- }
- protected function execute(Input $input, Output $output)
- {
- // 覆盖安装
- $force = $input->getOption('force');
- $hostname = $input->getOption('hostname');
- $hostport = $input->getOption('hostport');
- $database = $input->getOption('database');
- $prefix = $input->getOption('prefix');
- $username = $input->getOption('username');
- $password = $input->getOption('password');
- $installLockFile = __DIR__ . "/Install/install.lock";
- if (is_file($installLockFile) && !$force) {
- throw new Exception("\nFastAdmin already installed!\nIf you need to reinstall again, use the parameter --force=true ");
- }
- $sql = file_get_contents(__DIR__ . '/Install/fastadmin.sql');
- $sql = str_replace("`fa_", "`{$prefix}", $sql);
- // 先尝试能否自动创建数据库
- $config = Config::get('database');
- $pdo = new PDO("{$config['type']}:host={$hostname}" . ($hostport ? ";port={$hostport}" : ''), $username, $password);
- $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
- $pdo->query("CREATE DATABASE IF NOT EXISTS `{$database}` CHARACTER SET utf8 COLLATE utf8_general_ci;");
- // 连接install命令中指定的数据库
- $instance = Db::connect([
- 'type' => "{$config['type']}",
- 'hostname' => "{$hostname}",
- 'hostport' => "{$hostport}",
- 'database' => "{$database}",
- 'username' => "{$username}",
- 'password' => "{$password}",
- ]);
- // 查询一次SQL,判断连接是否正常
- $instance->execute("SELECT 1");
- // 调用原生PDO对象进行批量查询
- $instance->getPdo()->exec($sql);
- file_put_contents($installLockFile, 1);
- //后台入口文件
- $adminFile = ROOT_PATH . 'public' . DS . 'admin.php';
- $dbConfigFile = APP_PATH . 'database.php';
- $config = @file_get_contents($dbConfigFile);
- $callback = function ($matches) use ($hostname, $hostport, $username, $password, $database, $prefix) {
- $field = $matches[1];
- $replace = $$field;
- if ($matches[1] == 'hostport' && $hostport == 3306) {
- $replace = '';
- }
- return "'{$matches[1]}'{$matches[2]}=>{$matches[3]}Env::get('database.{$matches[1]}', '{$replace}'),";
- };
- $config = preg_replace_callback("/'(hostname|database|username|password|hostport|prefix)'(\s+)=>(\s+)Env::get\((.*)\)\,/", $callback, $config);
- // 写入数据库配置
- file_put_contents($dbConfigFile, $config);
- // 修改后台入口
- if (is_file($adminFile)) {
- $x = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
- $adminName = substr(str_shuffle(str_repeat($x, ceil(10 / strlen($x)))), 1, 10) . '.php';
- rename($adminFile, ROOT_PATH . 'public' . DS . $adminName);
- $output->highlight("Admin url:http://www.yoursite.com/{$adminName}");
- }
- $output->highlight("Admin username:admin");
- $output->highlight("Admin password:123456");
- \think\Cache::rm('__menu__');
- $output->info("Install Successed!");
- }
- }
|