User.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. <?php
  2. namespace App\Controllers;
  3. use CodeIgniter\RESTful\ResourceController;
  4. class User extends ResourceController
  5. {
  6. //유저 리스트
  7. public function userlist()
  8. {
  9. // DB 객체 얻기
  10. $db = \Config\Database::connect();
  11. $request = $this->request->getJSON(true);
  12. // USER_LIST 테이블 모든 레코드 가져오기
  13. $builder = $db->table('USER_LIST');
  14. $lists = $builder->get()->getResultArray();
  15. // PASSWORD 필드 제거
  16. $filtered = array_map(function($row) {
  17. unset($row['PASSWORD']);
  18. return $row;
  19. }, $lists);
  20. // 역순으로 정렬
  21. $filtered = array_reverse($filtered);
  22. // JSON 응답
  23. return $this->respond($filtered, 200);
  24. }
  25. //브랜드 리스트
  26. public function brandlist()
  27. {
  28. // DB 객체 얻기
  29. $db = \Config\Database::connect();
  30. $request = $this->request->getJSON(true);
  31. $builder = $db->table('BRAND_LIST');
  32. $lists = $builder->get()->getResultArray();
  33. // PASSWORD 필드 제거
  34. $filtered = array_map(function($row) {
  35. unset($row['PASSWORD']);
  36. return $row;
  37. }, $lists);
  38. // 역순으로 정렬
  39. $filtered = array_reverse($filtered);
  40. // JSON 응답
  41. return $this->respond($filtered, 200);
  42. }
  43. public function userSearch()
  44. {
  45. $db = \Config\Database::connect();
  46. // 요청 바디에서 filter와 keyword 추출 (예: {filter: "id", keyword: "admin"})
  47. $request = $this->request->getJSON(true);
  48. // 필수값 체크
  49. if (
  50. !isset($request['compId']) ||
  51. !isset($request['filter']) ||
  52. !isset($request['keyword']) ||
  53. !in_array($request['filter'], ['id', 'name', 'status'])
  54. ) {
  55. return $this->respond([
  56. 'status' => 'fail',
  57. 'message' => 'filter(id, name, status)와 keyword가 필요합니다.'
  58. ], 400);
  59. }
  60. $filterMap = [
  61. 'id' => 'ID',
  62. 'name' => 'NAME',
  63. 'status' => 'STATUS'
  64. ];
  65. $filterColumn = $filterMap[$request['filter']];
  66. $keyword = $request['keyword'];
  67. $status = isset($request['status']) ? $request['status'] : null;
  68. if (!isset($request['compId'])) {
  69. return $this->respond([
  70. 'status' => 'fail',
  71. 'message' => 'filter(compId)가 누락되었습니다.'
  72. ], 400);
  73. }
  74. $compId = $request['compId'];
  75. // 평문 검색 (LIKE 연산 사용)
  76. $builder = $db->table('ADM_LIST');
  77. if ($compId !== '0-000000') {
  78. $builder->where('COMP_ID', $compId);
  79. }
  80. // 사용중 관리자 리스트 검색, 삭제 관리자 리스트 검색 분리
  81. if ($status === '-1') {
  82. $builder->where('STATUS', '-1');
  83. } else {
  84. $builder->whereIn('STATUS', ['0', '1']);
  85. }
  86. $builder->like($filterColumn, $keyword);
  87. $lists = $builder->get()->getResultArray();
  88. // PASSWORD 제거
  89. $filtered = array_map(function($row) {
  90. unset($row['PASSWORD']);
  91. return $row;
  92. }, $lists);
  93. // 최신순(역순) 정렬 (ID 기준 또는 원하는 기준으로 변경 가능)
  94. $filtered = array_reverse($filtered);
  95. return $this->respond($filtered, 200);
  96. }
  97. //관리자 등록
  98. public function userRegister()
  99. {
  100. // DB 객체 얻기
  101. $db = \Config\Database::connect();
  102. $request = $this->request->getJSON(true);
  103. if (
  104. !isset($request['id']) ||
  105. !isset($request['password']) ||
  106. !isset($request['name']) ||
  107. !isset($request['email']) ||
  108. !isset($request['phone'])
  109. ) {
  110. return $this->respond([
  111. 'status' => 'fail',
  112. 'message' => '필수 값이 누락됐습니다.(id, password, name, email, phone)'
  113. ], 400);
  114. }
  115. // 비밀번호 해시
  116. $hashedPassword = password_hash($request['password'], PASSWORD_DEFAULT);
  117. $userData = [
  118. 'id' => $request['id'],
  119. 'password' => $hashedPassword,
  120. 'name' => $request['name'],
  121. 'email' => $request['email'],
  122. 'regdate' => date('Y-m-d', strtotime($request['regdate'])),
  123. 'phone' => $request['phone'],
  124. 'status' => 0,
  125. 'comp_name' => $request['comp_name'],
  126. 'comp_id' => $request['comp_id'],
  127. ];
  128. $builder = $db->table('ADM_LIST');
  129. if ($builder->insert($userData)) {
  130. return $this->respond(['message' => '관리자 등록 성공'], 201);
  131. } else {
  132. return $this->respond(['error' => '등록 실패'], 500);
  133. }
  134. }
  135. //아이디 중복체크
  136. public function userIDChk(){
  137. $db = \Config\Database::connect();
  138. $request = $this->request->getJSON(true);
  139. if (!isset($request['id']) || trim($request['id']) === '') {
  140. return $this->respond([
  141. 'status' => 'fail',
  142. 'message' => 'ID가 없습니다.'
  143. ], 400);
  144. }
  145. $id = $request['id'];
  146. // 영어 소문자와 숫자만 허용 (정규식 체크)
  147. if (!preg_match('/^[a-z0-9]+$/', $id)) {
  148. return $this->respond([
  149. 'status' => 'fail',
  150. 'message' => 'ID는 영어 소문자와 숫자만 사용할 수 있습니다.'
  151. ], 400);
  152. }
  153. $builder = $db->table('ADM_LIST');
  154. $exists = $builder->where('id', $id)->countAllResults();
  155. if ($exists > 0) {
  156. return $this->respond([
  157. 'status' => 'fail',
  158. 'message' => '이미 사용 중인 ID입니다.'
  159. ], 409);
  160. }
  161. return $this->respond([
  162. 'status' => 'success',
  163. 'message' => '사용 가능한 ID입니다.'
  164. ], 200);
  165. }
  166. //관리자 수정
  167. public function userUpdate(){
  168. $db = \Config\Database::connect();
  169. $request = $this->request->getJSON(true);
  170. if (
  171. !isset($request['id']) ||
  172. !isset($request['name']) ||
  173. !isset($request['phone']) ||
  174. !isset($request['email']) ||
  175. !isset($request['regdate']) ||
  176. !isset($request['status'])
  177. ) {
  178. return $this->respond([
  179. 'status' => 'fail',
  180. 'message' => '필수 값이 누락됐습니다.(id, name, phone, email, regdate, status)'
  181. ], 400);
  182. }
  183. $id = $request['id'];
  184. $userData = [
  185. 'EMAIL' => $request['email'],
  186. 'REGDATE' => date('Y-m-d', strtotime($request['regdate'])),
  187. 'PHONE' => $request['phone'],
  188. 'STATUS' => $request['status'],
  189. 'COMP_NAME' => $request['comp_name'],
  190. 'COMP_ID' => $request['comp_id'],
  191. ];
  192. //비밀번호 변경시
  193. if (!empty($request['password'])) {
  194. $userData['PASSWORD'] = password_hash($request['password'], PASSWORD_DEFAULT);
  195. }
  196. $updated = $db->table('ADM_LIST')->where('ID', $id)->update($userData);
  197. if ($updated) {
  198. return $this->respond([
  199. 'status' => 'success',
  200. 'message' => '관리자 정보가 수정되었습니다.'
  201. ], 200);
  202. } else {
  203. return $this->respond([
  204. 'status' => 'fail',
  205. 'message' => '수정에 실패했습니다.'
  206. ], 500);
  207. }
  208. }
  209. //관리자 상세
  210. public function userDetail($id)
  211. {
  212. // DB 객체 얻기
  213. $db = \Config\Database::connect();
  214. $builder = $db->table('ADM_LIST');
  215. $user = $builder->where('id', $id)->get()->getRowArray();
  216. if($user){
  217. // 보안상 패스워드는 반환 X
  218. unset($user['password']);
  219. return $this->respond($user, 200);
  220. } else {
  221. return $this->respond([
  222. 'status' => 'fail',
  223. 'message' => '해당 ID의 관리자가 존재하지 않습니다.'
  224. ], 404);
  225. }
  226. }
  227. //관리자 상태 변경(삭제, 복원)
  228. public function userStatusUpdate($id){
  229. $db = \Config\Database::connect();
  230. $user = $db->table('ADM_LIST')->select('STATUS')->where('ID', $id)->get()->getRowArray();
  231. $currentStatus = (int) $user['STATUS'];
  232. if ($currentStatus == -1 ){
  233. // 복원 시 사용중 상태로 변경
  234. $nextStatus = 0;
  235. } else {
  236. // 삭제 시 삭제 상태로 변경
  237. $nextStatus = -1;
  238. }
  239. $updated = $db->table('ADM_LIST')
  240. ->where('ID', $id)
  241. ->update(['STATUS' => $nextStatus, 'REGDATE' => date('Y-m-d') ]);
  242. if ($updated) {
  243. return $this->respond(['status' => 'success', 'message' => '상태 변경 완료', 'new_status' => $nextStatus], 200);
  244. } else {
  245. return $this->respond(['status' => 'fail', 'message' => '상태 변경 실패']);
  246. }
  247. }
  248. // contact_inf로 사용자 정보 조회
  249. public function getInfName($seq)
  250. {
  251. $db = \Config\Database::connect();
  252. // SEQ로 USER_LIST에서 사용자 정보 조회
  253. $builder = $db->table('USER_LIST');
  254. $user = $builder->select('SEQ, NAME, NICK_NAME')
  255. ->where('SEQ', $seq)
  256. ->get()
  257. ->getRowArray();
  258. if ($user) {
  259. return $this->respond([
  260. 'status' => 'success',
  261. 'data' => [
  262. 'SEQ' => $user['SEQ'],
  263. 'NAME' => $user['NAME'],
  264. 'NICK_NAME' => $user['NICK_NAME']
  265. ]
  266. ], 200);
  267. } else {
  268. return $this->respond([
  269. 'status' => 'fail',
  270. 'message' => '해당 SEQ의 사용자를 찾을 수 없습니다.'
  271. ], 404);
  272. }
  273. }
  274. public function getBrdName($seq)
  275. {
  276. $db = \Config\Database::connect();
  277. $builder = $db->table('BRAND_LIST');
  278. $user = $builder->select('SEQ, COMPANY_NAME')
  279. ->where('SEQ', $seq)
  280. ->get()
  281. ->getRowArray();
  282. if ($user) {
  283. return $this->respond([
  284. 'status' => 'success',
  285. 'data' => [
  286. 'SEQ' => $user['SEQ'],
  287. 'NAME' => $user['COMPANY_NAME'],
  288. ]
  289. ], 200);
  290. } else {
  291. return $this->respond([
  292. 'status' => 'fail',
  293. 'message' => '해당 SEQ의 사용자를 찾을 수 없습니다.'
  294. ], 404);
  295. }
  296. }
  297. }