Skip to content

Oneycs/nginx-egg

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

11 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Pterodactyl Nginx Egg

My "own" repository of Nginx Egg for Pterodactyl. Huge thanks to Ym0T

Β© Ym0T - https://github.com/Ym0T/pterodactyl-nginx-egg


Table of Contents


Features

  • 🧹 LogCleaner: Cleans /tmp and old logs (dry-run supported)
  • 🌱 Git Module: Auto git pull on restart
  • πŸ“¦ Composer Module: Installs packages from composer.json or a fallback variable
  • πŸ” ionCube Loader: Auto-detected and enabled for encrypted PHP
  • 🌐 Cloudflare Tunnel: Secure tunnel with token validation
  • πŸš€ PHP-NGINX Startup: Auto-detects PHP-FPM version, runs NGINX in foreground
  • πŸ–₯️ Multi-arch support: AMD64 & ARM64
  • 🎯 Selectable PHP Versions:
    • βœ… 8.4
    • βœ… 8.3
    • β˜‘οΈ 8.2 (security-only)
    • β˜‘οΈ 8.1 (security-only)

PHP Supported Versions


Installation

  1. Download the egg file (egg-nginx.json)
  2. In your Pterodactyl panel, navigate to Nests in the sidebar
  3. Import the egg under Import Egg
  4. Create a new server and select the Nginx egg
  5. Choose the Docker image matching your desired PHP version
  6. Fill in all required variables, including whether WordPress is desired and the PHP version field (must be set explicitly)

Composer Modules Usage

This egg supports easy installation of PHP libraries using Composer.

How it works:

  • If a composer.json file exists in your server's root directory, it will be used automatically to install dependencies.
  • If composer.json is missing, the egg looks for a variable (e.g. COMPOSER_MODULES) with a space-separated list of Composer packages to install.
  • If neither composer.json nor COMPOSER_MODULES is set, Composer installation is skipped.

Specifying Composer Modules manually:

  • Enter the packages in the COMPOSER_MODULES variable in this format:
vendor/package[:version_constraint]

Examples:

  • Latest stable version:
    symfony/http-foundation 
    
  • Specific version or range:
    monolog/monolog:^2.0 doctrine/orm:~2.10 nesbot/carbon:^2.50 
    
  • Multiple packages separated by spaces:
    symfony/http-foundation:^6.0 monolog/monolog guzzlehttp/guzzle 
    

Notes:

  • Make sure package names and versions exist on Packagist.
  • Incorrect inputs can cause installation errors visible in the server console.
  • Installing many or complex packages can increase startup time.
  • Composer must be pre-installed in the container environment (this egg includes it).

ionCube Loader Support

  • ionCube Loader is detected and enabled automatically if encrypted PHP files are present.
  • No manual configuration needed; simply upload your ionCube-protected scripts and run.

πŸš€ Cloudflared Tunnel Tutorial

With Cloudflared, you can create a secure tunnel to your server, making it accessible over the internet without complicated port forwarding!
Cloudflared | Create a remotely-managed tunnel

πŸ“Œ Requirements


  • πŸ”Ή Step 1: Log in to Zero Trust β†— and go to Networks > Tunnel
  • πŸ”Ή Step 2: Select Create a tunnel.
  • πŸ”Ή Step 3: Choose Cloudflared for the connector type and select Next.
  • πŸ”Ή Step 4: Enter a name for your tunnel.
  • πŸ”Ή Step 5: Select Save tunnel.
  • πŸ”Ή Step 6: Save the token. (The token is very long)

grafik


  • πŸ”Ή Step 7: Activate Cloudflared

grafik


  • πŸ”Ή Step 8: Add your token.

grafik


  • πŸ”Ή Step 9: Add public hostname

grafik


  • πŸ”Ή Step 10: Depending on the type, select http and URL always β€œlocalhost” + the web server port

grafik


  • πŸ”Ή Step 11: Restart your webserver.

grafik


Git Module

  • Specify your Git repository URL in the GIT_ADDRESS variable
  • Enable Git by setting the GIT_STATUS variable to 1 or true
  • On server creation, your repo will be cloned into the www folder
  • On each restart, git pull runs to update the files

Change PHP version

Changing the PHP version is currently still somewhat cumbersome. A revised version will be available in the future.

  • Step 1: In your Pterodactyl panel, go to the "Startup" tab on your web server. Change the variable "PHP VERSION" to the desired version.

php_version


  • Step 2: Finally, you need to customise the Docker image. Select the appropriate Docker image to match the version.

docker_image


PHP extensions

PHP extensions of PHP version 8.3:

Core, date, libxml, openssl, pcre, zlib, filter, hash, json, random, Reflection, SPL, session, standard, sodium, cgi-fcgi, mysqlnd, PDO, psr, xml, bcmath, calendar, ctype, curl, dom, mbstring, FFI, fileinfo, ftp, gd, gettext, gmp, iconv, igbinary, imagick, imap, intl, ldap, exif, memcache, mongodb, msgpack, mysqli, odbc, pcov, pdo_mysql, PDO_ODBC, pdo_pgsql, pdo_sqlite, pgsql, Phar, posix, ps, pspell, readline, shmop, SimpleXML, soap, sockets, sqlite3, sysvmsg, sysvsem, sysvshm, tokenizer, xmlreader, xmlwriter, xsl, zip, mailparse, memcached, inotify, maxminddb, protobuf, Zend OPcache

Notes

  • Public web root directory: www
  • To enable HTTPS, modify /home/container/nginx/conf.d/default.conf accordingly
  • PHP extensions vary slightly per version; full list available in docs
  • Changing PHP versions requires matching Docker image selection and restart

License

MIT License

Forked and adapted from: https://gitlab.com/tenten8401/pterodactyl-nginx

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors