Base PHP Framework for Multi Projects.
Bootgly is the first PHP framework to use the I2P (Interface-to-Platform) architecture.
Note
Bootgly will be completely refactored to use "Property Hooks" and v1.0 will be released only after PHP 8.4 is released.
Warning
π§ DO NOT USE IT IN PRODUCTION ENVIRONMENTS. π§
Bootgly is in beta testing. A major version (1.0) is soon to release.
- π€ About
- π’ Boot Requirements
- π± Community
- π Getting started
- πΌ Highlights
- π License
- π Versioning System
Bootgly is a base framework for developing APIs and Apps for both CLI (Console) π and WPI (Web) π.
"Bootgly is focused on efficiency and follows a minimum dependency policy. Thanks to this approach, its unique I2P architecture, along with some uncommon code conventions and design patterns, allows Bootgly to offer superior performance while providing an easy-to-understand Code APIs."
Command Line Interface
For the base CLI development, Bootgly already has the following UI Components: Alert, Fieldset, Header, Menu, Progress, Table.
Web Programming Interface
For the base Web development, Bootgly has a HTTP Server CLI, a TCP Client CLI and a TCP Server CLI.
More news may come until the release of v1.0. Stay tuned.
Operation System |
---|
β Linux (Debian based) |
β Windows |
β Unix |
--
β = Compatible
β = Incompatible
β = Untested
Above is the native compatibility, of course it is possible to run on Windows and Unix using Docker containers.
- PHP 8.2+
β οΈ - Opcache + JIT enabled (+50% performance) π
php-cli
β οΈ php-mbstring
πphp-readline
β οΈ
rewrite
module enabledβ οΈ
--
π = Recommended
Join us and help the community.
Love Bootgly? Give our repo a star β!
Wait for the "contributing guidelines" to start your contribution.
Help us keep Bootgly open and inclusive. Please read and follow our Code of Conduct.
- Bootgly on LinkedIn: [Company Page]
- Bootgly on Telegram: [Telegram Group]
- Bootgly on Reddit: [Reddit Community]
- Bootgly on Discord: [Discord Channel]
A lot of time and energy is devoted to Bootgly projects. To accelerate your growth, if you like this project or depend on it for your stack to work, consider sponsoring it.
Your sponsorship will keep this project always up to date with new features and improvements / bug fixes.
Run Bootgly CLI demo
- See the examples in
projects/Bootgly/CLI/examples/
; - Check the file
projects/Bootgly/CLI.php
; - Run the Bootgly CLI demo in terminal:
php bootgly demo
Setup Bootgly CLI globally
- Run the Bootgly CLI setup command in terminal (with sudo):
sudo php bootgly setup
Perform Bootgly tests
- Check the bootstrap tests file
tests/@.php
; - Run the Bootgly CLI test command in terminal:
bootgly test
Running a HTTP Server
- Enable support to
rewrite
; - Configure the WPI boot file in
projects/Bootgly/WPI.boot.php
file; - Run the Non-CLI HTTP Server pointing to
index.php
.
Directly in Linux OS (max performance):
- Configure the Bootgly HTTP Server script in
scripts/http-server-cli
file; - Configure the HTTP Server API in
projects/Bootgly/WPI/HTTP_Server_CLI-1.SAPI.php
file; - Run the Bootgly HTTP Server CLI in the terminal:
bootgly serve
or
php scripts/http-server-cli
--
or using Docker:
- Pull the image:
docker pull bootgly/http-server-cli
- Run the container in interactive mode and in the host network for max performance:
docker run -it --network host bootgly/http-server-cli
Routing HTTP Requests on the Server-side
Bootgly CLI - initial output |
Progress component (with Bar) - Render β7x faster than Laravel / Symfony |
Bootgly HTTP Server CLI (wrk benchmark) - +7% faster than Workerman in the Plain Text test |
HTTP Server CLI - started in monitor mode |
More Screenshots, videos and details can be found in the home page of Bootgly Docs.
The Bootgly is open-sourced software licensed under the MIT license.
Bootgly uses Semantic Versioning 2.0.