프론트엔드 - 정현용
├── nest-cli.json
├── package.json
├── src
│ ├── app.controller.spec.ts
│ ├── app.controller.ts
│ ├── app.module.ts
│ ├── app.service.ts
│ ├── auth
│ │ └── auth.middleware.ts
│ ├── ims.we
│ │ ├── dto
│ │ ├── entities
│ │ │ └── ims.we.entity.ts
│ │ ├── ims.we.controller.spec.ts
│ │ ├── ims.we.controller.ts
│ │ ├── ims.we.module.ts
│ │ ├── ims.we.service.spec.ts
│ │ └── ims.we.service.ts
│ ├── main.ts
│ ├── middleware
│ │ ├── auth.module.ts
│ │ ├── dto
│ │ │ └── authDto.ts
│ │ ├── guard.ts
│ │ └── passport.jwt.ts
│ ├── urls
│ │ ├── dto
│ │ │ ├── create-qrcode.ts
│ │ │ ├── create-url.dto.ts
│ │ │ ├── get-original-url.dto.ts
│ │ │ ├── get-url.dto.ts
│ │ │ └── update-url.dto.ts
│ │ ├── entities
│ │ │ └── url.entity.ts
│ │ ├── urls.controller.spec.ts
│ │ ├── urls.controller.ts
│ │ ├── urls.module.ts
│ │ ├── urls.service.spec.ts
│ │ └── urls.service.ts
│ └── users
│ ├── entities
│ │ └── users.entity.ts
│ ├── users.controller.spec.ts
│ ├── users.controller.ts
│ ├── users.module.ts
│ ├── users.service.spec.ts
│ └── users.service.ts
├── test
│ ├── app.e2e-spec.ts
│ └── jest-e2e.json
├── tsconfig.build.json
├── tsconfig.json
└── yarn.lock
- 백엔드 저장소 구조는 위와 같습니다.
Backend: Nest.js
Frontend: Next.js
-
yarn을 설치해 주세요.
brew install yarn
yarn -v
- 명령어를 입력했을 때 1.22.21 미만이면 버전 업그레이드를 진행해주세요.
-
nestjs cli 10.2.1 버전을 설치해 주세요.
sudo npm -i g @nestjs/[email protected]
-
백엔드 저장소를 클론해주세요.
git clone https://github.com/chs991209/ims_shortenurl_backend
-
yarn 패키지를 설치해 주세요.
yarn install
- 명령어는 디렉토리 최상단에서 실행해주세요.
- pkg list는 package.json에서 확인하시면 됩니다.
-
dbmate를 (brew로도 설치 가능) 글로벌 설치하여 db 설치를 진행해 주세요
$ brew install -g dbmate $ npm install dbmate
- dbmate를 설치하였으면 mysql 설치를 진행합니다. username과 password를 지정하고 사용할 database를 생성해 줍니다.
- Project 폴더 내에 .env 파일을 생성합니다.
DATABASE_URL="protocol(ex.mysql)://username:password@host:port/DATABASE_NAME"
- .env 파일 내에 위 내용을 추가해 줍니다. sql 파일을 Repo에서 내려받습니다.
mkdir db
- 클론받은 directory 최상단에서 db 폴더를 생성해 줍니다.
-
클론받은 sql 파일을 db 폴더 내의 repo의 순서와 동일하게 넣어 줍니다.
dbmate up
dbmate와 관련된 설명은 여기에서 볼 수 있습니다(공식 문서).
- 아래 명령어를 입력하여 실행해주세요.
yarn start:dev
- 명령어는 디렉토리 최상단에서 실행해주세요.
위코드 50기 팀원 총 3명이 참여하였습니다.
프론트엔드 1명, 백엔드 2명이 참여하였습니다.
현재 기여하기는 팀원들을 통해서만 가능하니, 추가 코드 수정은 팀원을 통해 추후 진행할 예정입니다.
- 줄여진 주소를 입력하면 원본 url로 이동하도록 호스팅해 주는 기능을 참고하였습니다.
- bitly는 비회원은 기능을 이용할 수가 없습니다.
- 비회원은 24시간동안 10회, 회원은 무제한으로 사용할 수 있도록 기능을 구성하였습니다.
- 회원의 결제 멤버십에 따른 기능 확장은 추후에 추가하도록 정하였습니다.
- 비회원, 회원 모두 원본 url로 이동시키는 qrcode 이미지 생성을 할 수 있습니다.
- 로그인한 회원이 마이페이지에 접근하여 과거의 URL 생성 History를 볼 수 있습니다.
🍑 Munyeong | 🥑 Hyunsu | 🍇 Hyeonyong |
---|
Server 관련 google docs는 여기에 있습니다.
저장소에 별 달아주세요 ✨✨✨