73 lines
2.8 KiB
PHP
73 lines
2.8 KiB
PHP
<?php
|
|
|
|
namespace App\Controllers\Admin;
|
|
|
|
use CodeIgniter\HTTP\RedirectResponse;
|
|
use CodeIgniter\HTTP\RequestInterface;
|
|
|
|
use CodeIgniter\HTTP\ResponseInterface;
|
|
use CodeIgniter\Validation\Validation;
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
use App\Helpers\UserHelper;
|
|
use App\Services\UserService;
|
|
|
|
class UserController extends AdminController
|
|
{
|
|
private $_service = null;
|
|
private $_helper = null;
|
|
public function initController(RequestInterface $request, ResponseInterface $response, LoggerInterface $logger)
|
|
{
|
|
parent::initController($request, $response, $logger);
|
|
$this->content_title = lang("{$this->getService()->getClassName()}.title");
|
|
$this->class_path .= $this->getService()->getClassName();
|
|
$this->uri_path .= strtolower($this->getService()->getClassName('/')) . '/';
|
|
// $this->view_path .= strtolower($this->getService()->getClassName()) . DIRECTORY_SEPARATOR;
|
|
|
|
}
|
|
final public function getService(): UserService
|
|
{
|
|
if (!$this->_service) {
|
|
$this->_service = new UserService();
|
|
}
|
|
return $this->_service;
|
|
}
|
|
public function getHelper(): UserHelper
|
|
{
|
|
if (!$this->_helper) {
|
|
$this->_helper = new UserHelper($this->request);
|
|
}
|
|
return $this->_helper;
|
|
}
|
|
//Index,FieldForm관련
|
|
protected function setValidation(Validation $validation, string $field, string $rule): Validation
|
|
{
|
|
switch ($field) {
|
|
case 'role':
|
|
//아래 Rule Array는 필드명.* checkbox를 사용
|
|
$validation->setRule("{$field}.*", $field, $rule);
|
|
break;
|
|
default:
|
|
$validation = parent::setValidation($validation, $field, $rule);
|
|
break;
|
|
}
|
|
return $validation;
|
|
}
|
|
//Index,FieldForm관련.
|
|
protected function setFilterConditionForList(): void
|
|
{
|
|
foreach ($this->getFilterFields() as $field) {
|
|
$this->$field = $this->request->getVar($field);
|
|
if ($this->$field !== null && $this->$field !== '') {
|
|
if ($field === 'role') {
|
|
$where = "FIND_IN_SET(" . $this->getService()->getModel()->escape($this->$field) . ", {$this->getService()->getModel()->getTable()}.{$field}) > 0";
|
|
//FIND_IN_SET()은 MySQL 함수이므로 CodeIgniter가 이를 일반 컬럼명으로 착각하고 escape하게 되면 오류가 발생합니다. 따라서 ->where($sql, null, false)로 명시하여 escape를 꺼줘야 정상 작동
|
|
$this->getService()->getModel()->where($where, null, false);
|
|
} else {
|
|
$this->getService()->getModel()->where("{$this->getService()->getModel()->getTable()}.{$field}", $this->$field);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|