Skip to content

Install

huoyijie edited this page Sep 4, 2023 · 2 revisions

Bankend

Get started [Ubuntu 22.04]

  • Prerequisites
  1. Node v18.15.0+
  2. npm 9.5.0+
  3. Mysql server
  4. git
  • Clone the repo
$ cd ~/vswork
$ git clone [email protected]:huoyijie/infinity.git
  • Install deps
$ cd infinity/backend
$ npm i
  • Add .env file
$ cat <<EOF > .env
PORT=5000
DATABASE_URL="mysql://your_mysql_username:your_mysql_password@localhost:3306/infinity"
EOF

Don't forget to change your_mysql_username and your_mysql_password.

  • Create database infinity
$ mysql -u your_mysql_username -p
# Input your_mysql_password
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4986
Server version: 8.0.32-0ubuntu0.22.04.2 (Ubuntu)

Copyright (c) 2000, 2023, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

# create database `infinity`
mysql> CREATE DATABASE `infinity` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci */ /*!80016 DEFAULT ENCRYPTION='N' */;
Query OK, 1 row affected (0.53 sec)

# exit
mysql> exit
  • Creating the database schemas
$ npx prisma db push
Environment variables loaded from .env
Prisma schema loaded from prisma/schema.prisma
Datasource "db": MySQL database "infinity" at "localhost:3306"

🚀  Your database is now in sync with your Prisma schema. Done in 545ms

✔ Generated Prisma Client (5.1.1 | library) to ./node_modules/@prisma/client in 72ms

Query the database:

mysql> use infinity
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+--------------------+
| Tables_in_infinity |
+--------------------+
| Drawing            |
+--------------------+
1 row in set (0.00 sec)
  • Run server
$ npm start

All Environment variables

  • HOST (default: localhost)

Backend server listen addr.

  • PORT (default: 5000)

Backend server listen port.

  • BASE_PATH (default: /)

You shoud deploy backend server behind nginx with ssl/htt2 enabled.

Such as wss://huoyijie.cn:1024/infinity/socket.io, bashPath is /infinity.

  • ALLOW_ORIGIN (default: *)

You should config like this ALLOW_ORIGIN=https://huoyijie.github.io for security

Frontend

Get started (run locally)

  • Prerequisites
  1. Node 18.15.0+
  2. npm 9.5.0+
  3. git
$ cd ~/vswork
$ git clone [email protected]:huoyijie/infinity.git
  • Install deps
$ cd infinity/frontend
$ npm i
  • Add .env file
$ cat <<EOF > .env
NEXT_PUBLIC_SOCKETIO_URL=ws://your_bankend_server_domain_or_ip:your_bankend_server_port
EOF

Don't forget to change your_bankend_server_domain_or_ip (localhost) and your_bankend_server_port (5000).

If you run the bankend server behind reverse server (such as Nginx) and use tls, change ws to wss.

  • Run server
$ npm run dev

Deploy with Github Actions (Github pages)

See .github/workflows/nextjs.yml

All Environment variables

  • NEXT_PUBLIC_SOCKETIO_URL=ws://localhost:5000

If your backend server is deployed behind nginx with ssl/http2 enabled, you shoud forward the websocket upgrade request from nginx to backend server, and you shoud config NEXT_PUBLIC_SOCKETIO_URL=wss://your_domain.

  • NEXT_PUBLIC_BASE_PATH=/

If your backend server configed with BASH_PATH=/infinity, then you shoud config NEXT_PUBLIC_BASE_PATH=/infinity too.