Skip to content
/ lyrio Public
forked from lyrio-dev/lyrio

The API server of next-generation SYZOJ

License

Notifications You must be signed in to change notification settings

ZhiliOJ/lyrio

 
 

Repository files navigation

Lyrio

Build Status Dependencies Commitizen friendly code style: prettier License

The backend service of Lyrio.

Deploying & Development

Clone this git repo and install dependencies:

$ git clone [email protected]:lyrio-dev/lyrio.git
$ cd lyrio
$ yarn

Create a config.yaml file based on config-example.yaml:

$ cp config-example.yaml config.yaml

Database

Create a database and user in MySQL or MariaDB:

CREATE DATABASE `lyrio` DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
GRANT ALL PRIVILEGES ON `lyrio`.* TO "lyrio"@"localhost" IDENTIFIED BY "lyrio-password";

Then fill the database connection information in the configuration file.

Redis

Install Redis (>= 5) and change the redis url in the config (if your redis isn't listening on the default address and port).

MinIO

Install MinIO file storage server and run with a data directory (if you're not running locally, please specify the environmental variables MINIO_ACCESS_KEY and MINIO_SECRET_KEY for security):

$ wget https://dl.min.io/server/minio/release/linux-amd64/minio
$ chmod +x minio
$ MINIO_ACCESS_KEY=AKAK MINIO_SECRET_KEY=SKSK ./minio server /mnt/data # /mnt/data is the data directory

After starting MinIO server, create a bucket with MinIO's management tool mc:

$ wget https://dl.min.io/client/mc/release/linux-amd64/mc
$ chmod +x mc
$ ./mc alias set minio http://127.0.0.1:9000 "AKAK" "SKSK"
$ ./mc mb -p minio/lyrio-files

Then fill the MinIO server information in the config file. The endpoint property is used by the server. If you want the user or judge to connect to MinIO with other host as the endpoint, set endpointForUser or endpointForJudge to a URL path. Make sure you configure Nginx properly, especially when you use a sub-directory.

Run

By default this app listens on 127.0.0.1:2002. You can change this in the configuration file. You can use nginx as reversed proxy to access the app with a domain name like lyrio.test.

$ LYRIO_CONFIG_FILE=./config.yaml yarn start

Add LYRIO_LOG_SQL to enable TypeORM logging:

$ LYRIO_LOG_SQL=1 LYRIO_CONFIG_FILE=./config.yaml yarn start

Refer to lyrio-ui for the guide of the front-end app server.
Refer to lyrio-judge for the guide of the judge client.

About

The API server of next-generation SYZOJ

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 98.1%
  • Lua 1.5%
  • EJS 0.4%