Timecard/provide/classes/BootLoader.php
2022-05-22 16:46:00 +09:00

263 lines
7.7 KiB
PHP

<?php
/***
* Copyright (c) 2022 DevRas
*
*/
class BootLoader
{
public function __construct($root)
{
$this->root = $root;
$this->session = new UserSession();
$this->model = new Template($this->root . "/template");
}
protected $root;
protected $pdo;
protected $cards;
protected $config;
protected $session;
protected $model;
public function run()
{
try {
$this->InitPDO();
$this->cards = new Timecard($this->pdo);
$this->cards->InitTables();
$user = new User($this->pdo);
$isAdmin = false;
$loginUser = [];
$works = [];
$page = filter_input(INPUT_GET, "p") ?? "home";
if ($user->hasLogout())
{
$this->session->setUsername(null);
header("Location: ?login");
exit;
}
$logged = $this->session->isLogged();
if (!$logged)
{
$loginUser = $user->hasLogin();
if ($loginUser)
{
$this->session->setUsername($loginUser["username"]);
$logged = true;
} else
{
$this->model->viewModel("login", [
"method" => "POST",
"canonical" => $this->config["canonical"],
"config" => $this->config
]);
exit;
}
}
$loginUser = $user->getUser($this->session->getUsername());
if (!$loginUser)
{
throw new \RuntimeException("不正なユーザーです");
}
$isAdmin = array_search($this->session->getUsername(), $this->config["admin_users"]) !== false;
if ($page == "passwd")
{
if ($user->hasUpdatePassword($loginUser))
{
header("Location: ?p=home");
exit;
}
$this->model->viewModel("passwd", [
"username" => $this->session->getUsername(),
"config" => $this->config,
]);
exit;
}
if ($page == "create" && $isAdmin)
{
if ($user->hasCreate())
{
header("Location: ?p=home");
exit;
}
$this->model->viewModel("create", [
"config" => $this->config,
]);
exit;
}
if ($page == "view")
{
$id = filter_input(INPUT_GET, "id");
$loginUser = $user->getUserById($id);
if (!$loginUser)
{
throw new \RuntimeException("不正なユーザーです");
}
}
$result = $this->cards->hasCard($loginUser["id"], $isAdmin);
$works = $this->cards->SelectTimes($loginUser["id"]);
$lastCard = $this->cards->getLastInsert($loginUser["id"]);
$users = $this->cards->getUsers();
$this->model->viewModel("view", [
"logged" => $logged,
"users" => $users,
"user" => $loginUser,
"works" => $works,
"canonical" => $this->config["canonical"],
"config" => $this->config,
"addCard" => $result,
"lastCard" => $lastCard,
"isAdmin" => $isAdmin,
]);
} catch (\RuntimeException $e)
{
http_response_code(401);
$result = $this->model->viewModel("error", [
"exception" => $e,
"message" => $e->getMessage(),
"config" => $this->config,
]);
if (!$result)
{
echo $e->getMessage();
exit;
}
}
}
protected function InitPDO()
{
$config = require_once $this->root . '/config.php';
$db = new IDB();
if (!$db->Connect($config["mysql"]["hostname"],
$config["mysql"]["dbname"],
$config["mysql"]["username"],
$config["mysql"]["password"])
)
{
throw new \RuntimeException('can not connect to mysql server.');
}
$this->pdo = $db->getDB();
$this->config = $config;
}
/**
* Install Timecard
*/
public function install()
{
try {
$step = "welcome";
$configPath = $this->root . '/config.php';
if (!file_exists($configPath))
{
$from = @file_get_contents($this->root . "/config.sample.php");
@file_put_contents($configPath, $from);
}
$install = new Installer($configPath);
$install->open();
$fStep = filter_input(INPUT_POST, "step");
switch ($fStep)
{
case "welcome":
$step = "mysql";
break;
case "mysql":
$hostname = filter_input(INPUT_POST, "hostname");
$dbname = filter_input(INPUT_POST, "dbname");
$username = filter_input(INPUT_POST, "username");
$password = filter_input(INPUT_POST, "password");
$install->readToBuffer();
$install->setKeyBuffer("hostname", $hostname);
$install->setKeyBuffer("dbname", $dbname);
$install->setKeyBuffer("username", $username);
$install->setKeyBuffer("password", $password);
$install->writeBuffer();
$step = "link";
break;
case "link":
$url = filter_input(INPUT_POST, "url");
$install->readToBuffer();
$install->setKeyBuffer("canonical", $url);
$install->writeBuffer();
$step = "account";
break;
case "account":
$this->InitPDO();
$this->cards = new Timecard($this->pdo);
$this->cards->InitTables();
$user = new User($this->pdo);
$username = filter_input(INPUT_POST, "username");
if (!$user->hasCreate())
{
throw new \RuntimeException("ユーザーを作成できませんでした。");
}
$install->readToBuffer();
$install->setKeyBuffer("admin_users", "[" . $username . "]", false);
$install->writeBuffer();
$step = "done";
break;
case "done":
@unlink($this->root . "/install.php");
header("Location: index.php");
exit;
break;
default:
break;
}
$install->close();
$this->model->viewModel("install", [
"step" => $step
]);
} catch (\RuntimeException $e)
{
http_response_code(401);
$result = $this->model->viewModel("error", [
"exception" => $e,
"message" => $e->getMessage(),
"config" => $this->config,
]);
if (!$result)
{
echo $e->getMessage();
exit;
}
}
}
}