php-formula

Travis CI Build Status Semantic Release

Formula to set up and configure php

WARNING: BREAKING CHANGES SINCE v1.0.0

Prior to v1.0.0, this formula provided two methods for managing PHP; the old method under php and the new method under php.ng. The old method has now been removed and php.ng has been promoted to be php in its place.

If you are not in a position to migrate, please pin your repo to the final release tag before v1.0.0, i.e. v0.40.1.

To migrate from php.ng, simply modify your pillar to promote the entire section under php:ng so that it is under php instead. So with the editor of your choice, highlight the entire section and then unindent one level. Finish by removing the ng: line.

To migrate from the old php, first convert to php.ng under v0.40.1. and then follow the steps laid out in the paragraph directly above.

1. General notes

If you are interested in writing or contributing to formulas, please pay attention to the Writing Formula Section.

If you want to use this formula, please pay attention to the FORMULA file and/or git tag, which contains the currently released version. This formula is versioned according to Semantic Versioning.

See Formula Versioning Section for more details.

2. Contributing to this repo

Commit message formatting is significant!!

Please see How to contribute for more details.

3. Available states

Please provide feedback by filing issues, discussing in #salt in Freenode and the mailing list as normal.

Note: php states require the merge parameter of salt.modules.pillar.get(), first available in the Helium release.

3.1. php

Installs the php package.

3.2. php.adodb

Installs the php-adodb package.

3.3. php.apache2

Meta-state that combines php.apache2.install and php.apache2.ini.

3.4. php.apache2.ini

Manages the apache2 php.ini file

3.5. php.apache2.install

Installs the apache2 and libapache2-mod-php5 package. Debian Only.

3.6. php.apc

Installs the php-apc package. Disabled on opensuse need server:php repo

3.7. php.apcu

Installs the php-apcu package. Disabled on opensuse need server:php repo

3.8. php.auth-sasl

Installs the php-auth-sasl package.

3.9. php.bcmath

Installs the php-bcmath package.

3.10. php.bz2

Installs the php-bz2 package.

3.11. php.cache-lite

Installs the php-cache-lite package.

3.12. php.cgi

Installs the php-cgi package. Disabled on opensuse only php5-fastcgi available.

3.13. php.cli

Meta-state that combines php.cli.install and php.cli.ini.

3.14. php.cli.ini

Manages the php-cli ini file.

3.15. php.cli.install

Installs the php-cli package.

3.16. php.composer

Installs [composer](https://getcomposer.org) and keeps it updated.

3.17. php.console-table

Installs the php-console-table package.

3.18. php.ctype

Installs the php-ctype package.

3.19. php.curl

Installs the php5-curl package on Debian, and ensures that curl itself is installed for RedHat systems, this is due to the curl libs being provided by php-common, which will get installed with the main php package.

3.20. php.dba

Installs the php-dba package.

3.21. php.dev

Installs the php5-dev and build-essential package.

3.22. php.filter

Installs the php-filter package.

3.23. php.fpm

Meta-state that combines all php.fpm states.

3.24. php.fpm.config

Manages the (non-pool) php-fpm config files.

3.25. php.fpm.install

Installs the php-fpm package.

3.26. php.fpm.pools

Meta-state that combines php.fpm.service and php.fpm.pools_config

3.27. php.fpm.pools_config

Manages php-fpm pool config files.

3.28. php.fpm.service

Manages the php-fpm service.

3.29. php.gd

Installs the php-gd package.

3.30. php.gearman

Installs the php-gearman package.

3.31. php.geoip

Installs the php-geoip package.

3.32. php.geshi

Installs the php-geshi package.

3.33. php.gettext

Installs the php-gettext package.

3.34. php.gmp

Installs the php-gmp package. Debian Only.

3.35. php.hash

Installs the php-hash package.

3.36. php.http

Installs the php-http package.

3.37. php.hhvm

Meta-state that combines php.hhvm states

3.38. php.hhvm.config

Manages the php-hhvm config files

3.39. php.hhvm.install

Installs the php-hhvm package

3.40. php.hhvm.repo

Configures the hhvm repo for debian/ubuntu

3.41. php.hhvm.service

Manages the php-hhvm service.

3.42. php.igbinary

Installs the php-igbinary package.

3.43. php.imagick

Installs the php-imagick package. Disabled on opensuse no package.

3.44. php.imap

Installs the php-imap package.

3.45. php.intl

Installs the php-intl package.

3.46. php.json

Installs the php-json package.

3.47. php.ldap

Installs the php-ldap package.

3.48. php.mail

Installs the php-mail package.

3.49. php.mbstring

Installs the php-mbstring package.

3.50. php.mcrypt

Installs the php-mcrypt package.

3.51. php.mdb2

Installs the php-mdb2 package.

3.52. php.mdb2-driver-mysql

Installs the php-mdb2-driver-mysql package.

3.53. php.mdb2-driver-pgsql

Installs the php-mdb2-driver-pgsql package.

3.54. php.memcache

Installs the php-memcache package. Disabled on opensuse need server:php:extensions repo

3.55. php.memcached

Installs the php-memcached package. Disabled on opensuse need server:php:extensions repo

3.56. php.modules

Calls php.<name> for each entry in php:modules if available, or try to install the matching packages that can be set via from php:lookup:pkgs

3.57. php.mongo

Installs the php-mongo package.

3.58. php.mongodb

Installs the php-mongodb package.

3.59. php.msgpack

Installs the php-msgpack package.

3.60. php.mysql

Installs the php-mysql package.

3.61. php.mysqlnd

Installs the php-mysqlnd package. Disabled on opensuse no package.

3.62. php.net-smtp

Installs the php-net-smtp package.

3.63. php.net4

Installs the php-net4 package.

php.net6 ^^^^^NET6

Installs the php-net6 package.

3.64. php.oauth

Installs the php-oauth package.

3.65. php.opcache

Installs the php-opcache package.

3.66. php.openssl

Installs the php-openssl package.

3.67. php.pear

Installs the php-pear package.

3.68. php.pgsql

Installs the php-pgsql package.

3.69. php.phar

Installs the php-phar package.

3.70. php.posix

Installs the php-posix package.

3.71. php.pspell

Installs the php-pspell package.

3.72. php.readline

Installs the php-readline package.

3.73. php.redis

Installs the php-redis package. Disabled on opensuse need server:php:extensions repo

3.74. php.seclib

Installs the php-seclib package.

3.75. php.session

Installs the php-session package.

3.76. php.snmp

Installs the php-snmp package.

3.77. php.soap

Installs the php-soap package.

3.78. php.sqlite

Installs the php-sqlite package,

3.79. php.ssh2

Installs the php-ssh2 package,

3.80. php.suhosin

Installs the php-suhosin package.

3.81. php.svn

Installs the php-svn package.

3.82. php.sybase

Installs the php-sybase package.

3.83. php.tcpdf

Installs the php-tcpdf package.

3.84. php.tidy

Installs the php-tidy package.

3.85. php.uuid

Installs the php-uuid package.

3.86. php.xcache

Meta-state that combines php.xcache.install and php.xcache.ini.

3.87. php.xcache.ini

Manages the php-xcache ini file

3.88. php.xcache.install

Installs the php-xcache package. Disabled on opensuse need server:php:extensions repo

3.89. php.xdebug

Installs the php-xdebug package.

3.90. php.xml

Installs the php-xml package.

3.91. php.xsl

Installs the php-xsl package.

3.92. php.zip

Installs the php-zip package.

4. Testing

Linux testing is done with kitchen-salt.

4.1. Requirements

  • Ruby

  • Docker

$ gem install bundler
$ bundle install
$ bin/kitchen test [platform]

Where [platform] is the platform name defined in kitchen.yml, e.g. debian-9-2019-2-py3.

4.2. bin/kitchen converge

Creates the docker instance and runs the php main states, ready for testing.

4.3. bin/kitchen verify

Runs the inspec tests on the actual instance.

4.4. bin/kitchen destroy

Removes the docker instance.

4.5. bin/kitchen test

Runs all of the stages above in one go: i.e. destroy + converge
verify + destroy.

4.6. bin/kitchen login

Gives you SSH access to the instance for manual testing.

5. Testing with Vagrant

Windows/FreeBSD/OpenBSD testing is done with kitchen-salt.

5.1. Requirements

  • Ruby

  • Virtualbox

  • Vagrant

5.2. Setup

$ gem install bundler
$ bundle install --with=vagrant
$ bin/kitchen test [platform]

Where [platform] is the platform name defined in kitchen.vagrant.yml, e.g. windows-81-latest-py3.

5.3. Note

When testing using Vagrant you must set the environment variable KITCHEN_LOCAL_YAML to kitchen.vagrant.yml. For example:

$ KITCHEN_LOCAL_YAML=kitchen.vagrant.yml bin/kitchen test      # Alternatively,
$ export KITCHEN_LOCAL_YAML=kitchen.vagrant.yml
$ bin/kitchen test

Then run the following commands as needed.

5.4. bin/kitchen converge

Creates the Vagrant instance and runs the php main states, ready for testing.

5.5. bin/kitchen verify

Runs the inspec tests on the actual instance.

5.6. bin/kitchen destroy

Removes the Vagrant instance.

5.7. bin/kitchen test

Runs all of the stages above in one go: i.e. destroy + converge
verify + destroy.

5.8. bin/kitchen login

Gives you RDP/SSH access to the instance for manual testing.