mirror of https://gitee.com/karson/fastadmin.git
58 lines
1.6 KiB
PHP
58 lines
1.6 KiB
PHP
<?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()
|
|
{
|
|
$this
|
|
->setName('install')
|
|
->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');
|
|
|
|
$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');
|
|
|
|
// 先尝试能否自动创建数据
|
|
$config = Config::get('database');
|
|
$pdo = new PDO("{$config['type']}:host={$config['hostname']}", $config['username'], $config['password']);
|
|
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
|
|
$pdo->query("CREATE DATABASE IF NOT EXISTS `{$config['database']}` CHARACTER SET utf8 COLLATE utf8_general_ci;");
|
|
|
|
// 查询一次SQL,判断连接是否正常
|
|
Db::execute("SELECT 1");
|
|
|
|
// 调用原生PDO对象进行批量查询
|
|
Db::getPdo()->exec($sql);
|
|
|
|
file_put_contents($installLockFile, 1);
|
|
$output->info("Install Successed!");
|
|
}
|
|
|
|
}
|