Egg Repository

Pterodactyl Community Egg Repository

python generic

A Generic Python Egg for Pterodactyl Tested with: https://github.com/Ispira/pixel-bot

Read Me

Python Language Generic

This egg is designed to run any generic Python application, allowing users to pull their own Python 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. image

You can use arrays to have multiple different values when different bots are being used

{
  "done":[
    "change this text 1",
    "change this text 2"
  ]
}
Yolks
NameTag
Python 3.12ghcr.io/ptero-eggs/yolks:python_3.12
Python 3.11ghcr.io/ptero-eggs/yolks:python_3.11
Python 3.10ghcr.io/ptero-eggs/yolks:python_3.10
Python 3.9ghcr.io/ptero-eggs/yolks:python_3.9
Python 3.8ghcr.io/ptero-eggs/yolks:python_3.8
Python 3.7ghcr.io/ptero-eggs/yolks:python_3.7
Python 2.7ghcr.io/ptero-eggs/yolks:python_2.7
Variables
NameDescriptionEnvironment VariableDefault ValueUser ViewableUser Editable
Git Repo AddressGit repo to clone I.E. https://github.com/parkervcp/repo_nameGIT_ADDRESSYesYes
Git BranchWhat branch to pull from github. Default is blank to pull the repo default branchBRANCHYesYes
User Uploaded FilesSkip all the install stuff if you are letting a user upload files. 0 = false (default) 1 = trueUSER_UPLOAD0YesYes
Auto UpdatePull the latest files on startup when using a GitHub repo.AUTO_UPDATE0YesYes
App py fileThe file that starts the App.PY_FILEapp.pyYesYes
Additional Python packagesInstall additional python packages. Use spaces to separatePY_PACKAGESYesYes
Git UsernameUsername to auth with git.USERNAMEYesYes
Git Access TokenPassword 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_tokensACCESS_TOKENYesYes
Requirements fileif there are other requirements files to choose from.REQUIREMENTS_FILErequirements.txtYesYes
Install Script
#!/bin/bash
# Python App Installation Script
#
# Server Files: /mnt/server
apt update
apt install -y git curl jq file unzip make gcc g++ 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 python 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

export HOME=/mnt/server

echo "Installing python requirements into folder"
if [[ ! -z ${PY_PACKAGES} ]]; then
    pip install -U --prefix .local ${PY_PACKAGES}
fi

if [ -f /mnt/server/requirements.txt ]; then
    pip install -U --prefix .local -r ${REQUIREMENTS_FILE}
fi

echo -e "install complete"
exit 0