Skip to content

Latest commit

 

History

History
459 lines (383 loc) · 21.5 KB

README.md

File metadata and controls

459 lines (383 loc) · 21.5 KB

ALGO싶다 - ALgorithm Q&A Community

image

알고리즘 문제 풀이 꿀팁 공유 및 질문을 위한 커뮤니티
개발기간: 2023.04 ~ 2023.06

배포 주소

https://algoqna.ddns.net/

웹개발팀 소개

김솔민 장윤희 이진희 전오승
@so1omon @janguni @bebusl @jeonoseung
Backend 개발 Backend 개발 Frontend 개발 Frontend 개발

프로젝트 소개

알고리즘 분야에서의 학습과 문제 해결을 돕기 위해 만들어진 간편한 커뮤니티 사이트를 제작했습니다.

저희의 목표는 프로그래머스, 백준 저지 등 다양한 코딩 테스트 문제를 풀고 이에 대한 질의 응답과 풀이를 공유하는데 있습니다. 우리는 알고리즘 문제 풀이와 관련된 모든 분야에서 활동하는 개발자들을 위해 특정 온라인 저지 사이트에 관계 없이 유저들의 질문과 고민을 나누고 풀이를 공유할 수 있는 플랫폼을 제공합니다.

이 커뮤니티에서는 그래프, 탐색, 정렬, 다이나믹 프로그래밍 등 다양한 알고리즘 분류별로 질문과 꿀팁을 누구나 공유할 수 있습니다. 우리의 목표는 상호간에 지식을 나누고 향상시킴으로써 개발자들의 알고리즘 역량을 향상시키는 것입니다.

위와 같은 커뮤니티 서비스를 구현하기 위해 유저들의 의견 공유를 원할히 수행하기 위한 기능 (알람, 댓글 하이라이팅 등)을 제외한 부가적인 기능들 없이 컴팩트한 서비스만을 제공하고 있습니다.

시작 가이드

Requirements

다음 요구사항은 M1 Mac을 기준으로 작성하였습니다. Docker 기반으로 작동하기 때문에 운영체제에 맞게 아래 Requirements를 충족시키시기 바랍니다.

Backend

  1. 레포지토리 클론
$ git clone https://github.com/algorithmQNA/algorithmQNA_backend.git
  1. application.yml 생성
##### 공통 properties를 포함한 local 환경과 production 환경을 분리하여 작성하였습니다. #####
##### 또한 properties 정보를 외부에 노출하지 않기 위해 Git action 동작 시 {$secret.PROPERTIES}에 복사하여 사용하였습니다. #####
##### logging 관련 설정값은 적절히 바꿔서 사용하시기 바랍니다. #####
spring:
  profiles:
    active: local
  security:
    oauth2:
      client:
        registration:
          google:
            client-id: {google oauth client id}
            client-secret: {google oauth client secret}
            redirect-uri: {google callback uri}
            authorization-grant-type: authorization_code
            scope:
              - profile
              - email
            client-name: Google
            client-authentication-method: basic

        provider:
          google:
            authorization-uri: https://accounts.google.com/o/oauth2/v2/auth?prompt=consent&access_type=offline
google:
  uri: "https://accounts.google.com/o/oauth2/v2/auth"

cookie:
  domain: {Your domain}

jwt:
  header: Authorization
  accessSecret: {accessSecret}
  refreshSecret: {refreshSecret}

# local properties
---
spring.config.activate.on-profile: local
spring:
  datasource:
    url: {local datasource url}
    username: {mysql username}
    password: {mysql password}
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    hibernate:
      ddl-auto: create
    properties:
      hibernate:
        default_batch_fetch_size: 1000
        show_sql: true
        format_sql: true
  data:
    redis:
      host: {local redis host}
      port: {local redis port}
      password: {local redis port}

logging:
  level:
    org.hibernate.SQL: debug
    org.hibernate.type: trace
    root: info

cloud:
  aws:
    credentials:
      accessKey: {IAM Access key}
      secretKey: {IAM Secret key}
    s3:
      bucket: {s3 bucket name}
    region:
      static: {s3 bucket region}
    stack:
      auto: false

# production properties
---
spring.config.activate.on-profile: prod
spring:
  datasource:
    url: {local datasource url}
    username: {mysql username}
    password: {mysql password}
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    hibernate:
      ddl-auto: none
    properties:
      hibernate:
        default_batch_fetch_size: 1000
        show_sql: false
        format_sql: false
  data:
    redis:
      host: {local redis host}
      port: {local redis port}
      password: {local redis port}

logging:
  level:
    root: info

cloud:
  aws:
    credentials:
      accessKey: {IAM Access key}
      secretKey: {IAM Secret key}
    s3:
      bucket: {s3 bucket name}
    region:
      static: {s3 bucket region}
    stack:
      auto: false

decorator:
  datasource:
    p6spy:
      enable-logging: false

  1. docker-compose.yml 파일 수정 : 도커허브 레포지토리에 있는 이미지 대신 Dockerfile을 통한 이미지 빌드로 전환하기
1  version: "3"
2
3  services:
4    myapp:
5        # image: janguni/algorithm-project-docker-repo:1.0)
6        build:
7            context: .
8            dockerfile: Dockerfile
  1. docker-compose 파일을 통한 이미지 필드
$ docker-compose build
  1. 빌드한 이미지 파일로부터 컨테이너 실행 (백그라운드 실행 시 -d 옵션 추가)
$ docker-compose up

Frontend

1. 레포지토리 클론

$ git clone https://github.com/algorithmQNA/algorithmQNA_frontend.git
$ cd algorithmQNA_frontend.git

2. 패키지 설치

$ npm i

3. 개발서버 실행
환경 변수를 작성해서 최상단 디렉토리에 넣어주세요

3.1. 목서버와 연동하여 실행

.env.development.local 작성
REACT_APP_API_BASE_URL={API_PREFIX}
REACT_APP_OAUTH_REDIRECT_URI={YOUR_OAUTH_REDIRECTURI}

npm run dev

3.2. 실제서버와 연동하여 실행

.env.production 작성
REACT_APP_API_BASE_URL={API_PREFIX}
REACT_APP_OAUTH_REDIRECT_URI={YOUR_OAUTH_REDIRECTURI}

npm start

Stacks 🐈

Environment

Visual Studio Code Git Github Docker Ubuntu msw

Config

npm gradle

Development

Spring SpringSecurity Mysql Typescript React recoil React query tailwind css Amazon EC2 S3 intellijidea nginx

Communication

Slack Notion


화면 구성 📺

대시보드 게시판
로그인대시보드 게시판필터링
전체게시판의 글을 간략하게 볼 수 있는 대시보드입니다. 로그인 후 접근 가능합니다. 게시판에는 Q&A게시판, 꿀팁게시판이 있습니다. 여러가지 필터링과 정렬 기능을 사용할 수 있습니다.
게시글작성 게시글보기
글작성 글보기및채택
게시글을 작성할 때 이미지, 코드블록을 이용해 구체적인 질문 사항이나 꿀팁을 작성할 수 있습니다. 또한 키워드도 등록이 가능합니다. 이용자들이 작성한 글을 읽고 댓글을 달거나 신고, 채택, 좋아요 표시 등의 기능을 수행할 수 있습니다.
하이라이팅 --
하이라이팅 .
알람을 받은 댓글이나 채택된 댓글로 바로 이동하고 하이라이팅해줍니다 .
마이페이지 관리자페이지(신고)
마이페이지 신고합
마이페이지에서 내 정보 수정, 내 뱃지, 내 활동 내역, 받은 알람등을 확인하고 관리가능합니다. 관리자 페이지에서 글/댓글에 대한 신고를 관리, 공지사항을 관리할 수 있습니다.

주요 기능 📦

⭐️ 소셜 로그인을 통한 회원가입

  • Google Oauth를 통한 유저 로그인, 간편 회원가입 제공

⭐️ 알고리즘 카테고리별 Q&A, TIP 게시판 제공

  • 게시글 작성 시 이미지 업로드 등 다양한 형태의 게시글을 작성할 수 있도록 하는 Editor 제공
  • 제목, 글쓴이, 키워드로 검색과 댓글 유무, 채택 유무를 통하여 게시글을 필터링하는 기능 제공

⭐️ 신고된 게시글, 공지사항 등을 관리 가능한 관리자 페이지 기능

⭐️ 다양한 상황에서 알람 확인 가능

  • 내가 쓴 게시글이나 댓글을 좋아요/싫어요 시 알람
  • 다른 사람이 내가 쓴 게시글에 댓글을 작성 시, 내가 쓴 댓글에 대댓글을 작성 시 알람
  • 관리자가 내 작성글을 삭제 시
  • 댓글 또는 게시글 알람의 경우 해당 게시글 페이지로 이동 가능한 링크를 제공
  • 댓글 알람의 경우 해당 게시글 페이지에 댓글이 위치한 페이지로 동적 이동 가능한 하이라이팅 기능 제공

제작 일정(프론트엔드)

246996272-f83647fe-b8a4-4ddb-a5cd-7f919143111c.png (1590×777)

문서

피그마

피그마

API Specification

API 명세 노션 페이지

디렉토리 구조

.
├── README.md
├── package-lock.json
├── package.json
├── public/
│   ├── ALGOQNA_LOGO.png
│   ├── favicon-16x16.png
│   ├── favicon-32x32.png
│   ├── favicon-96x96.png
│   ├── favicon.ico
│   ├── index.html
│   ├── manifest.json
│   ├── mockServiceWorker.js
│   ├── question.png
│   ├── robots.txt
│   └── svg/
│       ├── question.png
│       ├── spinner.png
│       ├── spinner.svg
│       └── tip.png
├── src/
│   ├── App.css
│   ├── App.tsx
│   ├── DefaultRouter.tsx
│   ├── apis/
│   │   ├── adminApi.ts
│   │   ├── alarmApi.ts
│   │   ├── authApi.ts
│   │   ├── commentApi.ts
│   │   ├── instance.ts
│   │   └── postApi.ts
│   ├── assets/
│   │   └── images/
│   ├── components/
│   │   ├── Badge/
│   │   ├── Board/
│   │   ├── Button/
│   │   ├── Comment/
│   │   ├── DashBoard/
│   │   ├── DropDown/
│   │   ├── ErrorBoundary.jsx
│   │   ├── Footer/
│   │   ├── Header/
│   │   ├── Icon/
│   │   ├── Input/
│   │   ├── Loading/
│   │   ├── Login/
│   │   ├── MessageBox/
│   │   ├── Modal/
│   │   ├── MyPage/
│   │   ├── Notice/
│   │   ├── PageTitle/
│   │   ├── Pagination/
│   │   ├── Paper/
│   │   ├── PrivateRoute.tsx
│   │   ├── Report/
│   │   ├── RoundedImage/
│   │   ├── TabNav/
│   │   ├── TableRow/
│   │   ├── Tooltip/
│   │   ├── UserProfile/
│   │   ├── isLoading/
│   │   └── layouts/
│   ├── constants/
│   │   ├── PostCategory.ts
│   │   ├── PostType.ts
│   │   ├── Report.ts
│   │   ├── Role.ts
│   │   └── Sort.ts
│   ├── hooks/
│   │   ├── useCheckAuthority.ts
│   │   ├── useGetMember.ts
│   │   ├── useGetParams.tsx
│   │   ├── useLazyQuery.ts
│   │   └── useModal.ts
│   ├── index.tsx
│   ├── mocks/
│   │   ├── browser.ts
│   │   ├── handlers.ts
│   │   ├── mockAdmin.ts
│   │   ├── mockAuth.ts
│   │   ├── mockComments.ts
│   │   ├── mockPost.ts
│   │   ├── os/
│   │   └── utils/
│   ├── pages/
│   │   ├── Admin/
│   │   ├── Board/
│   │   ├── DashBoard/
│   │   ├── Landing/
│   │   ├── LoginRequest/
│   │   ├── Logout/
│   │   ├── MyPage/
│   │   └── Post/
│   ├── react-app-env.d.ts
│   ├── setupProxy.js
│   ├── storage/
│   │   ├── Dash/
│   │   ├── Highlight/
│   │   ├── Login/
│   │   ├── PageTitle/
│   │   ├── Post/
│   │   └── PostWrite/
│   ├── types/
│   │   ├── Alarm.ts
│   │   ├── Error.ts
│   │   ├── Login.ts
│   │   ├── Post/
│   │   ├── apis/
│   │   ├── category.ts
│   │   ├── comment.ts
│   │   ├── member.ts
│   │   ├── pagination.ts
│   │   ├── post.ts
│   │   ├── report.ts
│   │   ├── typeUtils.ts
│   │   └── user.ts
│   └── utils/
│       ├── TextProcessing.ts
│       └── random.ts
├── tailwind.config.js
├── tree
└── tsconfig.json