237 lines
14 KiB
PHP
237 lines
14 KiB
PHP
<?php
|
|
|
|
namespace App\Models\Mangboard;
|
|
|
|
use App\Entities\Mangboard\UserEntity;
|
|
use App\Models\CommonModel;
|
|
|
|
// +-------------------+----------------------+------+-----+---------------------+----------------+
|
|
// | Field | Type | Null | Key | Default | Extra |
|
|
// +-------------------+----------------------+------+-----+---------------------+----------------+
|
|
// | pid | int(10) unsigned | NO | PRI | NULL | auto_increment |
|
|
// | wp_user_pid | int(10) unsigned | NO | | 0 | |
|
|
// | user_id | varchar(150) | NO | UNI | | |
|
|
// | passwd | varchar(255) | NO | | | |
|
|
// | user_name | varchar(100) | NO | | | |
|
|
// | user_state | varchar(255) | NO | | | |
|
|
// | user_level | tinyint(3) unsigned | NO | | 1 | |
|
|
// | user_group | varchar(255) | NO | MUL | home | |
|
|
// | user_platform | varchar(100) | NO | | mb | |
|
|
// | user_email | varchar(255) | NO | | | |
|
|
// | user_point | int(10) unsigned | NO | | 0 | |
|
|
// | user_money | int(10) unsigned | NO | | 0 | |
|
|
// | user_coin | int(10) unsigned | NO | | 0 | |
|
|
// | payment_count | smallint(5) unsigned | NO | | 0 | |
|
|
// | payment_total | int(10) unsigned | NO | | 0 | |
|
|
// | user_birthday | varchar(50) | NO | | | |
|
|
// | user_phone | varchar(50) | NO | | | |
|
|
// | user_picture | varchar(255) | NO | | | |
|
|
// | user_icon | varchar(255) | NO | | | |
|
|
// | user_messenger | varchar(255) | NO | | | |
|
|
// | user_homepage | varchar(255) | NO | | | |
|
|
// | user_blog | varchar(255) | NO | | | |
|
|
// | user_sex | tinyint(3) | NO | | 0 | |
|
|
// | home_postcode | varchar(20) | NO | | | |
|
|
// | home_address1 | varchar(255) | NO | | | |
|
|
// | home_address2 | varchar(255) | NO | | | |
|
|
// | home_tel | varchar(50) | NO | | | |
|
|
// | office_postcode | varchar(20) | NO | | | |
|
|
// | office_address1 | varchar(255) | NO | | | |
|
|
// | office_address2 | varchar(255) | NO | | | |
|
|
// | office_tel | varchar(50) | NO | | | |
|
|
// | office_fax | varchar(50) | NO | | | |
|
|
// | company_name | varchar(255) | NO | | | |
|
|
// | job_title | varchar(255) | NO | | | |
|
|
// | gps_latitude | decimal(10,8) | NO | | 0.00000000 | |
|
|
// | gps_longitude | decimal(11,8) | NO | | 0.00000000 | |
|
|
// | allow_mailing | tinyint(3) unsigned | NO | MUL | 1 | |
|
|
// | allow_message | tinyint(3) unsigned | NO | | 1 | |
|
|
// | allow_push | tinyint(3) unsigned | NO | | 1 | |
|
|
// | allow_sms | tinyint(3) unsigned | NO | | 1 | |
|
|
// | followers | int(10) unsigned | NO | | 0 | |
|
|
// | following | int(10) unsigned | NO | | 0 | |
|
|
// | new_memo | smallint(5) unsigned | NO | | 0 | |
|
|
// | login_count | int(10) unsigned | NO | | 0 | |
|
|
// | write_count | int(10) unsigned | NO | | 0 | |
|
|
// | reply_count | int(10) unsigned | NO | | 0 | |
|
|
// | comment_count | int(10) unsigned | NO | | 0 | |
|
|
// | send_count | int(10) unsigned | NO | | 0 | |
|
|
// | api_count | int(10) unsigned | NO | | 0 | |
|
|
// | item1_count | int(10) unsigned | NO | | 0 | |
|
|
// | item2_count | int(10) unsigned | NO | | 0 | |
|
|
// | item3_count | int(10) unsigned | NO | | 0 | |
|
|
// | review_count | int(10) unsigned | NO | | 0 | |
|
|
// | review_star_sum | int(10) unsigned | NO | | 0 | |
|
|
// | reg_mail | tinyint(3) | NO | | 0 | |
|
|
// | reg_phone | tinyint(3) | NO | | 0 | |
|
|
// | push_pid | int(10) unsigned | NO | | 0 | |
|
|
// | reg_date | datetime | NO | MUL | 0000-00-00 00:00:00 | |
|
|
// | last_login | datetime | NO | MUL | 0000-00-00 00:00:00 | |
|
|
// | user_memo | varchar(255) | NO | | | |
|
|
// | admin_memo | varchar(255) | NO | | | |
|
|
// | recommender_id | varchar(255) | NO | | | |
|
|
// | user_auth_key | varchar(255) | NO | | | |
|
|
// | user_access_token | varchar(255) | NO | | | |
|
|
// | ext1 | varchar(255) | NO | | | |
|
|
// | ext2 | varchar(255) | NO | | | |
|
|
// | ext3 | varchar(255) | NO | | | |
|
|
// | ext4 | varchar(255) | NO | | | |
|
|
// | ext5 | varchar(255) | NO | | | |
|
|
// | ext6 | varchar(255) | NO | | | |
|
|
// | ext7 | varchar(255) | NO | | | |
|
|
// | ext8 | varchar(255) | NO | | | |
|
|
// | ext9 | varchar(255) | NO | | | |
|
|
// | ext10 | varchar(255) | NO | | | |
|
|
// | ext11 | varchar(255) | NO | | | |
|
|
// | ext12 | varchar(255) | NO | | | |
|
|
// | ext13 | varchar(255) | NO | | | |
|
|
// | ext14 | varchar(255) | NO | | | |
|
|
// | ext15 | varchar(255) | NO | | | |
|
|
// | ext16 | varchar(255) | NO | | | |
|
|
// | ext17 | varchar(255) | NO | | | |
|
|
// | ext18 | varchar(255) | NO | | | |
|
|
// | ext19 | varchar(255) | NO | | | |
|
|
// | ext20 | varchar(255) | NO | | | |
|
|
// +-------------------+----------------------+------+-----+---------------------+----------------+
|
|
|
|
class UserModel extends CommonModel
|
|
{
|
|
protected $table = 'mb_users';
|
|
protected $primaryKey = 'pid';
|
|
protected $returnType = UserEntity::class;
|
|
|
|
public function __construct()
|
|
{
|
|
$fields = ["user_id", "passwd", "user_name", "user_email", "user_state", "user_level", "user_point"];
|
|
parent::__construct($fields);
|
|
}
|
|
public function getTitleField(): string
|
|
{
|
|
return 'user_name';
|
|
}
|
|
public function getFieldRule(string $field, array $rules): array
|
|
{
|
|
switch ($field) {
|
|
case "user_id":
|
|
case "passwd":
|
|
$rules[$field] = "required|trim|string";
|
|
break;
|
|
case "user_state":
|
|
$rules[$field] = "if_exist|trim|string";
|
|
break;
|
|
case "user_email":
|
|
$rules[$field] = "if_exist|trim|valid_email";
|
|
break;
|
|
case "user_level":
|
|
case "user_point":
|
|
$rules[$field] = "if_exist|numeric";
|
|
break;
|
|
default:
|
|
$rules = parent::getFieldRule($field, $rules);
|
|
break;
|
|
}
|
|
return $rules;
|
|
}
|
|
|
|
public function getEntityByPK(int $uid): null|UserEntity
|
|
{
|
|
$this->where($this->getPKField(), $uid);
|
|
return $this->getEntity();
|
|
}
|
|
public function getEntityByID(string $id): null|UserEntity
|
|
{
|
|
$this->where('user_id', $id);
|
|
return $this->getEntity();
|
|
}
|
|
|
|
private function checkLevel(UserEntity $entity): UserEntity
|
|
{
|
|
//Admin용 Level로는 변경불가
|
|
if ($entity->getLevel() == getenv('mangboard.admin.level')) {
|
|
// throw new \Exception("Admin용 Level을 변경하실수 없습니다.\n");
|
|
return $entity;
|
|
}
|
|
|
|
//사용자 Point별 Level 계산
|
|
$level = intval($entity->getPoint() / getenv('mangboard.point.unit') * getenv('mangboard.point.unit') / getenv('mangboard.point.unit'));
|
|
|
|
//운영자면 7~9
|
|
if (getenv('mangboard.manager.level.min') <= $level && $level <= getenv('mangboard.manager.level.max')) {
|
|
$level = $level < getenv('mangboard.manager.level.min') ? getenv('mangboard.manager.level.min') : $level;
|
|
$level = getenv('mangboard.manager.level.max') < $level ? getenv('mangboard.manager.level.max') : $level;
|
|
}
|
|
// echo "point:" . $entity->getPoint() . ",level:" . $level . "\n";
|
|
|
|
//사용자 Level 1~5;
|
|
if (getenv('mangboard.user.level.min') <= $level && $level <= getenv('mangboard.user.level.max')) {
|
|
$level = $level < getenv('mangboard.user.level.min') ? getenv('mangboard.user.level.min') : $level;
|
|
$level = getenv('mangboard.user.level.max') < $level ? getenv('mangboard.user.level.max') : $level;
|
|
}
|
|
// echo "point:" . $entity->getPoint() . ",level:" . $level . "\n";
|
|
|
|
//기존정보와 Level값이 다르면 저장
|
|
if ($entity->getLevel() != $level) {
|
|
$old_level = $entity->getLevel();
|
|
$entity->setLevel($level);
|
|
$entity = $this->modify($entity);
|
|
log_message("notice", __FUNCTION__ . "=>{$entity}의 Level이 {$old_level}에서 {$entity->getLevel()}로 변경되었습니다.");
|
|
}
|
|
return $entity;
|
|
}
|
|
|
|
public function setPoint($id, int $point, $sign = '+'): UserEntity
|
|
{
|
|
$entity = is_numeric($id) ? $this->getEntityByPK(intval($id)) : $this->getEntityByID($id);
|
|
if (!$entity) {
|
|
throw new \Exception("해당 회원[{$id}]이 없습니다.");
|
|
}
|
|
|
|
switch ($sign) {
|
|
case '-':
|
|
if ($point < $point) {
|
|
throw new \Exception("기존포인트:{$point}가 감소 포인트:-{$point} 작습니다.\n");
|
|
}
|
|
$point = $point - $point;
|
|
break;
|
|
case '+':
|
|
$point = $point + $point;
|
|
break;
|
|
default:
|
|
throw new \Exception(__FUNCTION__ . "에서는 {$sign}은 사용할수 없습니다.\n");
|
|
// break;
|
|
}
|
|
|
|
//기존정보와 Point값이 다르면 저장
|
|
if ($entity->getPoint() != $point) {
|
|
$old_point = $entity->getPoint();
|
|
$entity->setPoint($point);
|
|
$entity = $this->modify($entity);
|
|
log_message("notice", __FUNCTION__ . "=>{$entity}의 Point가 {$old_point}에서 {$entity->getPoint()}로 변경되었습니다.");
|
|
}
|
|
return $this->checkLevel($entity);
|
|
}
|
|
public function setLevel(): void
|
|
{
|
|
foreach ($this->getEntitys() as $entity) {
|
|
$entity = $this->checkLevel($entity);
|
|
log_message("debug", __FUNCTION__ . "=>[{$entity}] 회원님의 Level은 {$entity->getLevel()} 입니다.");
|
|
}
|
|
}
|
|
|
|
//create용
|
|
public function create(UserEntity $entity): UserEntity
|
|
{
|
|
$entity = $this->create_process($entity);
|
|
//GID값이 PK랑 같은 값 전달 후 Entity 수정
|
|
$entity->gid = $entity->getPK();
|
|
$this->setFields(["gid"]);
|
|
return $this->modify_process($entity);
|
|
}
|
|
|
|
//modify용
|
|
public function modify(UserEntity $entity): UserEntity
|
|
{
|
|
return $this->modify_process($entity);
|
|
}
|
|
}
|