REQUIRES NODE 4 OR GREATER
Start a PHP-server
This is pretty much a gulp version of @sindresorhus's grunt-php and acts as a basic version drop-in replacement for gulp-connect, though please note not all features from gulp-connect are supported with gulp-connect-php. I am open to supporting other features and pull requests that implement them.
Uses the built-in server in PHP 5.4.0+.
$ npm install --save-dev gulp-connect-php
var gulp = require('gulp'),
connect = require('gulp-connect-php');
gulp.task('connect', function() {
connect.server();
});
gulp.task('default', ['connect']);
var gulp = require('gulp'),
connect = require('gulp-connect-php');
let server = new connect();
gulp.task('connect', function() {
server.server();
});
gulp.task('disconnect', function() {
server.closeServer();
});
gulp.task('default', ['connect', 'disconnect']);
var gulp = require('gulp'),
connect = require('gulp-connect-php'),
browserSync = require('browser-sync');
gulp.task('connect-sync', function() {
connect.server({}, function (){
browserSync({
proxy: '127.0.0.1:8000'
});
});
gulp.watch('**/*.php').on('change', function () {
browserSync.reload();
});
});
gulp.task('connect', function() {
connect.server({
configCallback: function _configCallback(type, collection) {
// If you wish to leave one of the argument types alone, simply return the passed in collection.
if (type === connect.OPTIONS_SPAWN_OBJ) { // As the constant suggests, collection is an Object.
// Lets add a custom env var. Good for injecting AWS_RDS config variables.
collection.env = Object.assign({
MY_CUSTOM_ENV_VAR: "env_var_value"
}, process.env);
return collection;
} else if (type === connect.OPTIONS_PHP_CLI_ARR) { // As the constant suggests, collection is an Array.
let newArgs = [
'-e', // Generate extended information for debugger/profiler.
'-d', 'memory_limit=2G' // Define INI entry, Up memory limit to 2G.
];
// Ensure our argument switches appear before the rest.
return newArgs.concat(collection);
}
}
}, function _connected_callback() {
console.log("PHP Development Server Connected.");
});
});
gulp.task('disconnect', function() {
connect.closeServer();
});
gulp.task('default', ['connect', 'disconnect']);
Windows Batch file execution via a %PATH%
specified batchfile is possible, but some considerations are required.
- The batch file must be on your
%PATH%
and executable with permissions of the invoker. - You must pass the parameter set off to the PHP process.
- We have no -real- way of detecting an error state at this point.
- You must use the 'Advanced Option Maniulation' scheme and set the
shell
option onspawn(...)
.
- PHP is located at
C:\Users\mainuser\Applications\PHP\7.0.17-NTS-VC14\php.exe
. - The batch file is located at
C:\Users\mainuser\MyProject\strap\php.bat
. - I have set
%PATH%
manually toC:\Users\mainuser\MyProject\strap\;%PATH%
.
@echo off
REM We specify the whole path to PHP since the working directory is that of gulp...
REM unless we also changed that in our gulp callback.
C:\Users\mainuser\Applications\PHP\7.0.17-NTS-VC14\php.exe %*
gulp.task('connect', function _gulp_connect_task() {
connect.server({
configCallback: function _configCallback(type, collection) {
if (type === connect.OPTIONS_SPAWN_OBJ) {
// Windows Batch files are NOT executable on their own. This will start a shell
// session then execute.
collection.shell = true;
return collection;
}
}
}, function _connected_callback() {
console.log("PHP Development Server Connected.");
});
});
gulp.task('default', ['connect']);
Type: number
Default: 8000
The port on which you want to access the webserver. Task will fail if the port is already in use.
Type: string
Default: '127.0.0.1'
(usually same as localhost
)
The hostname the webserver will use.
Use 0.0.0.0
if you want it to be accessible from the outside.
Type: string
Default: '.'
From which folder the webserver will be served. Defaults to the directory of the gulpfile.
Type: boolean
Default: false
Open the server in the browser when the task is triggered.
Type: string
Optionally specify the path to a router script that is run at the start of each HTTP request. If this script returns false
, then the requested resource is returned as-is. Otherwise the script's output is returned to the browser.
Example router script:
<?php
// router.php
if (preg_match('/\.(?:png|jpg|jpeg|gif)$/', $_SERVER["REQUEST_URI"])) {
return false; // serve the requested resource as-is
} else {
echo "<p>Thanks for using gulp-connect-php :)</p>";
}
?>
Type: string
Default: 'php'
Path to the PHP binary. Useful if you have multiple versions of PHP installed.
Type: string
Default: Built-in php.ini
Path to a custom php.ini
config file.
Type: string
Default: 'inherit'
Node's stdio parameter, set it to 'ignore'
to suppress all the logging into console of the php server process.
Type: function (type, collection) : collection
Prototype:
-
type
- String, eitherOPTIONS_SPAWN_OBJ
orOPTIONS_PHP_CLI_ARR
. -
collection
- Array or Object, the initial version of the collection specified bytype
.Return: Optionally modified version of
collection
.
Default: 'null'
(Which is replaced with a no-op call that returns an unmodified version of the collection
parameter)
Allows the caller to modify the spawn
options object and or the PHP command line arguments (array) before the PHP development server is invoked.
Type: boolean
Default: 'false'
Enables debugging of the spawn call and its parameters.
This package comes with a NPM run-script command called prepack
. This is intended to be run before the packaging and pushing to NPM, however it is also what builds the Node 4.X compatibility script index-compat.js
. Without it the default package.json
will not execute properly.
MIT © Micah Blu