nodemon
Generic LanguageNodemon javascript egg that automatically restarts the node application when file changes in the directory are detected This will clone a git repo for a bot. it defaults to master if no branch is specified. Installs the node_modules on install. If you set user_upload, then I assume you know what you are doing.
README
Nodemon (JavaScript & TypeScript)
Tired of manually restarting your bot? Nodemon will do it by itself.
Nodemon is a tool that helps develop node.js based applications by automatically restarting the node application when file changes in the directory are detected. Nodemon does not require any additional changes to your code or method of development.
This egg is designed to run any generic Javascript application, allowing users to pull their own JavaScript or TypeScript source code from a Github repository.
There is an option to allow a user to upload their own files to run a bot.
The startup configs and commands may need changing to actually function properly.
Configuration
The server will be stuck as starting until the egg Start Configuration is modified. You have to edit the text to match something your bot will print for Pterodactyl panel to detect it as running.

You can use arrays to have multiple different values when different bots are being used
{
"done":[
"change this text 1",
"change this text 2"
]
}
Docker Images (11)
| Name | Image |
|---|---|
Nodejs 24 | ghcr.io/ptero-eggs/yolks:nodejs_24 |
Nodejs 23 | ghcr.io/ptero-eggs/yolks:nodejs_23 |
Nodejs 22 | ghcr.io/ptero-eggs/yolks:nodejs_22 |
Nodejs 21 | ghcr.io/ptero-eggs/yolks:nodejs_21 |
Nodejs 20 | ghcr.io/ptero-eggs/yolks:nodejs_20 |
Nodejs 19 | ghcr.io/ptero-eggs/yolks:nodejs_19 |
Nodejs 18 | ghcr.io/ptero-eggs/yolks:nodejs_18 |
Nodejs 17 | ghcr.io/ptero-eggs/yolks:nodejs_17 |
Nodejs 16 | ghcr.io/ptero-eggs/yolks:nodejs_16 |
Nodejs 14 | ghcr.io/ptero-eggs/yolks:nodejs_14 |
Nodejs 12 | ghcr.io/ptero-eggs/yolks:nodejs_12 |
Startup Command
npm install nodemon; if [[ -d .git ]] && [[ {{AUTO_UPDATE}} == "1" ]]; then git pull; fi; if [[ ! -z ${NODE_PACKAGES} ]]; then /usr/local/bin/npm install ${NODE_PACKAGES}; fi; if [[ ! -z ${UNNODE_PACKAGES} ]]; then /usr/local/bin/npm uninstall ${UNNODE_PACKAGES}; fi; if [ -f /home/container/package.json ]; then /usr/local/bin/npm install --production; fi; /home/container/node_modules/nodemon/bin/nodemon.js /home/container/{{BOT_JS_FILE}} Variables (9)
Git Repo Address
GitHub Repo to clone I.E. https://github.com/nickdevnl/repo_name
- Environment:
GIT_ADDRESS- Default:
None- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
nullable|string
Install Branch
The branch of the bot to install.
- Environment:
BRANCH- Default:
None- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
nullable|string
User Uploaded Files
Skip all the install stuff if you are letting a user upload files. 0 = false (default) 1 = true
- Environment:
USER_UPLOAD- Default:
0- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
required|boolean
Auto Update
Pull the latest files on startup when using a GitHub repo. You must have .git folder, reinstall if you are missing it.
- Environment:
AUTO_UPDATE- Default:
0- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
required|boolean
Bot js file
The file that starts the bot.
- Environment:
BOT_JS_FILE- Default:
index.js- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
required|string
Additional Node packages
Install additional node packages. Use spaces to separate.
- Environment:
NODE_PACKAGES- Default:
None- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
nullable|string
Uninstall Node packages
Uninstall node packages. Use spaces to separate.
- Environment:
UNNODE_PACKAGES- Default:
None- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
nullable|string
Git Username
Username to auth with git.
- Environment:
USERNAME- Default:
None- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
nullable|string
Git Access Token
Password to use with git. It's best practice to use a Personal Access Token. https://github.com/settings/tokens https://gitlab.com/-/profile/personal_access_tokens
- Environment:
ACCESS_TOKEN- Default:
None- User Viewable:
- ❌
- User Editable:
- ❌
- Rules:
nullable|string
Installation Script
node:lts-bookwormbash#!/bin/bash
# NodeJS Bot Installation Script
#
# Server Files: /mnt/server
apt update
apt install -y git curl jq file unzip make gcc g++ python python-dev libtool
mkdir -p /mnt/server
cd /mnt/server
if [ "${USER_UPLOAD}" == "true" ] || [ "${USER_UPLOAD}" == "1" ]; then
echo -e "assuming user knows what they are doing have a good day."
exit 0
fi
## add git ending if it's not on the address
if [[ ${GIT_ADDRESS} != *.git ]]; then
GIT_ADDRESS=${GIT_ADDRESS}.git
fi
if [ -z "${USERNAME}" ] && [ -z "${ACCESS_TOKEN}" ]; then
echo -e "using anon api call"
else
GIT_ADDRESS="https://${USERNAME}:${ACCESS_TOKEN}@$(echo -e ${GIT_ADDRESS} | cut -d/ -f3-)"
fi
## pull git js bot repo
if [ "$(ls -A /mnt/server)" ]; then
echo -e "/mnt/server directory is not empty."
if [ -d .git ]; then
echo -e ".git directory exists"
if [ -f .git/config ]; then
echo -e "loading info from git config"
ORIGIN=$(git config --get remote.origin.url)
else
echo -e "files found with no git config"
echo -e "closing out without touching things to not break anything"
exit 10
fi
fi
if [ "${ORIGIN}" == "${GIT_ADDRESS}" ]; then
echo "pulling latest from github"
git pull
fi
else
echo -e "/mnt/server is empty.\ncloning files into repo"
if [ -z ${BRANCH} ]; then
echo -e "cloning default branch"
git clone ${GIT_ADDRESS} .
else
echo -e "cloning ${BRANCH}'"
git clone --single-branch --branch ${BRANCH} ${GIT_ADDRESS} .
fi
fi
echo "Installing nodejs packages"
if [[ ! -z ${NODE_PACKAGES} ]]; then
/usr/local/bin/npm install ${NODE_PACKAGES}
fi
if [ -f /mnt/server/package.json ]; then
/usr/local/bin/npm install --production
fi
echo -e "install complete"
exit 0