-
Notifications
You must be signed in to change notification settings - Fork 6
서비스 흐름, API
- 로그인 여부 판단
- 되어있으면 가계부 목록
- 안되어 있으면 로그인 페이지
-
READ
-
GET /accountbook
request response statuscode, [{_id, name, description}...] -
이 때 accountbook 안에 transaction들도 모두 가지고 올 것인가?
- 만약 트랜잭션이 엄청 많다면 모든 transaction들을 가지고 있는 것이 성능 문제가 있을 것 같다.
- {_id, name, description}만 가져오고 accountbook 목록은 useState로 관리한다.
-
accoutbook 전체를 가지고 있는 store를 만들것인가?
- 굳이 필요가 없을 것 같다.
- 우리의 UI 상에서는 가계부 선택으로 돌아가서 가계부를 선택했을 때 상태가 유지될 필요가 없을 것 같다.
-
-
CREATE
-
POST /accountbook
request response name, description statuscode, _id, name, description
-
-
UPDATE
-
Patch /accountbook/:accountbookid
request response name, description statuscode, _id, name, description
-
-
DELETE
-
DELETE /accountbook/:accountbookid
request response statuscode
-
-
READ
-
GET /accountbook/:accountbookid
request response statuscode, {_id, name, description, category, user, payment, transaction} -
특정 어카운트북의 정보를 전부 store 데이터에 넣어서 전역으로 관리한다. 즉 어카운트북 안의 모든 페이지가 이 스토어를 참조한다.
- 여기서 달력과 차트는 store에 있는 값을 직접 변경하지 않고 참조만 하기 때문에 특별히 API가 필요하지 않다.
-
-
CREATE
-
POST /accountbook/:accountbookid/transaction
request response content(내용), type(수입/지출), category({name, type, icon}), cost, date, payment({name, descriptioni}) statuscode, {_id, name, description, category, user, payment, transaction}
- db.accountBookModel.find({_id})
- accountBook.transactions
- REQ => transaction 만들
- accountBookModel.update({_id}, {transactions : [ ...accountBook.transactions , transaction ]})
-
-
UPDATE
-
PATCH /accountbook/:accountbookid/transaction/:transactionid
request response content(내용), type(수입/지출), category({name, type, icon}), cost, date, payment({name, descriptioni}) statuscode -
mongoose에서 update를 할 때 return 값이 전체 data가 나오지 않기 때문에 응답코드만 주는 것이 편할 것 같다.
-
-
DELETE
-
DELETE /accountbook/:accountbookid/transaction/:transactionid
request response statuscode
-
-
READ
- accountbook 전체를 가져올 때 embeded 돼서 나오기 때문에 가계부의 결제수단만 가져오는 api는 필요가 없다.
-
CREATE
-
POST /accountbook/:accountbookid/payment
request response name, color, desc statuscode, _id, name, description, color
-
-
UPDATE
-
UPDATE /accountbook/:accountbookid/payment/:paymentid
request response name, color, desc statuscode
-
-
DELETE
DELETE /accountbook/:accountbookid/payment/:paymentid
-
CREATE
-
GET /accountbook/:accountbookid/category
request response name, type(수입/지출), icon statuscode, _id, name, type, icon
-
-
UPDATE
-
PATCH /accoutbook/:acccountbookid/category/:categoryid
request response name, type, icon statuscode
-
-
DELETE
-
DELETE /accoutbook/:acccountbookid/category/:categoryid
request response statuscode
-