Apache OpenWhisk runtime for PHP language functions. https://openwhisk.apache.org/
Clone or download
csantanapr Update patch level for php & publish docker image latest with git hash (
#45)

* publish docker image latest with git hash
* update patch levels for php
Latest commit ab65b67 Nov 13, 2018

README.md

Apache OpenWhisk runtimes for PHP

License Build Status

PHP versions

This runtime provides PHP 7.2 and 7.1.

Give it a try today

To use as a docker action

PHP 7.2:

wsk action update myAction myAction.php --docker openwhisk/action-php-v7.2:latest

PHP 7.1:

wsk action update myAction myAction.php --docker openwhisk/action-php-v7.1:latest

This works on any deployment of Apache OpenWhisk

To use on deployment that contains the rutime as a kind

To use as a kind action

PHP 7.2:

wsk action update myAction myAction.php --kind php:7.2

PHP 7.1:

wsk action update myAction myAction.php --kind php:7.1

Local development

./gradlew core:php7.2Action:distDocker
./gradlew core:php7.1Action:distDocker

This will produce the images whisk/action-php-v7.2 & whisk/action-php-v7.1

Build and Push image

docker login
./gradlew core:php7.2Action:distDocker -PdockerImagePrefix=$prefix-user -PdockerRegistry=docker.io
./gradlew core:php7.1Action:distDocker -PdockerImagePrefix=$prefix-user -PdockerRegistry=docker.io

Deploy OpenWhisk using ansible environment that contains the kinds php:7.2 & php:7.1 Assuming you have OpenWhisk already deploy locally and OPENWHISK_HOME pointing to root directory of OpenWhisk core repository.

Set ROOTDIR to the root directory of this repository.

Redeploy OpenWhisk

cd $OPENWHISK_HOME/ansible
ANSIBLE_CMD="ansible-playbook -i ${ROOTDIR}/ansible/environments/local"
$ANSIBLE_CMD setup.yml
$ANSIBLE_CMD couchdb.yml
$ANSIBLE_CMD initdb.yml
$ANSIBLE_CMD wipe.yml
$ANSIBLE_CMD openwhisk.yml

Or you can use wskdev and create a soft link to the target ansible environment, for example:

ln -s ${ROOTDIR}/ansible/environments/local ${OPENWHISK_HOME}/ansible/environments/local-php
wskdev fresh -t local-php

To use as docker action push to your own dockerhub account

docker tag whisk/php7.2Action $user_prefix/action-php-v7.2
docker push $user_prefix/action-php-v7.2
docker tag whisk/php7.1Action $user_prefix/action-php-v7.1
docker push $user_prefix/action-php-v7.1

Then create the action using your the image from dockerhub

wsk action update myAction myAction.php --docker $user_prefix/action-php-v7.2

The $user_prefix is usually your dockerhub user id.

Testing

Install dependencies from the root directory on $OPENWHISK_HOME repository

./gradlew install

Using gradle for the ActionContainer tests you need to use a proxy if running on Mac, if Linux then don't use proxy options You can pass the flags -Dhttp.proxyHost=localhost -Dhttp.proxyPort=3128 directly in gradle command. Or save in your $HOME/.gradle/gradle.properties

systemProp.http.proxyHost=localhost
systemProp.http.proxyPort=3128

Using gradle to run all tests

./gradlew :tests:test

Using gradle to run some tests

./gradlew :tests:test --tests *ActionContainerTests*

Using IntelliJ:

  • Import project as gradle project.
  • Make sure working directory is root of the project/repo
  • Add the following Java VM properties in ScalaTests Run Configuration, easiest is to change the Defaults for all ScalaTests to use this VM properties
-Dhttp.proxyHost=localhost
-Dhttp.proxyPort=3128

Disclaimer

Apache OpenWhisk Runtime PHP is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by the Apache Incubator. Incubation is required of all newly accepted projects until a further review indicates that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. While incubation status is not necessarily a reflection of the completeness or stability of the code, it does indicate that the project has yet to be fully endorsed by the ASF.