diff --git a/group-admin/pic/group-approval.png b/group-admin/assets/group-approval.png
similarity index 100%
rename from group-admin/pic/group-approval.png
rename to group-admin/assets/group-approval.png
diff --git a/group-admin/pic/group-config-detail.png b/group-admin/assets/group-config-detail.png
similarity index 100%
rename from group-admin/pic/group-config-detail.png
rename to group-admin/assets/group-config-detail.png
diff --git a/group-admin/pic/group-create-detail.png b/group-admin/assets/group-create-detail.png
similarity index 100%
rename from group-admin/pic/group-create-detail.png
rename to group-admin/assets/group-create-detail.png
diff --git a/group-admin/pic/group-detail.png b/group-admin/assets/group-detail.png
similarity index 100%
rename from group-admin/pic/group-detail.png
rename to group-admin/assets/group-detail.png
diff --git a/group-admin/pic/group-member.png b/group-admin/assets/group-member.png
similarity index 100%
rename from group-admin/pic/group-member.png
rename to group-admin/assets/group-member.png
diff --git a/group-admin/pic/management.png b/group-admin/assets/management.png
similarity index 100%
rename from group-admin/pic/management.png
rename to group-admin/assets/management.png
diff --git a/group-admin/pic/myGroup.png b/group-admin/assets/myGroup.png
similarity index 100%
rename from group-admin/pic/myGroup.png
rename to group-admin/assets/myGroup.png
diff --git a/group-admin/pic/problem-create-detail.png b/group-admin/assets/problem-create-detail.png
similarity index 100%
rename from group-admin/pic/problem-create-detail.png
rename to group-admin/assets/problem-create-detail.png
diff --git a/group-admin/pic/problem-create.png b/group-admin/assets/problem-create.png
similarity index 100%
rename from group-admin/pic/problem-create.png
rename to group-admin/assets/problem-create.png
diff --git a/group-admin/group.md b/group-admin/group.md
index 04a1c66..6c9e9b8 100644
--- a/group-admin/group.md
+++ b/group-admin/group.md
@@ -4,60 +4,64 @@
::: warning Group 내의 계층 관련 ⛔️
Group 내에서는 두 가지의 계층이 존재합니다.
-- __GroupLeader__ : 그룹의 관리자 역할으로, Group 및 Member 관리에 관한 권한들을 갖고 있습니다.
-- __GroupMember__ : 그룹 내의 일반적인 Member 역할입니다.
+
+- **GroupLeader** : 그룹의 관리자 역할으로, Group 및 Member 관리에 관한 권한들을 갖고 있습니다.
+- **GroupMember** : 그룹 내의 일반적인 Member 역할입니다.
본 Section의 독자는 GroupLeader로 가정합니다.
:::
-## 그룹 관리
+
+## 그룹 관리
### 새로운 그룹 생성
Manager 이상 계층의 관리자는 직접 그룹을 생성할 수 있습니다.
Group 페이지에서 +Create Group
버튼을 클릭하면 그룹 생성창으로 넘어갑니다.
-![My Groups](pic/myGroup.png)
+![My Groups](assets/myGroup.png)
원하는 Group Name, Group Configuration, Group Description을 작성하고 Save를 클릭하면 그룹이 생성됩니다. 이때, 그룹을 생성한 관리자는 자동으로 해당 그룹의 GroupLeader로 설정됩니다.
-![Create Group](pic/group-create-detail.png)
+![Create Group](assets/group-create-detail.png)
Group Configuration의 자세한 설명은 아래와 같습니다.
- - __Show On List__ :
- 자신의 그룹의 전체 공개(All Groups에 표시) 여부를 결정합니다.
- - __Allow Join From Search__ : 그룹 목록에서 해당 그룹을 선택한 사용자들에게 그룹 가입 버튼의 공개 여부를 결정합니다.
- - __Allow Join With URL__ : 그룹 가입용 URL 발급 가능 여부를 결정합니다. (⚠️ Allow Join From Search와 Allow Join With URL이 모두 False
라면 경고창을 반환합니다.)
- - __Require Approval Before Join__ : 가입 승인 절차의 유무를 결정합니다. False
라면 승인 절차없이 즉시 가입이 완료됩니다.
+
+- **Show On List** :
+ 자신의 그룹의 전체 공개(All Groups에 표시) 여부를 결정합니다.
+- **Allow Join From Search** : 그룹 목록에서 해당 그룹을 선택한 사용자들에게 그룹 가입 버튼의 공개 여부를 결정합니다.
+- **Allow Join With URL** : 그룹 가입용 URL 발급 가능 여부를 결정합니다. (⚠️ Allow Join From Search와 Allow Join With URL이 모두 False
라면 경고창을 반환합니다.)
+- **Require Approval Before Join** : 가입 승인 절차의 유무를 결정합니다. False
라면 승인 절차없이 즉시 가입이 완료됩니다.
### 기존 그룹 관리
+
관리자들은 상단 Header 중 Group을 눌러 자신이 속한 그룹들을 확인할 수 있습니다.
이때, 자신이 GroupLeader로 속한 그룹은 그룹명 우측 상단에 톱니바퀴(⚙️) 모양의 아이콘이 뜨게 됩니다.
-![My Groups](pic/myGroup.png)
+![My Groups](assets/myGroup.png)
톱니바퀴 아이콘(⚙️)을 클릭시 관리자용 그룹 창으로 이동하게 됩니다.
관리자는 그룹 창에서 (1) 그룹 세부설정 수정 (2) 초대 URL 생성 (3) 그룹 삭제를 할 수 있습니다.
-![Group Config](pic/group-detail.png)
+![Group Config](assets/group-detail.png)
+
+- **그룹 세부설정 수정**
-- __그룹 세부설정 수정__
-
관리자는 그룹명 옆의 연필 아이콘(📝)을 클릭해 그룹 세부 설정을 수정할 수 있습니다.
- ![Group Config](pic/group-config-detail.png)
+ ![Group Config](assets/group-config-detail.png)
Group Name, Group Configuration, Description을 수정할 수 있습니다.
-- __초대 URL 생성__
+- **초대 URL 생성**
- Create URL
버튼을 클릭하여 학생들이 클릭시 해당 그룹에 가입할 수 있는 일회용 초대 URL을 생성할 수 있습니다.
+ Create URL
버튼을 클릭하여 학생들이 클릭시 해당 그룹에 가입할 수 있는 일회용 초대 URL을 생성할 수 있습니다.
-- __그룹 삭제__
+- **그룹 삭제**
Admin, SuperAdmin 계층의 관리자는 바로 그룹을 삭제할 수 있으며, 이외의 관리자는 자신이 생성한 그룹에 한해서 삭제할 수 있습니다.
## 멤버 관리
-![Group Config](pic/group-detail.png)
+![Group Config](assets/group-detail.png)
관리자는 관리자용 그룹창에서 Member 탭을 통해 관리자용 멤버창으로 접속할 수 있습니다.
-![Group Member](pic/group-member.png)
+![Group Member](assets/group-member.png)
관리자용 멤버창에서 사용할 수 있는 기능들은 아래와 같습니다.
@@ -67,14 +71,14 @@ Group Configuration의 자세한 설명은 아래와 같습니다.
계층 변경은 두 가지의 경우가 존재합니다.
-- __GroupLeader에서 GroupMember로 downgrade__
+- **GroupLeader에서 GroupMember로 downgrade**
Member 탭의 GroupLeaders 목록에서 ⬇ 버튼을 클릭하면 해당 멤버의 계층을 GroupMember로 downgrade할 수 있습니다.
> 이때, 모든 GroupLeader를 GroupMember로 downgrade할 수 없습니다.(최소 한 명의 GroupLeader가 존재해야 합니다.)
> 또한 Admin 및 SuperAdmin 계층의 사용자는 downgrade할 수 없습니다.
-- __GroupMember에서 GroupLeader로 upgrade__
+- **GroupMember에서 GroupLeader로 upgrade**
Member 탭의 GroupMembers 목록에서 ⬆ 버튼을 클릭하면 해당 멤버의 계층을 GroupLeader로 upgrade할 수 있습니다.
@@ -84,6 +88,5 @@ Group Configuration의 자세한 설명은 아래와 같습니다.
### 그룹 가입 승인 및 거절
-![Group Approval](pic/group-approval.png)
+![Group Approval](assets/group-approval.png)
관리자는 Group Member Approval 목록에서 대기중인 그룹 가입신청 내역들을 확인할 수 있으며, 승인(✅) 혹은 거절(❎)을 선택할 수 있습니다.
-
diff --git a/group-admin/problem.md b/group-admin/problem.md
index 317ba8c..e7f48e3 100644
--- a/group-admin/problem.md
+++ b/group-admin/problem.md
@@ -1,51 +1,52 @@
# 문제 생성 및 관리하기
+
본 Section에서는 문제를 생성하고 관리하는 기능들을 소개합니다.
## 문제 생성 및 삭제하기
+
관리자들은 상단 Header 중 Group을 눌러 자신이 속한 그룹들을 확인할 수 있습니다.
이때, 자신이 GroupLeader로 속한 그룹은 그룹명 우측 상단에 톱니바퀴(⚙️) 모양의 아이콘이 뜨게 됩니다.
-![My Groups](pic/myGroup.png)
+![My Groups](assets/myGroup.png)
톱니바퀴 아이콘(⚙️)을 클릭시 관리자용 그룹 창으로 이동하게 됩니다.
-![Group Config](pic/group-detail.png)
+![Group Config](assets/group-detail.png)
-관리자는 옆 Problem 탭을 통해 관리자용 Problem 창으로 이동할 수 있습니다.
+관리자는 옆 Problem 탭을 통해 관리자용 Problem 창으로 이동할 수 있습니다.
-![Problem Create](pic/problem-create.png)
+![Problem Create](assets/problem-create.png)
### 문제 생성하기
그룹 내에서 문제를 생성할 수 있는 방법은 세 경우가 있습니다.
-- __문제를 직접 생성하는 경우__ (Create
버튼)
+- **문제를 직접 생성하는 경우** (Create
버튼)
Create
버튼을 누르면 직접 문제를 생성할 수 있습니다.
- ![Problem Create](pic/problem-create-detail.png)
+ ![Problem Create](assets/problem-create-detail.png)
문제의 세부 구성사항은 아래와 같습니다.
- - __Title__ : 문제의 제목을 설정합니다.
- - __Difficulty__ : 문제의 난이도를 설정합니다 Level 1~5까지 존재합니다.
- - __Language__ : 문제의 지원언어를 설정합니다. 종류는 `C`, `C++`,`Java`, `Python3`로 이루어져 있습니다.
- - __Description__ : 문제의 설명을 설정합니다.
- - __Input Description__ : 입력과 관련한 설명을 설정합니다.
- - __Output Description__ : 출력과 관련한 설명을 설정합니다.
- - __Time Limit(ms)__ : 시간 제한을 설정합니다. 단위는 ms(밀리초)입니다.
- - __Memory Limit(MB)__ : 메모리 제한을 설정합니다. 단위는 MB(메가바이트)입니다.
- - __Hint__ : 표시될 힌트를 설정합니다.
- - __Input Sample, Output Sample__ : 사용자에게 보여질 입력, 출력 예시를 설정합니다.
- - __Testcase__ : 테스트케이스를 설정합니다.
-
-- __문제를 Import하는 경우__ (Import
버튼)
+
+ - **Title** : 문제의 제목을 설정합니다.
+ - **Difficulty** : 문제의 난이도를 설정합니다 Level 1~5까지 존재합니다.
+ - **Language** : 문제의 지원언어를 설정합니다. 종류는 `C`, `C++`,`Java`, `Python3`로 이루어져 있습니다.
+ - **Description** : 문제의 설명을 설정합니다.
+ - **Input Description** : 입력과 관련한 설명을 설정합니다.
+ - **Output Description** : 출력과 관련한 설명을 설정합니다.
+ - **Time Limit(ms)** : 시간 제한을 설정합니다. 단위는 ms(밀리초)입니다.
+ - **Memory Limit(MB)** : 메모리 제한을 설정합니다. 단위는 MB(메가바이트)입니다.
+ - **Hint** : 표시될 힌트를 설정합니다.
+ - **Input Sample, Output Sample** : 사용자에게 보여질 입력, 출력 예시를 설정합니다.
+ - **Testcase** : 테스트케이스를 설정합니다.
+
+- **문제를 Import하는 경우** (Import
버튼)
추후 추가할 예정입니다.
-- __문제를 파일로 업로드 하는 경우__ (File Upload
버튼)
+- **문제를 파일로 업로드 하는 경우** (File Upload
버튼)
Excel 파일을 업로드하여 여러 개의 문제 및 테스트 케이스들을 업로드할 수 있습니다.
### 문제 삭제하기
-문제 옆 🗑️ 버튼을 클릭하면 문제를 삭제할 수 있습니다.
-
-
+문제 옆 🗑️ 버튼을 클릭하면 문제를 삭제할 수 있습니다.
diff --git a/intro/backend-preview.png b/intro/assets/backend-preview.png
similarity index 100%
rename from intro/backend-preview.png
rename to intro/assets/backend-preview.png
diff --git a/intro/bruno-env.png b/intro/assets/bruno-env.png
similarity index 100%
rename from intro/bruno-env.png
rename to intro/assets/bruno-env.png
diff --git a/intro/bruno-select.png b/intro/assets/bruno-select.png
similarity index 100%
rename from intro/bruno-select.png
rename to intro/assets/bruno-select.png
diff --git a/intro/bruno-start.png b/intro/assets/bruno-start.png
similarity index 100%
rename from intro/bruno-start.png
rename to intro/assets/bruno-start.png
diff --git a/intro/codedang.png b/intro/assets/codedang.png
similarity index 100%
rename from intro/codedang.png
rename to intro/assets/codedang.png
diff --git a/intro/frontend-preview.png b/intro/assets/frontend-preview.png
similarity index 100%
rename from intro/frontend-preview.png
rename to intro/assets/frontend-preview.png
diff --git a/intro/git-clone.png b/intro/assets/git-clone.png
similarity index 100%
rename from intro/git-clone.png
rename to intro/assets/git-clone.png
diff --git a/intro/graphql-docs.png b/intro/assets/graphql-docs.png
similarity index 100%
rename from intro/graphql-docs.png
rename to intro/assets/graphql-docs.png
diff --git a/intro/new-wsl-window.png b/intro/assets/new-wsl-window.png
similarity index 100%
rename from intro/new-wsl-window.png
rename to intro/assets/new-wsl-window.png
diff --git a/intro/remote-containers.png b/intro/assets/remote-containers.png
similarity index 100%
rename from intro/remote-containers.png
rename to intro/assets/remote-containers.png
diff --git a/intro/remote-wsl.png b/intro/assets/remote-wsl.png
similarity index 100%
rename from intro/remote-wsl.png
rename to intro/assets/remote-wsl.png
diff --git a/intro/reopen-in-container.png b/intro/assets/reopen-in-container.png
similarity index 100%
rename from intro/reopen-in-container.png
rename to intro/assets/reopen-in-container.png
diff --git a/intro/vscode-download.png b/intro/assets/vscode-download.png
similarity index 100%
rename from intro/vscode-download.png
rename to intro/assets/vscode-download.png
diff --git a/intro/bruno.md b/intro/bruno.md
index ca07c7c..12af3fe 100644
--- a/intro/bruno.md
+++ b/intro/bruno.md
@@ -21,7 +21,7 @@ https://www.usebruno.com/downloads
Bruno를 실행하고 'Open Collection'을 클릭합니다.
Codedang 폴더에서 collection 폴더의 client 또는 admin을 선택합니다.
-![Open Collection](bruno-start.png)
+![Open Collection](assets/bruno-start.png)
### 3. 환경 변수 설정
@@ -30,13 +30,13 @@ Codedang 폴더에서 collection 폴더의 client 또는 admin을 선택합니
- Development: 개발 서버 (https://dev.codedang.com)
- Local: 로컬 서버 (http://localhost)
-![Environment](bruno-env.png)
+![Environment](assets/bruno-env.png)
### 4. 확인
왼쪽 탭에서 request를 선택하여 실행할 수 있습니다. `baseUrl`이 초록색으로 표시되는지 확인해주세요.
-![Select](bruno-select.png)
+![Select](assets/bruno-select.png)
## Convention 🤙
@@ -72,9 +72,11 @@ Endpoint마다 'Succeed' request의 'Docs' 탭에 아래 Format을 준수하여
```markdown
## API 제목
+
API가 수행하는 역할을 기재합니다.
### Args / Query / Params / Body
+
필요한 경우, Args/Query/Params/Body에 대한 설명을 표로 정리합니다.
이름, 타입, 의미, 기본값, 제약사항을 포함해야 합니다.
(예)
@@ -85,19 +87,21 @@ API가 수행하는 역할을 기재합니다.
|problemId|Int|problemId와 contestId중 하나는 반드시 포함한다.|
|contestId|Int|problemId와 contestId중 하나는 반드시 포함한다.|
-
### Error Case
+
API를 호출했을 때 발생 가능한 Error Case의 이름과 설명을 기재합니다.
Error case의 이름은 실패하는 파일의 이름과 일치시켜주세요.
이름은 '#' 4개, 설명은 줄글로 작성합니다.
(예)
+
#### BAD_USER_INPUT(1)
+
password가 조건에 맞지 않는 경우.
```
### Scripts
-로그인 및 권한이 필요한 request의 경우, Pre Request에서 사전 인증 작업을 수행해주세요. GraphQL의 경우, Admin 계정으로 로그인하는 작업이 전역으로 적용되어 있습니다.
+로그인 및 권한이 필요한 request의 경우, Pre Request에서 사전 인증 작업을 수행해주세요. GraphQL의 경우, Admin 계정으로 로그인하는 작업이 전역으로 적용되어 있습니다.
~~Request를 보낼 때 상황별로 결과가 달라지지 않게 해주세요. 다시 말해 **언제나 동일한 결과**가 오게 해주세요.~~
@@ -106,14 +110,18 @@ password가 조건에 맞지 않는 경우.
모든 request마다 test를 충분히 작성해주세요(상태 코드 검사, body 검사 등). PR이 merge될 때마다 자동으로 E2E 검사가 이뤄집니다.
다음 항목을 포함해야 합니다.
+
#### REST API
+
- 성공하는 경우
- res.status
- res.body의 모든 property
- 실패하는 경우
- res.status
- res.message
+
#### GraphQL
+
- 성공하는 경우
- res.body.data[0] 존재 유무
- 실패하는 경우
@@ -122,7 +130,7 @@ password가 조건에 맞지 않는 경우.
### GraphQL
-![GraphQL Docs](graphql-docs.png)
+![GraphQL Docs](assets/graphql-docs.png)
GraphQL 서버 개발 시, field 타입을 정확하게 지정하여 Docs panel만으로 필드 및 반환 객체의 이름과 타입 정보를 알 수 있게 해 주세요.
Query나 Mutation에 인자가 들어가는 경우, `Variables` 항목에 분리하여 작성해주세요.
diff --git a/intro/getting-started.md b/intro/getting-started.md
index 1243a1e..33c00ae 100644
--- a/intro/getting-started.md
+++ b/intro/getting-started.md
@@ -7,33 +7,33 @@
2. GitPod
3. Manual
-가장 권장하는 개발 환경은 Container 내에서 개발하는 Visual Studio Code이지만, 어려울 경우에는 GitPod을 이용하거나 직접 세팅할 수도 있습니다.
+가장 권장하는 개발 환경은 Container 내에서 개발하는 Visual Studio Code이지만, 어려울 경우에는 GitPod을 이용하거나 직접 세팅할 수도 있습니다.
## Visual Studio Code (이하 VSCode)
### 1. 기본 도구 설치 (Git, WSL2(Windows), Docker)
- **Git**: Windows는 [https://git-scm.com/download/win](https://git-scm.com/download/win)에서 다운로드하고, Mac은 [https://git-scm.com/download/mac](https://git-scm.com/download/mac)에서 다운로드합니다.
-Linux는 패키지 관리도구로 쉽게 설치할 수 있습니다. (예: Debian 계열인 경우 `sudo apt install git-all`)
+ Linux는 패키지 관리도구로 쉽게 설치할 수 있습니다. (예: Debian 계열인 경우 `sudo apt install git-all`)
- **WSL2(Windows)**: 자세한 설치 방법은 [WSL 설치 공식 가이드](https://docs.microsoft.com/ko-kr/windows/wsl/install)를 참고해주세요.
-- **Docker**: Windows는 WSL2를 먼저 설치하고, [Docker Desktop for Windows](https://docs.docker.com/desktop/install/windows-install/)를 설치하면 됩니다.
-Mac은 [Docker Desktop for Mac](https://docs.docker.com/desktop/install/mac-install/)을 설치하면 됩니다.
-Linux는 자신의 배포판에 맞는 버전을 [공식 홈페이지](https://docs.docker.com/engine/install/)에서 찾아 설치하면 됩니다.
+- **Docker**: Windows는 WSL2를 먼저 설치하고, [Docker Desktop for Windows](https://docs.docker.com/desktop/install/windows-install/)를 설치하면 됩니다.
+ Mac은 [Docker Desktop for Mac](https://docs.docker.com/desktop/install/mac-install/)을 설치하면 됩니다.
+ Linux는 자신의 배포판에 맞는 버전을 [공식 홈페이지](https://docs.docker.com/engine/install/)에서 찾아 설치하면 됩니다.
### 2. VSCode 설치
[VSCode 홈페이지](https://code.visualstudio.com/)에서 VSCode 설치 파일을 다운로드 받고, 파일을 실행하여 설치합니다.
-![VSCode Download](vscode-download.png)
+![VSCode Download](assets/vscode-download.png)
### 3. Remote - Containers 확장 설치
왼쪽의 'Extensions' icon을 눌러(단축키 Ctrl+Shift+X, ⇧⌘X) "remote containers"를 검색창에 입력합니다.
'Remote - Containers'를 선택하고 'Install' 버튼을 눌러 설치합니다.
-![Remote - Containers](remote-containers.png)
+![Remote - Containers](assets/remote-containers.png)
### 4. Clone Repository
@@ -46,18 +46,18 @@ Windows file system에 clone 받는 것보다 WSL file system에 clone 받는
WSL에 clone 받는 방법은 아래 설명을 참고해주세요.
:::
-![Git Clone in VSCode](git-clone.png)
+![Git Clone in VSCode](assets/git-clone.png)
#### 4-1. WSL에 Clone 받기 (Windows만)
3번처럼 'Extensions' 탭을 열어 "remote wsl"을 검색창에 입력합니다.
'Remote - WSL'을 선택하고 'Install' 버튼을 눌러 설치합니다.
-![Remote - WSL](remote-wsl.png)
+![Remote - WSL](assets/remote-wsl.png)
왼쪽 아래의 `><` 모양 아이콘을 누르고 'New WSL Window' 옵션을 선택하여 WSL 환경에서 VSCode를 시작합니다.
-![New WSL Window](new-wsl-window.png)
+![New WSL Window](assets/new-wsl-window.png)
이후 4번과 같은 방식으로 WSL 내에 clone하면 됩니다.
@@ -69,7 +69,7 @@ Repository가 열리면 좌측 하단의 `><` 모양 아이콘을 누르고, "Re
이후 자동으로 Docker container가 생성되며 도구와 라이브러리, VSCode 확장들이 설치됩니다.
초기 구성에는 5~10분 정도 소요되지만, 다시 실행할 때에는 오래 걸리지 않습니다.
-![Reopen in Container](reopen-in-container.png)
+![Reopen in Container](assets/reopen-in-container.png)
### 6. Preview server 열기
@@ -84,7 +84,7 @@ pnpm dev
Story(component 문서)를 보고 싶으면, `pnpm story` 명령어를 입력해주세요.
-![Frontend Preview](frontend-preview.png)
+![Frontend Preview](assets/frontend-preview.png)
#### 6-2. Backend
@@ -93,7 +93,7 @@ cd backend
pnpm start:dev
```
-![Backend Preview](backend-preview.png)
+![Backend Preview](assets/backend-preview.png)
## GitPod
diff --git a/intro/index.md b/intro/index.md
index c5ae5bb..4894e5c 100644
--- a/intro/index.md
+++ b/intro/index.md
@@ -12,4 +12,4 @@
스꾸딩 팀 뿐만 아니라 누구나 수정하고 싶은 기능을 건의하고, 심지어 직접 구현할 수 있습니다.
자세한 내용은 [GitHub에서 확인해보세요.](https://github.com/skkuding) (이슈 & PR은 언제나 환영이에요!)
-![코드당](codedang.png)
+![코드당](assets/codedang.png)
diff --git a/project/deploy-pipeline.png b/project/assets/deploy-pipeline.png
similarity index 100%
rename from project/deploy-pipeline.png
rename to project/assets/deploy-pipeline.png
diff --git a/project/github-actions-runner.png b/project/assets/github-actions-runner.png
similarity index 100%
rename from project/github-actions-runner.png
rename to project/assets/github-actions-runner.png
diff --git a/project/github-projects.png b/project/assets/github-projects.png
similarity index 100%
rename from project/github-projects.png
rename to project/assets/github-projects.png
diff --git a/project/stage-server.md b/project/stage-server.md
index 61d68e4..a679959 100644
--- a/project/stage-server.md
+++ b/project/stage-server.md
@@ -2,7 +2,7 @@
스테이지 서버는 배포 전 테스트를 위한 서버로, [dev.codedang.com](https://dev.codedang.com/)에서 확인할 수 있습니다.
-![배포 과정](./deploy-pipeline.png)
+![배포 과정](assets/deploy-pipeline.png)
`main` 브랜치에 올라간 코드는 `deployment` environment에서 자동으로 스테이지 서버에 배포되며,
수동으로 production 배포를 trigger하면 `production` environment에서 진행합니다.
@@ -63,4 +63,4 @@ GitHub의 codedang repository에서 `Settings` > 좌측 사이드 바 `Actions`
이후 설명된 내용을 따라 Runner를 등록합니다.
-![GitHub Action Runner 등록](./github-actions-runner.png)
+![GitHub Action Runner 등록](assets/github-actions-runner.png)
diff --git a/project/tech-stack.md b/project/tech-stack.md
index 36281eb..8aa8fc9 100644
--- a/project/tech-stack.md
+++ b/project/tech-stack.md
@@ -2,12 +2,12 @@
Coding Platform은 Frontend, Backend, DevOps 세 팀으로 나누어 프로젝트를 진행합니다.
-| 분류 | Stacks |
-|:--------:|-------------|
-| 공통 | Visual Studio Code, GitHub, pnpm, Typescript, ESLint, Prettier, Lefthook |
-| Frontend | Vue.js, Vite, Tailwind CSS, Pinia, Histoire |
-| Backend | Node.js, Nest.js, Express, Mocha, Prisma, PostgreSQL, Redis |
-| DevOps | Docker, AWS |
+| 분류 | Stacks |
+| :------: | ------------------------------------------------------------------------ |
+| 공통 | Visual Studio Code, GitHub, pnpm, Typescript, ESLint, Prettier, Lefthook |
+| Frontend | Vue.js, Vite, Tailwind CSS, Pinia, Histoire |
+| Backend | Node.js, Nest.js, Express, Mocha, Prisma, PostgreSQL, Redis |
+| DevOps | Docker, AWS |
## 공통
@@ -17,7 +17,7 @@ Coding Platform은 Frontend, Backend, DevOps 세 팀으로 나누어 프로젝
GitHub Issues에 모든 task를 저장하여 스꾸딩 팀의 업무 단위로 활용하고 있고, pull request로 코드 리뷰를 거치며 의견을 교환합니다.
또한 GitHub Actions로 CI/CD 시스템을 구축하여 테스팅과 배포를 자동화하였습니다.
-![GitHub Projects](github-projects.png)
+![GitHub Projects](assets/github-projects.png)
### pnpm
@@ -64,13 +64,13 @@ Frontend framework로 [Vue 3](https://vuejs.org/)을 사용합니다.
React와 Svelte 등의 대안을 두고 Vue를 사용한 이유는 다음과 같습니다.
- **React**: React는 frontend library 중 가장 큰 커뮤니티를 가지고 있어 자료 검색이나 라이브러리 도입이 쉽다는 장점이 있습니다.
-또한 Next.js라는 훌륭한 SSR/SSG 용 framework도 있고, 채용 시장에서 수요도 제일 많습니다.
-하지만 난이도가 비교적 높아 진입장벽이 높고 Vue에 비해 문법이 직관적이지 못합니다.
-Vue 2에 대해서는 React가 Typescript 지원에서 크게 앞서있었지만, Vue 3에서는 Composition API로 여러 문제가 해결되며 React의 메리트가 줄어들었습니다.
+ 또한 Next.js라는 훌륭한 SSR/SSG 용 framework도 있고, 채용 시장에서 수요도 제일 많습니다.
+ 하지만 난이도가 비교적 높아 진입장벽이 높고 Vue에 비해 문법이 직관적이지 못합니다.
+ Vue 2에 대해서는 React가 Typescript 지원에서 크게 앞서있었지만, Vue 3에서는 Composition API로 여러 문제가 해결되며 React의 메리트가 줄어들었습니다.
- **Svelte**: Svelte는 신생 frontend library로 매우 직관적인 문법이 특징입니다.
-하지만 신생 라이브러리인 만큼 학습 자료나 라이브러리가 부족하여 개발 경험이 적은 팀원들에게 적합하지 않습니다.
-또한 [자체적으로 설계 문제](https://gist.github.com/rabelais88/19bfe8dfd29d901554389f0a8cc8947a)가 있어 추후 scalable한 운영이 어려울 수 있습니다.
+ 하지만 신생 라이브러리인 만큼 학습 자료나 라이브러리가 부족하여 개발 경험이 적은 팀원들에게 적합하지 않습니다.
+ 또한 [자체적으로 설계 문제](https://gist.github.com/rabelais88/19bfe8dfd29d901554389f0a8cc8947a)가 있어 추후 scalable한 운영이 어려울 수 있습니다.
기존에 스꾸딩 팀이 QingdaoU OJ 기반의 Online Judge를 구축할 때부터 Vue를 써온 것도 Vue를 택한 이유 중 하나입니다.
더 상세한 배경은 [issue #8](https://github.com/skkuding/next/issues/8#issuecomment-1065856244)에서 확인할 수 있습니다.
@@ -84,7 +84,7 @@ ES module을 적극적으로 활용하고 dependecies를 esbuild로 bundle하기
- [`vite-plugin-pages`](https://github.com/hannoeru/vite-plugin-pages): File system 기반의 routing을 자동으로 만들어줍니다.
- [`unplugin-icons`](https://github.com/antfu/unplugin-icons): Iconset들을 쉽게 불러올 수 있는 plugin입니다.
-[Icônes](https://icones.js.org/)에서 아이콘들을 확인할 수 있습니다.
+ [Icônes](https://icones.js.org/)에서 아이콘들을 확인할 수 있습니다.
### Tailwind CSS
@@ -149,7 +149,6 @@ Prisma는 각 model들을 type으로 생성해주기 때문에 Typescript로 쉽
[Redis](https://redis.io/)는 in-memory 저장소로, 이 프로젝트에서는 주로 caching과 message queue를 위해 쓰입니다. (추후 message queue는 Amazon SQS으로 대체할 수 있습니다)
-
## DevOps
::: warning Work in Progress 🚧