2021-01-02 07:49:12 +00:00
LQDOJ: Le Quy Don Online Judge
===
[![ ](https://github.com/DMOJ/online-judge/workflows/build/badge.svg )](https://lqdoj.edu.vn/)
[![Python ](https://img.shields.io/pypi/pyversions/tensorflow.svg?style=plastic )](https://python.org)
[![OS ](https://img.shields.io/badge/Ubuntu-16.04%20%7C%2018.04%20%7C%2020.04-brightgreen )](https://ubuntu.com/download)
2021-01-02 11:23:11 +00:00
[![License ](https://img.shields.io/badge/license-AGPL--3.0-blue )](https://www.gnu.org/licenses/agpl-3.0.en.html)
2021-01-02 07:49:12 +00:00
## Overview
Homepage: [https://lqdoj.edu.vn ](https://lqdoj.edu.vn )
2021-01-02 07:55:04 +00:00
Based on [DMOJ ](https://dmoj.ca/ ).
2021-01-02 07:49:12 +00:00
Supported languages:
- Assembly (x64)
- AWK
- C
2023-01-18 04:14:25 +00:00
- C++03 / C++11 / C++14 / C++17 / C++20
2021-01-02 07:49:12 +00:00
- Java 11
- Pascal
- Perl
- Python 2 / Python 3
2023-01-18 04:14:25 +00:00
- PyPy 2 / PyPy 3
2021-01-02 07:49:12 +00:00
2021-01-02 08:12:18 +00:00
Support plagiarism detection via [Stanford MOSS ](https://theory.stanford.edu/~aiken/moss/ ).
2021-01-02 07:49:12 +00:00
## Installation
2021-01-02 08:29:58 +00:00
Most of the setup are the same as DMOJ installations. You can view the installation guide of DMOJ here: https://docs.dmoj.ca/#/site/installation.
There is one minor change: Instead of `git clone https://github.com/DMOJ/site.git` , you clone this repo `git clone https://github.com/LQDJudge/online-judge.git` .
2021-01-11 02:47:36 +00:00
### Some frequent difficulties when installation:
2021-01-02 08:29:58 +00:00
1. Missing the `local_settings.py` . You need to copy the `local_settings.py` in order to pass the check.
2. Missing the problem folder in `local_settings.py` . You need to create a folder to contain all problem packages and configure in `local_settings.py` .
3. Missing static folder in `local_settings.py` . Similar to problem folder, make sure to configure `STATIC_FILES` inside `local_settings.py` .
4. Missing configure file for judges. Each judge must have a seperate configure file. To create this file, you can run `python dmojauto-conf` . Checkout all sample files here https://github.com/DMOJ/docs/blob/master/sample_files.
2022-12-28 11:05:14 +00:00
5. Missing timezone data for SQL. If you're using Ubuntu and you're following DMOJ's installation guide for the server, and you are getting the error mentioned in https://github.com/LQDJudge/online-judge/issues/45, then you can follow this method to fix:
2023-01-18 04:14:25 +00:00
```
2022-12-28 11:05:14 +00:00
mysql
-- You may have to do this if you haven't set root password for MySQL, replace mypass with your password
-- SET PASSWORD FOR 'root'@'localhost' = PASSWORD('mypass');
-- FLUSH PRIVILEGES;
exit
mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -D mysql -u root -p
mysql -u root -p -e "flush tables;" mysql
```
2023-01-08 00:44:11 +00:00
6. Missing the chat secret key, you must generate a Fernet key, and assign a variable in `local_settings.py` like this
```python
CHAT_SECRET_KEY = "81HqDtbqAywKSOumSxxxxxxxxxxxxxxxxx="
```
2022-12-28 11:05:14 +00:00
2021-01-02 08:12:18 +00:00
## Usage
2021-01-02 08:29:58 +00:00
Suppose you finished all the installation. Everytime you want to run a local server, follow these steps:
1. Activate virtualenv:
2021-01-02 07:49:12 +00:00
```bash
2020-01-21 18:00:50 +00:00
source dmojsite/bin/activate
2021-01-02 07:49:12 +00:00
```
2021-01-02 08:29:58 +00:00
2. Run server:
2021-01-02 07:49:12 +00:00
```bash
2022-12-21 04:53:32 +00:00
python3 manage.py runserver 0.0.0.0:8000
2021-01-02 07:49:12 +00:00
```
2020-01-21 18:00:50 +00:00
2021-01-02 08:29:58 +00:00
3. Create a bridge (this is opened in a different terminal with the second step if you are using the same machine)
2021-01-02 07:49:12 +00:00
```bash
2022-12-21 04:53:32 +00:00
python3 manage.py runbridged
2021-01-02 07:49:12 +00:00
```
2020-01-21 18:00:50 +00:00
2021-01-02 08:29:58 +00:00
4. Create a judge (another terminal)
2021-01-02 07:49:12 +00:00
```bash
2021-01-02 08:29:58 +00:00
dmoj 0.0.0.0 -p 9999 -c < path to yml configure file >
2021-01-02 07:49:12 +00:00
```
2021-01-02 08:29:58 +00:00
Here we suppose you use the default port 9999 for bridge in `settings.py` . You can create multiple judges, each should be in a seperate terminal.
2021-01-02 08:34:51 +00:00
**Optional**
5. Run celery worker (This is server's queue. It may be necessary in some functions)
```bash
celery -A dmoj_celery worker
```
6. Run a live event server (So everything is updated lively like in the production)
```bash
node websocket/daemon.js
```
2021-01-02 08:29:58 +00:00
## Deploy
Most of the steps are similar to Django tutorials. Here are two usual steps:
2020-01-21 18:00:50 +00:00
2021-01-02 08:29:58 +00:00
1. Update vietnamese translation:
2022-12-21 04:53:32 +00:00
- If you add any new phrases in the code, ```python3 manage.py makemessages```
2021-01-02 07:49:12 +00:00
- go to `locale/vi`
- modify `.po` file
2022-12-21 04:53:32 +00:00
- ```python3 manage.py compilemessages```
- ```python3 manage.py compilejsi18n```
2020-03-16 02:28:46 +00:00
2021-01-02 08:29:58 +00:00
2. Update styles (using SASS)
- Change .css/.scss files in `resources` folder
2022-12-21 04:53:32 +00:00
- ```./make_style.sh && python3 manage.py collectstatic```
2023-01-18 04:14:25 +00:00
- Sometimes you need to press `Ctrl + F5` to see the new user interface in browser.
2021-01-02 08:29:58 +00:00
2021-01-02 07:49:12 +00:00
## Screenshots
### Leaderboard
Leaderboard with information about contest rating, performance points and real name of all users.
2022-12-28 14:01:20 +00:00
![](https://raw.githubusercontent.com/emladevops/LQDOJ-image/main/brave_SK67WA26FA.png#gh-light-mode-only)
![](https://raw.githubusercontent.com/emladevops/LQDOJ-image/main/brave_cmqqCnwaFc.png#gh-dark-mode-only)
2021-01-02 07:49:12 +00:00
### Admin dashboard
Admin dashboard helps you easily managing problems, users, contests and blog posts.
![](https://i.imgur.com/iccr3mh.png)
### Statement editor
You can write the problems' statement in Markdown with LaTeX figures and formulas supported.
![](https://i.imgur.com/CQVC754.png)
### Chat
Users can communicate with each other and can see who's online.
2022-12-28 14:01:20 +00:00
![](https://raw.githubusercontent.com/emladevops/LQDOJ-image/main/brave_kPsC5bJluc.png#gh-light-mode-only)
![](https://raw.githubusercontent.com/emladevops/LQDOJ-image/main/brave_AtrEzXzEAx.png#gh-dark-mode-only)