Skip to content

Latest commit

 

History

History
201 lines (142 loc) · 5.42 KB

README.md

File metadata and controls

201 lines (142 loc) · 5.42 KB

Logo

Squad SDM

A JavaScript Discord bot to manage your Squad server

OverviewRequirementsDependenciesDiscord bot identityInstallationRunning the botUsage & ManagementCredits


Overview

SSDM is a Discord bot adapted to manage your LinuxGSM Squad server.

It provides essential features like:

  • Start/Stop/Restart server
  • Update server
  • Get server status
  • Manage server configuration
  • Install/Update/Delete mods

If you need help, contact me on Discord : nom4de


Requirements


Dependencies

Discord.js
Powerful Node.js module that allows you to easily interact with the Discord API. See on npm

fs
Node.js file system module. See on npm

ssh2
SSH2 client and server modules written in pure JavaScript for node.js. See on npm


Discord bot identity

  1. Go to the Discord Developer Portal and create a new application.
  2. In the general information tab, enter the name of your bot (this is only the developer portal's name) and the description you want. You can also add a profile picture.
  3. Copy the application ID and enter it in the config.json file as the clientID
  4. Then go the the bot tab and add the name you want to display inside Discord. If you need a banner, this is also the place to do it.
  5. You can now reset the token and copy it in the config.json file as the token. DO NOT SHARE THIS TOKEN WITH ANYONE (if you do, regenerate it).
  6. Go to the OAuth2 tab and select bot in the OAuth2 URL Generator. Then select the permissions you want to give to your bot (I suggest giving it administrator permissions for your server). Select Guild Install as the integration type. You can generate a different link for each server you want to add the bot to.
  7. Copy the generated link and paste it in your browser. You can now add your bot to your server if you are admin.

Installation

  1. Clone the repository (or download the zip) :
git clone https://github.com/Nicolas-Colombier/SquadSDM.git
  1. Go to the bot directory :
cd SquadSDM
  1. Install npm dependencies :
npm install
  1. Create a config.json file using the config.json.example template :
cp config.json.example config.json
  1. Edit the config.json file with your Discord bot token and your Squad server SSH credentials :
  • token : Your Discord bot token
  • activity : The activity the bot will display (eg. "Watching your activity")
  • clientID : Your Discord bot client ID
  • guildID : Your Discord server ID
  • mods : The list of mods that will be in the 'updatemod' and 'deletemod' commands (DO NOT DELETE THE LAST ONE).
  • server : Each object is a server, if you have more then just add more object (be careful of the syntaxe). Each server can be on a different machine or user but need SSH access.
  1. Deploy the commands on the bot :
node utils/deployCommandsUtils.js

Running the bot

  1. Create a systemd service to run the bot (from this point requires sudo access):
nano /etc/systemd/system/squad_sdm.service
  1. Add the following content :
[Unit]
Description=Squad SDM

[Service]
Type=simple
User=name_of_your_linux_user
WorkingDirectory=/home/****/path_to_the_bot
ExecStart=/usr/bin/node /home/****/path_to_the_bot/index.js
Restart=always
RestartSec=3
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=name_of_your_linux_user

[Install]
WantedBy=multi-user.target
  1. Reload the service files to include the new service (requires sudo access) :
sudo systemctl daemon-reload
  1. Start the bot (requires sudo access) :
sudo systemctl start squad_sdm
  1. Check the status of the bot (requires sudo access) :
sudo systemctl status squad_sdm
  1. Enable the bot to start on boot (requires sudo access) :
sudo systemctl enable squad_sdm

Usage & Management

To disable the bot to start on boot (requires sudo access) :

sudo systemctl disable squad_sdm

Stop the bot (requires sudo access) :

sudo systemctl stop squad_sdm

Take a look to the logs (requires sudo access) :

sudo journalctl -u squad_sdm
sudo journalctl -fu squad_sdm

Credits

  • Foxinou - For the original idea and his help during development