연습

[Typescript]: express의 req.user 붙이기

onaeonae1 2021. 5. 28. 17:59

들어가는 글

Typescript를 쓰기 전에 그냥 node+express에서는 JWT로 사용자 인증을 하고 해당 정보를 전달할 때

req.user = decoed_user 와 같은 식으로 처리를 해주었다.

그런데 이게 TypeScript에서는 막힌다.

 

설명

왜냐하면 express.Request에 "user" namespace가 없기 때문이다.

 

이를 추가해주려면 다음의 과정이 필요하다.

1. decoded_user interface를 정의

 -> 폴더 하나 파고 type 정의 후 export

2. express.Request 변경에 추가

 -> 사진 참고

import 후 interface Request에 user 추가

3. tsconfig 설정

 -> typeRoots 설정

./src/customTypes라고 여기에 정의해뒀다.

 

아니 이 간단한 걸 왜 못하고 시간을 날렸나?

mongoose model과 JWT로 decode된 user를 착각했기 때문이다.

위의 사진을 보면 뭔가 이상함을 느낄 수 있다.

JWT를 사용할 때는 당연히 user 정보를 모두 가지고 있지는 않는다. 특히 password를 들고 다니는건 바보짓이다.(encrypted 라고 해도)

그래서 어느정도 노출이 되도 큰 문제가 없는 데이터(userName 같은)들을 가지고 sign, verify를 한다.

 

그런데 나는 mongoose의 user model을 넣으려고 하다보니깐 req.user가 추가에 성공했어도 타입 문제가 결국 발생함.