Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[3주차] 도전 과제 제출 #3

Open
wants to merge 2 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions week3/advanced/nodemon.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
{
"watch": ["src", ".env"],
"ext": "js,ts,json",
"ignore": ["src/**/*.spec.ts"],
"exec": "ts-node --transpile-only ./src/index.ts"
}
19 changes: 19 additions & 0 deletions week3/advanced/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
{
"name": "advanced",
"version": "1.0.0",
"main": "index.js",
"license": "MIT",
"scripts": {
"dev": "nodemon",
"build": "tsc && node dist"
},
"dependencies": {
"dotenv": "^16.0.3",
"express": "^4.18.2"
},
"devDependencies": {
"@types/express": "^4.17.14",
"@types/node": "^18.11.9",
"nodemon": "^2.0.20"
}
}
9 changes: 9 additions & 0 deletions week3/advanced/src/api/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
// src/api/index.ts

import express, { Router } from "express";

const router: Router = express.Router(); // express 라우팅 시스템을 받아올거!

router.use("/video", require("./video"));

module.exports = router; // 모듈로 반환
40 changes: 40 additions & 0 deletions week3/advanced/src/api/video.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
// src/api/user.ts

import express, { Request, Response, Router } from "express";
// express 모듈에서 express, (request, response, router)-> 타입 정의를 위해 불러옴!

const router: Router = express.Router();

router.get("/:movieId", (req: Request, res: Response) => {
const { movieId } = req.params;
return res.status(200).json({
status: 200,
message: "영화 조회 성공",
data: {
_id: movieId,
thumbnail: `${process.env.S3_BASE_URL}/aws+%E1%84%8B%E1%85%B5%E1%84%86%E1%85%B5%E1%84%8C%E1%85%B5.png`,
titleImage: `${process.env.S3_BASE_URL}/aws+%E1%84%8B%E1%85%B5%E1%84%86%E1%85%B5%E1%84%8C%E1%85%B5.png`,
videoUrl: `${process.env.S3_BASE_URL}/aws+%E1%84%8B%E1%85%B5%E1%84%86%E1%85%B5%E1%84%8C%E1%85%B5.png`,
movieInfo: {
title: "수리남",
isOriginal: true,
releaseDate: "2022-10-30",
ageLimit: 15,
episodeCount: 7,
actors: ["하정우", "..."],
genres: ["공포", "스릴러"],
seriesFeatures: [],
isLiked: true,
isHave: true,
},
},
currentEpisode: {
episodeNumber: 6,
summary: "재밌다..1화",
entireRunTime: 57,
currentRunTime: 62,
},
});
});

module.exports = router;
26 changes: 26 additions & 0 deletions week3/advanced/src/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
// src/index.ts
import express, { NextFunction, Request, Response } from "express";

const app = express(); // express 객체 받아옴
const PORT = 3000; // 사용할 port를 3000번으로 설정

app.use(express.json()); // express 에서 request body를 json 으로 받아오겠다.

app.use("/api", require("./api")); // use -> 모든 요청
// localhost:8000/api -> api 폴더
// localhost:8000/api/user -> user.ts

require("dotenv").config(); // .env file 가져오기

//* HTTP method - GET
app.get("/", (req: Request, res: Response, next: NextFunction) => {
res.send("마! 이게 서버다!");
});

app.listen(PORT, () => {
console.log(`
#############################################
🛡️ Server listening on port: ${PORT} 🛡️
#############################################
`);
}); // 8000 번 포트에서 서버를 실행하겠다!
29 changes: 29 additions & 0 deletions week3/advanced/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
// tsconfig.json
{
"compilerOptions": {
"target": "es6", //? 어떤 버전으로 컴파일
"allowSyntheticDefaultImports": true, //? default export가 없는 모듈에서 default imports를 허용
"experimentalDecorators": true, //? decorator 실험적 허용
"emitDecoratorMetadata": true, //? 데코레이터가 있는 선언에 대해 특정 타입의 메타 데이터를 내보내는 실험적인 지원
"skipLibCheck": true, //? 정의 파일 타입 체크 여부
"moduleResolution": "node", //? commonJS -> node 에서 동작
"module": "commonjs", //? import 문법
"strict": true, //? 타입 검사 엄격하게
"pretty": true, //? error 메시지 예쁘게
"sourceMap": true, //? 소스맵 파일 생성 -> .ts가 .js 파일로 트랜스 시 .js.map 생성
"outDir": "./dist", //? 트랜스 파일 (.js) 저장 경로
"allowJs": true, //? js 파일 ts에서 import 허용
"esModuleInterop": true, //? ES6 모듈 사양을 준수하여 CommonJS 모듈을 가져올 수 있게 허용
"typeRoots": [
"./src/types/express.d.ts", //? 타입(*.d.ts)파일을 가져올 디렉토리 설정
"./node_modules/@types" //? 설정 안할시 기본적으로 ./node_modules/@types
]
},
"include": [
"./src/**/*" //? build 시 포함
],
"exclude": [
"node_modules", //? build 시 제외
"tests"
]
}
Loading