0
0
Fork 0
Phantom-Ink-Online/server/README.md

59 lines
No EOL
2.8 KiB
Markdown

# Setup:
1. `cd` into this `server` directory.
2. Run `pnpm install` to install all of the required dependencies.
3. Create a copy of the `template.toml` file, and name it `server.toml`.
4. Edit the `server.toml` file to adjust the server and game settings.
5. Run `tsc` to compile the TypeScript into Javascript. This should create a
`dist` directory.
## Using systemd to manage the server:
This app comes with a `phantom-ink.service` file which is already set up to
manage the server, it just requires a little bit of additional setup. If you
change any of the symlinking in the steps below, it is your responsibility to
figure it out, I will not guarantee support for people who attempt to modify
the service file beyond the steps below.
6. Create a symlink named `server` in the server root (`/`) pointing to the
server folder in the Phantom Ink git repository.
(Ex: `sudo ln -s ~/Phantom-Ink-Online/server /server`)
7. Create a symlink named `phantom-ink.service` in `/etc/systemd/system`
pointing to the service file in the `server` folder of the Phantom Ink Online
repository. (Ex: `sudo ln -s /server/phantom-ink.service /etc/systemd/system/phantom-ink.service`)
8. Run `whereis node` and copy the absolute file path of the output
9. Edit the `phantom-ink.service` file to replace change the
`ExecStart=node dist/main.js` to replace `node` with the file path you copied
from the previous step
10. Reload the systemd daemon with `sudo systemd daemon-reload` to make the
changes to the service file take effect.
11. Start the websocket server with `sudo systemctl start phantom-ink`
12. Make sure the server is started by running `systemctl status phantom-ink`
* To start the server, run `sudo sustemctl start phantom-ink`
* To restart the server, run `sudo systemctl restart phantom-ink`
* To stop the server, run `sudo systemctl stop phantom-ink`
* To access the server logs, run `sudo journalctl -u phantom-ink`
## Using a detached terminal:
If you would prefer that the server does not automatically restart and you can
more easily output log output to a file, you can run the server by following
the below steps:
6. Make sure you know how to invoke a single command with your preferred method
of detaching terminals.
7. Have the detached terminal's working directory be in the `server` folder of
this repository.
8. Run `node dist/main.js` for logging directly to the CLI, or
`node dist/main.js > output.log` for logging to a file named `output.log`.
9. Detach your terminal.
---
# Configuration:
All of the configuration for the server is done in the `server.toml` with
explanations in the file. When a value is changed in the config, you will need
to restart the server. This is either through systemd
(`sudo systemctl restart phantom-ink`) or through your preferred terminal
detacher, by stopping then re-starting the process.