-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'develop' into refactor/type-hint
- Loading branch information
Showing
9 changed files
with
154 additions
and
224 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,218 +1,54 @@ | ||
# SPARCS NewAra API | ||
# Ara API | ||
|
||
<p align="center"> | ||
<a href="https://newara.sparcs.org"> | ||
<img src="res/logo.svg" alt="Logo" height="150"> | ||
</a> | ||
</p> | ||
<p align="center"> | ||
<em>Restful API for NewAra, KAIST's official community service</em> | ||
</p> | ||
<p align="center"> | ||
<img | ||
src="https://img.shields.io/github/v/release/sparcs-kaist/new-ara-api?display_name=tag&color=blue" | ||
alt="Release" | ||
> | ||
<img | ||
src="https://img.shields.io/github/license/sparcs-kaist/new-ara-api?color=black" | ||
alt="License" | ||
> | ||
<img | ||
src="https://github.com/sparcs-kaist/new-ara-api/actions/workflows/github-actions.yml/badge.svg" | ||
alt="Test" | ||
> | ||
</p> | ||
Restful API for Ara, KAIST's official community service | ||
|
||
## Management Information | ||
|
||
- Issue tracking: Notion | ||
- Credentials: S3 sparcs-credentials | ||
- Communication: Slack | ||
- general: #new-ara | ||
- backend: #new-ara-backend | ||
- fontend: #new-ara-frontend | ||
- github commits: #new-ara-noti | ||
- sentry alerts: #new-ara-sentry | ||
- notion changes: #new-ara-notion | ||
- with OB: #ara | ||
- Contact: <[email protected]> | ||
![GitHub Pipenv locked Python version (master)][badge/python-version] | ||
[![Code style: black][badge/black]][repo/black] | ||
[![Imports: isort][badge/isort]][isort] | ||
[![pre-commit][badge/pre-commit]][repo/pre-commit] | ||
[![Conventional Commits][badge/conventional-commits]][conventional-commits] | ||
|
||
## Project Setup | ||
|
||
### Create & Activate Virtual Environment | ||
Use pipenv to install packages. (e.g., `pipenv install <package>`) | ||
|
||
```bash | ||
python3 -m pip install pipenv # It must be Python 3.11 | ||
pipenv shell | ||
``` | ||
pipenv --python 3.11 # Use python 3.11 | ||
pipenv shell # Activate virtual environment | ||
pipenv install --dev # Install packages (`--dev` flag for development) | ||
|
||
### Install Requirements | ||
|
||
```bash | ||
pipenv install --dev # `--dev` flag for development | ||
# Run `pre-commit` automatically on `git commit` | ||
pre-commit install | ||
pre-commit install --hook-type commit-msg | ||
``` | ||
|
||
For macOS, you may need to install `openssl` & `mysqlclient` and set | ||
`LDFLAGS=-L/usr/local/opt/openssl/lib` before installing requirements. Only | ||
tested for macOS Mojave. See [link](https://stackoverflow.com/questions/50940302/installing-mysql-python-causes-command-clang-failed-with-exit-status-1-on-mac). | ||
|
||
### Fill Environment Configuration | ||
|
||
Refer to [.env.example file](https://github.com/sparcs-kaist/new-ara-api/blob/master/.env.example) | ||
and write your own `.env` file with required informations filled-in. For SPARCS | ||
SSO, create a test service or ask SYSOP to deploy production server. | ||
|
||
For the test service in [SPARCS SSO](https://sparcssso.kaist.ac.kr/) for local | ||
settings, fill in as below. | ||
|
||
- **Main URL**: (can be anything) | ||
- **Login Callback URL**: <http://127.0.0.1:9000/api/users/sso_login_callback/> | ||
- **Unregister URL**: <http://127.0.0.1:9000/api/users/sso_unregister/> | ||
|
||
After this, you should make the information in the `.env` file as environment | ||
variables for local run. (In development or porduction server, we do not use | ||
`.env` file. Rather, we use environment variables in `docker-compose.yml` file.) | ||
|
||
To make the make the information in the `.env` file as environment variables for | ||
local run, you can export each manually, or you can use the below command. Check | ||
the `Makefile`'s [env command](https://github.com/sparcs-kaist/new-ara-api/blob/master/Makefile#L32) | ||
and revise it. The command is written assuming you are using `~/.bashrc`. You | ||
might want to revise it to `~/.bash_profile` or `~/.zshrc` according to your | ||
settings. | ||
|
||
```bash | ||
make env | ||
``` | ||
|
||
### Useful Commands | ||
|
||
Most useful commands are already written in the [Makefile](https://github.com/sparcs-kaist/new-ara-api/blob/master/Makefile). | ||
Refer to the `Makefile` and try to understand and use them. | ||
|
||
### Create and Migrate Database | ||
|
||
```bash | ||
make init | ||
``` | ||
|
||
### Collect static files | ||
|
||
```bash | ||
python manage.py collectstatic | ||
``` | ||
|
||
`collectstatic` command collects all static files required to run installed apps | ||
to selected storage - for this project, static S3 bucket. You should open public | ||
access for the static bucket to get appropriate response. | ||
|
||
### Internationalization (i18n) | ||
|
||
[xgettext](https://man7.org/linux/man-pages/man1/xgettext.1.html) is required in | ||
order to generate translation files. Detailed background on this can be found on | ||
[Django's documentations](https://docs.djangoproject.com/en/3.1/topics/i18n/translation/). | ||
To generate translation files, run: | ||
|
||
```bash | ||
make i18n_generate | ||
``` | ||
|
||
Translation files are generated under `ara/locale/(Locale name)/LC_MESSAGES`. | ||
After writing translations, run the following command to apply the translations. | ||
|
||
```bash | ||
make i18n_compile | ||
``` | ||
|
||
### Create log directory | ||
|
||
```bash | ||
sudo mkdir -p /var/log/newara | ||
sudo chown $(whoami) /var/log/newara | ||
``` | ||
|
||
### Run lightweight server for development | ||
## How to Run | ||
|
||
```bash | ||
pipenv shell | ||
make run | ||
``` | ||
|
||
`0` is abbreviation for `0.0.0.0` which refers to 'listening to every incoming hosts'. | ||
**Do not deploy with runserver command - use WSGI. This command is only for development.** | ||
|
||
--- | ||
|
||
## Deployment with Docker | ||
|
||
### docker-compose.yml | ||
|
||
`docker-compose.yml` file is managed in S3 `sparcs-newara` bucket `docker-compose` | ||
directory. For simple local deployment, refer to [docker-compose.example.yml file](https://github.com/sparcs-kaist/new-ara-api/blob/master/docker-compose.example.yml) | ||
and fill in the information needed. | ||
|
||
For [development server](https://newara.dev.sparcs.org/), two docker containsers | ||
are up with the docker-compose file. Using AWS RDS for mysql, elastiCache for redis. | ||
|
||
- api container (used gunicorn for serving. celery-beat also here.) | ||
- celery-worker container | ||
|
||
### docker image | ||
|
||
For managing docker images, we are using AWS ECR, `newara` repository. | ||
|
||
- Using tag `newara:dev` for development server. | ||
|
||
### other docker related files | ||
|
||
- **Dockerfile**: We use virtual environment also inside the docker container. | ||
- **.docker/run.sh**: api container's entrypoint. | ||
- **.docker/run-celery.sh**: celery worker container's entrypoint. | ||
- **.docker/supervisor-app.conf** | ||
- **.docker/supervisor-celery-worker.conf** | ||
|
||
## Project Stack | ||
|
||
### Interpreter | ||
|
||
- `Python 3.11` | ||
- `Pipenv` is used as package manager | ||
- When adding libraries to the virtual environment, you should not use `pip`. | ||
Rather, use `pipenv` command. Refer to [this link](https://pipenv.pypa.io/en/latest/commands/) | ||
for pipenv commands. | ||
|
||
### Framework | ||
|
||
- `Django 4.2` | ||
- `djangorestframework 3.14` | ||
|
||
### Database | ||
|
||
- MySQL 8.0 | ||
- `mysqlclient 2.2` | ||
|
||
Works with MySQL for Linux & macOS, not tested in Windows. Timezone is | ||
automatically adjusted. It is strongly recommended to set default charset of | ||
database or MySQL server to `utf8mb4`. | ||
|
||
### Storage | ||
|
||
- AWS S3 | ||
- `django-s3-storage 0.14` | ||
|
||
Two buckets are used - one for storing static files, one for media files that | ||
users upload. Go to django-s3-storage documentation for required permissions. | ||
|
||
### Authentication | ||
|
||
- SPARCS SSO v2 API | ||
- `djangorestframework SessionAuthentication` | ||
|
||
### API Documentation | ||
## URLs | ||
|
||
- `drf-spectacular 0.26` | ||
- Base URL: `/api` | ||
- Admin page: `/api/admin/` | ||
- API documentations: | ||
- `/api/schema/swagger/` | ||
- `/api/schema/redoc/` | ||
|
||
--- | ||
## How to Contribute | ||
|
||
## Contributors | ||
1. Follow [Conventional Commits][conventional-commits] for writing commit messages. | ||
2. Use type hints strictly. (Check [PEP 484][pep-484].) | ||
|
||
See [contributors](https://github.com/sparcs-kaist/new-ara-api/graphs/contributors). | ||
[badge/python-version]: https://img.shields.io/github/pipenv/locked/python-version/sparcs-kaist/new-ara-api/master | ||
[badge/black]: https://img.shields.io/badge/code%20style-black-000000 | ||
[badge/isort]: https://img.shields.io/badge/%20imports-isort-%231674b1?labelColor=ef8336 | ||
[badge/pre-commit]: https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit | ||
[badge/conventional-commits]: https://img.shields.io/badge/Conventional%20Commits-1.0.0-%23FE5196?logo=conventionalcommits&logoColor=white | ||
[isort]: https://pycqa.github.io/isort | ||
[conventional-commits]: https://conventionalcommits.org | ||
[pep-484]: https://peps.python.org/pep-0484/ | ||
[repo/black]: https://github.com/psf/black | ||
[repo/pre-commit]: https://github.com/pre-commit/pre-commit |
83 changes: 83 additions & 0 deletions
83
apps/core/migrations/0056_alter_article_comment_count_alter_article_hit_count_and_more.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
# Generated by Django 4.2.3 on 2023-07-31 12:00 | ||
|
||
import apps.core.models.board | ||
from django.db import migrations, models | ||
|
||
|
||
class Migration(migrations.Migration): | ||
dependencies = [ | ||
("core", "0055_remove_board_group_id_board_group"), | ||
] | ||
|
||
operations = [ | ||
migrations.AlterField( | ||
model_name="article", | ||
name="comment_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="댓글 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="hit_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="조회수"), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="migrated_hit_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="이전된 조회수"), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="migrated_negative_vote_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="이전된 싫어요 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="migrated_positive_vote_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="이전된 좋아요 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="name_type", | ||
field=models.PositiveSmallIntegerField( | ||
default=apps.core.models.board.NameType["REGULAR"], | ||
verbose_name="익명 혹은 실명 여부", | ||
), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="negative_vote_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="싫어요 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="positive_vote_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="좋아요 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="article", | ||
name="report_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="신고 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="board", | ||
name="top_threshold", | ||
field=models.PositiveSmallIntegerField( | ||
default=10, verbose_name="인기글 달성 기준 좋아요 개수" | ||
), | ||
), | ||
migrations.AlterField( | ||
model_name="comment", | ||
name="negative_vote_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="싫어요 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="comment", | ||
name="positive_vote_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="좋아요 수"), | ||
), | ||
migrations.AlterField( | ||
model_name="comment", | ||
name="report_count", | ||
field=models.PositiveIntegerField(default=0, verbose_name="신고 수"), | ||
), | ||
] |
Oops, something went wrong.