103 lines
2.9 KiB

<?php
namespace console\controllers;
use Yii;
use yii\console\Controller;
use yii\helpers\Console;
use yii\db\Query;
use yii\helpers\ArrayHelper;
use common\models\User;
use common\models\Category;
/**
* Description of RbacsetController
*
* @author blobt
*/
class InitController extends Controller {
public function actionIndex() {
echo "index\n";
Category::deleteAll();
for ($i = 0; $i < 1000000; $i++) {
$model = new Category();
$model->attributes = [
"cat_name" => "这是一个测试分类{$i}",
"icon" => 'fa',
"icon_type" => 1,
"sort_order" => $i,
"created_at" => time() - rand(10000, 1000000)
];
$model->save();
}
}
public function actionCreateAdmin($password = NULL) {
$auth = Yii::$app->authManager;
while ($password == NULL) {
$password = $this->prompt("\n\n请输入admin用户密码(最少6位任意字符):");
if (strlen($password) < 6) {
$password = NULL;
continue;
}
break;
}
$this->createAdmin($password);
}
/**
* 数据迁移
* @param sring $migrationPath 数据迁移代码目录
*/
private function migrate($migrationPath = "@app/migrations") {
$migrate = Yii::createObject("yii\console\controllers\MigrateController", ["action", $this]);
$migrate->interactive = false;
$migrate->migrationPath = $migrationPath;
$migrate->runAction("up", []);
}
/**
* TODO没有完善
* 清空数据库
*/
public function clearDb() {
Yii::$app->db->createCommand("SET FOREIGN_KEY_CHECKS = 0;")->execute();
$dbname = explode('=', explode(';', Yii::$app->db->dsn)[1])[1];
$sql = "SELECT CONCAT('drop table ',table_name,';') FROM information_schema.`TABLES` WHERE table_schema='{$dbname}';";
$sqls = Yii::$app->db->createCommand($sql)->queryColumn();
foreach ($sqls as $dropSql) {
Yii::$app->db->createCommand($dropSql)->execute();
}
}
/**
* 创建管理员
* @param string $password 管理员密码
*/
private function createAdmin($password) {
$auth = Yii::$app->authManager;
$model = User::findOne("username = 'admin");
if (empty($model)) {
$model = new User();
}
$model->username = "admin";
$model->email = "admin@kcshop.store";
$model->setPassword($password);
$model->generateAuthKey();
$model->status = User::STATUS_ACTIVE;
$model->created_at = $model->updated_at = time();
if ($model->save()) {
//$oRole = $auth->getRole("超级管理员");
//if ($auth->assign($oRole, $model->id)) {
$this->stdout("Create admin success!\n", Console::FG_GREEN);
//}
}
}
}