tncrazvan / catpaw
The catpaw project
Requires
- php: ^8.2
- ext-mbstring: *
- ext-openssl: *
- ext-pcntl: *
- ext-zlib: *
- amphp/amp: ^3.0
- amphp/byte-stream: ^2.1
- amphp/file: ^3.0
- amphp/http-client: ^5.0
- amphp/http-server: ^3.3
- amphp/parallel: ^2.0
- amphp/process: ^2.0
- amphp/websocket-server: ^4.0
- monolog/monolog: ^3.3
- revolt/event-loop: ^1.0
- twig/twig: ^3.0
- vlucas/phpdotenv: ^5.4
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.8
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^9
- dev-master
- 3.3.1
- 3.3.0
- 3.2.6
- 3.2.5
- 3.2.4
- 3.2.3
- 3.2.2
- 3.2.1
- 3.2.0
- 3.1.0
- 3.0.12
- 3.0.11
- 3.0.10
- 3.0.9
- 3.0.8
- 3.0.7
- 3.0.6
- 3.0.5
- 3.0.4
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.4.10
- 2.4.9
- 2.4.8
- 2.4.7
- 2.4.6
- 2.4.5
- 2.4.4
- 2.4.3
- 2.4.2
- 2.4.1
- 2.4.0
- 2.3.26
- 2.3.25
- 2.3.24
- 2.3.23
- 2.3.22
- 2.3.21
- 2.3.20
- 2.3.19
- 2.3.18
- 2.3.17
- 2.3.16
- 2.3.15
- 2.3.14
- 2.3.13
- 2.3.12
- 2.3.11
- 2.3.10
- 2.3.9
- 2.3.8
- 2.3.7
- 2.3.6
- 2.3.5
- 2.3.4
- 2.3.3
- 2.3.2
- 2.3.1
- 2.3
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2
- 2.1.38
- 2.1.37
- 2.1.36
- 2.1.35
- 2.1.34
- 2.1.33
- 2.1.32
- 2.1.31
- 2.1.30
- 2.1.29
- 2.1.28
- 2.1.27
- 2.1.26
- 2.1.25
- 2.1.24
- 2.1.23
- 2.1.22
- 2.1.21
- 2.1.20
- 2.1.19
- 2.1.18
- 2.1.17
- 2.1.16
- 2.1.15
- 2.1.14
- 2.1.13
- 2.1.12
- 2.1.11
- 2.1.10
- 2.1.9
- 2.1.8
- 2.1.7
- 2.1.6
- 2.1.5
- 2.1.4
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.69
- 2.0.68
- 2.0.67
- 2.0.66
- 2.0.65
- 2.0.64
- 2.0.63
- 2.0.62
- 2.0.61
- 2.0.60
- 2.0.59
- 2.0.58
- 2.0.57
- 2.0.56
- 2.0.55
- 2.0.54
- 2.0.53
- 2.0.52
- 2.0.51
- 2.0.50
- 2.0.49
- 2.0.48
- 2.0.47
- 2.0.46
- 2.0.45
- 2.0.44
- 2.0.43
- 2.0.42
- 2.0.41
- 2.0.40
- 2.0.39
- 2.0.38
- 2.0.37
- 2.0.36
- 2.0.35
- 2.0.34
- 2.0.33
- 2.0.32
- 2.0.31
- 2.0.30
- 2.0.29
- 2.0.28
- 2.0.27
- 2.0.26
- 2.0.25
- 2.0.24
- 2.0.23
- 2.0.22
- 2.0.21
- 2.0.20
- 2.0.19
- 2.0.18
- 2.0.17
- 2.0.16
- 2.0.15
- 2.0.14
- 2.0.13
- 2.0.12
- 2.0.11
- 2.0.10
- 2.0.9
- 2.0.8
- 2.0.7
- 2.0.6
- 2.0.5
- 2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 1.0.22
- 1.0.21
- 1.0.20
- 1.0.19
- 1.0.18
- 1.0.17
- 1.0.16
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
This package is auto-updated.
Last update: 2024-05-24 22:11:27 UTC
README
Catpaw is an opinionated dependency injection library that comes with batteries included for developing asynchronous and declarative general purpose programs.
It leverages php attributes to provide declarative apis, and the amphp platform to make your program asynchronous.
Table of Contents |
---|
⚡ Error Management |
🌐 Router |
🌐 Path Parameters |
🌐 Open Api |
🌐 Session |
🌐 Byte Range Requests |
⚡ Entry |
⚡ Custom Attributes |
💡 RaspberryPi |
⚡ Services |
⚡ Stores |
⚡ Queues |
⚡ Schedule |
⚡ Build |
🌐 Websockets |
🌐 View (Twig) |
⚡ State |
⚡ Signals |
⚡ Go interop |
Note
This project is aimed at linux distributions, some features may or not may work on Windows and/or MacOS.
Feel free to contribute fixing issues for specific platforms.
Get started
You will need at least php 8.2 and the php-mbstring
extension.
Create a new project using one of the starter templates.
- you can start from scratch
composer create-project catpaw/starter
- you can start with a web server
composer create-project catpaw/web-starter
Every application must declare a main
function in the global scope, that will be your entry point:
<?php // src/main.php use Psr\Log\LoggerInterface; function main(LoggerInterface $logger){ $logger->info("hello world"); }
After you've created your new project, you can run it using
composer dev:watch
to watch file changes (useful in development) or
composer prod:start
for production mode.
Build & Run
It is possible, but not required, to build your application into a single .phar
file using
composer prod:build
The building process can be configured inside the build.ini
file.
After building your application, you can simply run it using
php app.phar
The resulting .phar
, by default (check build.ini
), includes the following directories:
./src
./vendor
./bin
./.build-cache
(created at comptile time)
which means it's a portable binary, you just need to make sure php is installed on whatever machine you're trying to run it on.
Debugging with VSCode
-
Install xdebug
apt install php8.2-xdebug
-
Put this configuration in your
./.vscode/launch.json
file{ "version": "0.2.0", "configurations": [ { "name": "Launch", "type": "php", "request": "launch", "program": "${workspaceRoot}/bin/start", "args": [ "--libraries='./src/lib'", "--entry='./src/main.php'" ], "cwd": "${workspaceRoot}", "runtimeArgs": [ "-dxdebug.start_with_request=yes" ], "env": { "XDEBUG_MODE": "debug,develop", "XDEBUG_CONFIG": "client_port=${port}" } }, { "name": "Listen", "type": "php", "request": "launch", "port": 9003 } ] }
-
Start debugging