cookbook 'php', '= 5.1.0'
php
(95) Versions
5.1.0
-
-
10.1.1
-
10.0.3
-
10.0.2
-
10.0.1
-
10.0.0
-
9.2.18
-
9.2.17
-
9.2.16
-
9.2.15
-
9.2.14
-
9.2.13
-
9.2.12
-
9.2.11
-
9.2.10
-
9.2.9
-
9.2.8
-
9.2.7
-
9.2.6
-
9.2.5
-
9.2.4
-
9.2.3
-
9.2.2
-
9.2.1
-
9.2.0
-
9.1.4
-
9.1.3
-
9.1.2
-
9.1.1
-
9.1.0
-
9.0.0
-
8.1.2
-
8.1.1
-
8.1.0
-
8.0.1
-
8.0.0
-
7.2.0
-
7.1.0
-
7.0.0
-
6.1.1
-
6.1.0
-
6.0.0
-
5.1.0
-
5.0.0
-
4.6.0
-
4.5.0
-
4.4.0
-
4.3.0
-
4.2.0
-
4.1.0
-
4.0.0
-
3.1.1
-
3.1.0
-
3.0.0
-
2.2.1
-
2.2.0
-
2.1.1
-
2.1.0
-
2.0.0
-
1.10.1
-
1.10.0
-
1.9.0
-
1.8.0
-
1.7.2
-
1.7.1
-
1.7.0
-
1.6.1
-
1.6.0
-
1.5.0
-
1.4.6
-
1.4.4
-
1.4.2
-
1.4.0
-
1.3.14
-
1.3.12
-
1.3.10
-
1.3.4
-
1.3.2
-
1.3.0
-
1.2.6
-
1.2.4
-
1.2.2
-
1.2.0
-
1.1.8
-
1.1.6
-
1.1.4
-
1.1.2
-
1.1.0
-
1.0.2
-
1.0.0
-
0.99.2
-
0.99.1
-
0.99.0
-
0.9.1
-
0.9.0
-
0.7.0
Follow296
- 10.1.1
- 10.0.3
- 10.0.2
- 10.0.1
- 10.0.0
- 9.2.18
- 9.2.17
- 9.2.16
- 9.2.15
- 9.2.14
- 9.2.13
- 9.2.12
- 9.2.11
- 9.2.10
- 9.2.9
- 9.2.8
- 9.2.7
- 9.2.6
- 9.2.5
- 9.2.4
- 9.2.3
- 9.2.2
- 9.2.1
- 9.2.0
- 9.1.4
- 9.1.3
- 9.1.2
- 9.1.1
- 9.1.0
- 9.0.0
- 8.1.2
- 8.1.1
- 8.1.0
- 8.0.1
- 8.0.0
- 7.2.0
- 7.1.0
- 7.0.0
- 6.1.1
- 6.1.0
- 6.0.0
- 5.1.0
- 5.0.0
- 4.6.0
- 4.5.0
- 4.4.0
- 4.3.0
- 4.2.0
- 4.1.0
- 4.0.0
- 3.1.1
- 3.1.0
- 3.0.0
- 2.2.1
- 2.2.0
- 2.1.1
- 2.1.0
- 2.0.0
- 1.10.1
- 1.10.0
- 1.9.0
- 1.8.0
- 1.7.2
- 1.7.1
- 1.7.0
- 1.6.1
- 1.6.0
- 1.5.0
- 1.4.6
- 1.4.4
- 1.4.2
- 1.4.0
- 1.3.14
- 1.3.12
- 1.3.10
- 1.3.4
- 1.3.2
- 1.3.0
- 1.2.6
- 1.2.4
- 1.2.2
- 1.2.0
- 1.1.8
- 1.1.6
- 1.1.4
- 1.1.2
- 1.1.0
- 1.0.2
- 1.0.0
- 0.99.2
- 0.99.1
- 0.99.0
- 0.9.1
- 0.9.0
- 0.7.0
Installs and maintains php and php modules
cookbook 'php', '= 5.1.0', :supermarket
knife supermarket install php
knife supermarket download php
php Cookbook
It installs and configures PHP and the PEAR package management system. Also includes resources for managing PEAR (and PECL) packages, PECL channels, and PHP-FPM pools.
Requirements
Platforms
- Debian, Ubuntu
- CentOS, Red Hat, Oracle, Scientific, Amazon Linux
- Fedora
Chef
- Chef 12.7+
Cookbooks
- build-essential
Attributes
-
node['php']['install_method']
= method to install php with, defaultpackage
. -
node['php']['directives']
= Hash of directives and values to append tophp.ini
, default{}
.
The file also contains the following attribute types:
- platform specific locations and settings.
- source installation settings
Resources
This cookbook includes resources for managing:
- PEAR channels
- PEAR/PECL packages
php_pear_channel
PEAR Channels are alternative sources for PEAR packages. This resource provides and easy way to manage these channels.
Actions
-
:discover
: Initialize a channel from its server. -
:add
: Add a channel to the channel list, usually only used to add private channels. Public channels are usually added using the:discover
action -
:update
: Update an existing channel -
:remove
: Remove a channel from the List
Properties
-
channel_name
: name attribute. The name of the channel to discover -
channel_xml
: the channel.xml file of the channel you are adding -
binary
: pear binary, default: pear
Examples
# discover the horde channel php_pear_channel "pear.horde.org" do action :discover end # download xml then add the symfony channel remote_file "#{Chef::Config[:file_cache_path]}/symfony-channel.xml" do source 'http://pear.symfony-project.com/channel.xml' mode '0644' end php_pear_channel 'symfony' do channel_xml "#{Chef::Config[:file_cache_path]}/symfony-channel.xml" action :add end # update the main pear channel php_pear_channel 'pear.php.net' do action :update end # update the main pecl channel php_pear_channel 'pecl.php.net' do action :update end
php_pear
PEAR is a framework and distribution system for reusable PHP components. PECL is a repository for PHP Extensions. PECL contains C extensions for compiling into PHP. As C programs, PECL extensions run more efficiently than PEAR packages. PEARs and PECLs use the same packaging and distribution system. As such this resource is clever enough to abstract away the small differences and can be used for managing either. This resource also creates the proper module .ini file for each PECL extension at the correct location for each supported platform.
Actions
-
:install
: Install a pear package - if version is provided, install that specific version -
:upgrade
: Upgrade a pear package - if version is provided, upgrade to that specific version -
:remove
: Remove a pear package -
:reinstall
: Force install of the package even if the same version is already installed. Note: This will converge on every Chef run and is probably not what you want. -
:purge
: An alias for remove as the two behave the same in pear
Properties
-
package_name
: name attribute. The name of the pear package to install -
version
: the version of the pear package to install/upgrade. If no version is given latest is assumed. -
channel
: -
options
: Add additional options to the underlying pear package command -
directives
: extra extension directives (settings) for a pecl. on most platforms these usually get rendered into the extension's .ini file -
zend_extensions
: extension filenames which should be loaded with zend_extension. -
preferred_state
: PEAR by default installs stable packages only, this allows you to install pear packages in a devel, alpha or beta state -
binary
: The pear binary to use, by default pear, can be overridden if the binary is not called pear, e.g. pear7
Examples
# upgrade a pear php_pear 'XML_RPC' do action :upgrade end # install a specific version php_pear 'XML_RPC' do version '1.5.4' action :install end # install the mongodb pecl php_pear 'Install mongo but use a different resource name' do package_name 'mongo' action :install end # install the xdebug pecl php_pear 'xdebug' do # Specify that xdebug.so must be loaded as a zend extension zend_extensions ['xdebug.so'] action :install end # install apc pecl with directives php_pear 'apc' do action :install directives(shm_size: 128, enable_cli: 1) end # install using the pear-7 binary php_pear 'apc' do action :install binary 'pear7' end # install the beta version of Horde_Url # from the horde channel hc = php_pear_channel 'pear.horde.org' do action :discover end php_pear 'Horde_Url' do preferred_state 'beta' channel hc.channel_name action :install end # install the YAML pear from the symfony project sc = php_pear_channel 'pear.symfony-project.com' do action :discover end php_pear 'YAML' do channel sc.channel_name action :install end
php_fpm_pool
Installs the php-fpm
package appropriate for your distro (if using packages) and configures a FPM pool for you. Currently only supported in Debian-family operating systems and CentOS 7 (or at least tested with such, YMMV if you are using source).
Please consider FPM functionally pre-release, and test it thoroughly in your environment before using it in production
More info: http://php.net/manual/en/install.fpm.php
Actions
-
:install
: Installs the FPM pool (default). -
:uninstall
: Removes the FPM pool.
Attribute Parameters
-
pool_name
: name attribute. The name of the FPM pool. -
listen
: The listen address. Default:/var/run/php5-fpm.sock
-
user
: The user to run the FPM under. Default should be the webserver user for your distro. -
group
: The group to run the FPM under. Default should be the webserver group for your distro. -
process_manager
: Process manager to use - see http://php.net/manual/en/install.fpm.configuration.php. Default:dynamic
-
max_children
: Max children to scale to. Default: 5 -
start_servers
: Number of servers to start the pool with. Default: 2 -
min_spare_servers
: Minimum number of servers to have as spares. Default: 1 -
max_spare_servers
: Maximum number of servers to have as spares. Default: 3 -
chdir
: The startup working directory of the pool. Default:/
-
additional_config
: Additional parameters in JSON. Default: {}
Examples
# Install a FPM pool named "default" php_fpm_pool 'default' do action :install end
Recipes
default
Include the default recipe in a run list, to get php
. By default php
is installed from packages but this can be changed by using the install_method
attribute.
package
This recipe installs PHP from packages.
source
This recipe installs PHP from source.
Deprecated Recipes
The following recipes are deprecated and will be removed from a future version of this cookbook.
module_apc
module_apcu
module_curl
module_fileinfo
module_fpdf
module_gd
module_imap
module_ldap
module_memcache
module_mysql
module_pgsql
module_sqlite3
The installation of the php modules in these recipes can now be accomplished by installing from a native package or via the new php_pear resource. For example, the functionality of the module_memcache
recipe can be enabled in the following ways:
# using apt package 'php5-memcache' # using pear resource php_pear 'memcache'
Usage
Simply include the php
recipe where ever you would like php installed. To install from source override the node['php']['install_method']
attribute with in a role or wrapper cookbook:
Role example:
name 'php' description 'Install php from source' override_attributes( 'php' => { 'install_method' => 'source', } ) run_list( 'recipe[php]' )
Maintainers
This cookbook is maintained by Chef's Community Cookbook Engineering team. Our goal is to improve cookbook quality and to aid the community in contributing to cookbooks. To learn more about our team, process, and design goals see our team documentation. To learn more about contributing to cookbooks like this see our contributing documentation, or if you have general questions about this cookbook come chat with us in #cookbok-engineering on the Chef Community Slack
License
Copyright: 2011-2017, Chef Software, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
php Cookbook CHANGELOG
This file is used to list changes made in each version of the php cookbook.
5.1.0 (2018-04-05)
- Don't eval the action_class
- use php pear binary property in all recipes
- Remove incorrect not_if in the php_pear resource
- More testing updates
- Initial support for Ubuntu 18.04
5.0.0 (2018-02-15)
- Simplify this cookbook to remove the dependency on mysql cookbook, and remove the database dependencies in the recipes and attributes. This will allow folks who are using the mysql cookbook to be able to upgrade as needed (or pin to earlier versions). As this is a big change, pin to an earlier version if you need the mysql support that was previously available in this cookbook. Future versions may contain a resource that allows for recompiling php with the necessary extensions.
- Usage of
node['php']['pear']
in the php_pear resource has been replaced with a new 'binary' property for specifying the path to the binary - Added a new
priority
property to the php_pear resource
4.6.0 (2018-02-07)
- Converted the php_pear resource to a custom resource
- Moved all helper logic out of the resource and into its own helper library file
- Fix source install on Ubuntu by making sure we have xml2-config package
- Remove options that are no longer recognised by the php installer when installing from source
- Remove matchers as we no longer require them with a modern ChefDK
4.5.0 (2017-07-11)
- Add reinstall chefspec matcher
- Switch from maintainers files to a simple readme section
- Remove allow_call_time_pass_reference and y2k_compliance config on Debian/Ubuntu as no supported PHP version supports it
- Initial Debian 9 support
4.4.0 (2017-06-27)
- Add a reinstall action to php_pear
- Added additional specs for package installs on different platforms
4.3.0 (2017-06-27)
- Remove fallback default php attributes that were used if we were on an unsupported platform. If we don't know the platform we don't support it and we should fail until we add proper support
- Add a few attributes needed for fpm support on opensuse. This is a work in progress to get full PHP support on opensuse
- Install xml deps and avoid using xml cookbook since it's been deprecated
- Expand the php_pear testing
- Remove double logging and log the correct package name in php_pear resource
- Cleanup readme example codes, improve formatting and remove references to LWRPs as they are just resources now
4.2.0 (2017-05-30)
- Make sure package intalls, php-fpm, and source installs work on Amazon linux
- Avoid symlink warning in the converges
- Simplify the package install logic
- Rename the inspec test to match the suite name so it actually runs
- Test on FreeBSD 11 / Amazon Linux
- Install 5.6.30 by default on source installs
4.1.0 (2017-05-30)
- Remove class_eval usage and require Chef 12.7+
4.0.0 (2017-04-20)
- Fix pear_channel resource to not fail on Chef 12.5 and 12.6
- Remove support for RHEL 5 as it is now EOL
- Resolve Amazon Linux failures on Chef 13
- Convert fpm_pool to a custom resource
- Fix php_pear failures on Chef 13
- Remove non-functional support for Windows
- Remove redundant Ubuntu version checks in the php_pear provider
- Expand testing to test all of the resources
3.1.1 (2017-04-20)
- Use the cookbook attribute as the default value of pear_channel pear property to provide better platform support
3.1.0 (2017-04-10)
- Use multi-package installs on supported platform_family(rhel debian suse amazon)
- Use a SPDX standardized license string in the metadata
- Update specs for the new Fauxhai data
3.0.0 (2017-03-27)
- Converted pear_channel LWRP into custom resource
- Removed use of pear node attribute from pear_channel resource
- Fix cookstyle issue with missing line on metadata.rb
- Clean up kitchen.dokken.yml file to eliminate duplication of testing suites.
- Eliminate duplicated resource from test cookbook that is in the default recipe.
- Rename php-test to standard cookbook testing cookbook of "test"
- Remove EOL ubuntu platform logic
NOTE Windows package installation is currently broken.
2.2.1 (2017-02-21)
- Fix double definition of ['php']['packages'] for rhel.
2.2.0 (2016-12-12)
- Use multipackage for installs to speed up chef runs
- Use all CPUs when building from source
- Remove need for apt/yum in testing
- Add opensuse to the metadata
- Migrate to inspec for integration testing
2.1.1 (2016-09-15)
- Fix recompile un-pack php creates
- Resolve cookstyle warnings
2.1.0 (2016-09-14)
- Fix source php version check
- Require Chef 12.1 not 12.0
2.0.0 (2016-09-07)
- Require Chef 12+
- Remove the dependency on the Windows cookbook which isn't necessary with Chef 12+
1.10.1 (2016-08-30)
- [fix] bug fixes related with Ubuntu 16.04 and PHP 7 support
- adding validator to listen attribute
- Fix node.foo.bar warnings
v1.10.0 (2016-07-27)
- PR #167 Preventing user specified pool of www from being deleted at the end of the chef run on the first install
- PR #122 Add recipe for php module_imap
- PR #172 Fix uninstall action for resource php_fpm_pool
v1.9.0 (2016-05-12)
Special thanks to @ThatGerber for getting the PR for this release together
- Added support for Ubuntu 16.04 and PHP 7
- Added support for different listen user/groups with FPM
- Cleaned up resource notification in the pear_channel provider to simplify code
- Fixed Ubuntu 14.04+ not being able to find the GMP library
v1.8.0 (2016-02-25)
- Bumped the source install default version from 5.5.9 to 5.6.13
- Added a chefignore file to limit the files uploaded to the Chef server
- Added source_url and issues_url to the metadata.rb
- Added additional Chefspec matchers
- Added a Chef standard rubocop.yml file and resolved warnings
- Added serverspec for integration testing
- Remove legacy cloud Test Kitchen configs
- Added testing in Travis CI with kitchen-docker
- Added additional test suites to the Test Kitchen config
- Updated contributing and testing documentation
- Updated testing gem dependencies to the latest
- Added maintainers.md and maintainers.toml files
- Remove gitter chat from the readme
- Add cookbook version badge to the readme
- Added Fedora as a supported platform in the readme
- Add missing cookbook dependencies to the readme
v1.7.2 (2015-8-24)
- Correct spelling in fpm_pool_start_servers (was servres)
v1.7.1 (2015-8-17)
- Correct permissions on ext_conf_dir folder (644 -> 755)
v1.7.0 (2015-7-31)
- NOTICE - This version changes the way the ['php']['directives'] is placed into configuration files. Quotes are no longer automatically placed around these aditional directives. Please take care when rolling out this version.
- Allow additional PHP FPM config
- Add recipe to recompile PHP from source
- Move source dependencies to attributes file
- Misc bug fixes
v1.6.0 (2015-7-6)
- Added ChefSpec matchers
- Added basic PHP-FPM Support (Pre-Release)
- Added support for FreeBSD
- Updated cookbook to use MySQL 6.0 cookbook
- Update cookbook to use php5enmod on supported platforms
- Allow users to override php-mysql package
v1.5.0 (2014-10-06)
- Adding package_options attribute, utilizing in package resource
v1.4.6 (2014-03-19)
- [COOK-4436] - Test this cookbook, not yum. Also test Fedora 20.
- [COOK-4427] - Add oracle as supported operating system
v1.4.4 (2014-03-12)
- [COOK-4393] - Fix convergence bug in source install
v1.4.2 (2014-02-27)
[COOK-4300] - Simplified and fixed pear/pecl logic. [Fixes #56 / #57]
v1.4.0 (2014-02-27)
[COOK-3639] - Allow users to specify php.ini source template
v1.3.14 (2014-02-21)
Bug
- COOK-4186 - Upgrade_package concatenates an empty version string when version is not set or is empty.
v1.3.12 (2014-01-28)
Fix github issue 'Cannot find a resource for preferred_state'
v1.3.10
Fixing my stove
v1.3.8
Version bump to ensure artifact sanity
v1.3.6
Version bump for toolchain
v1.3.4
Adding platform_family check to include_recipe in source.rb
v1.3.2
Fixing style cops. Updating test harness
v1.3.0
Bug
- COOK-3479 - Added Windows support to PHP
- COOK-2909 - Warnings about Chef::Exceptions::ShellCommandFailed is deprecated
v1.2.6
Bug
- COOK-3628 - Fix PHP download URL
- COOK-3568 - Fix Test Kitchen tests
-
COOK-3402 - When the
ext_dir
setting is present, configure php properly for the source recipe - COOK-2926 - Fix pear package detection when installing specific version
v1.2.4
Improvement
Bug
-
COOK-2378 - Fix
php_pear
for libevent
v1.2.2
Bug
- [COOK-3050]:
lib_dir
declared in wrong place for redhat - [COOK-3102]: remove fileinfo recipe from php cookbook
Improvement
- [COOK-3101]: use a method to abstract range of "el 5" versions in php recipes
v1.2.0
Improvement
- [COOK-2516]: Better support for SUSE distribution for php cookbook
- [COOK-3035]: update php::source to install 5.4.15 by default
Bug
- [COOK-2463]: PHP PEAR Provider Installs Most Recent Version, Without Respect to Preferred State
- [COOK-2514]: php_pear: does not handle more exotic version strings
v1.1.8
- [COOK-1998] - Enable override of PHP packages in attributes
v1.1.6
- [COOK-2324] - adds Oracle linux support
v1.1.4
- [COOK-2106] -
php_pear
cannot find available packages
v1.1.2
- [COOK-1803] - use better regexp to match package name
- [COOK-1926] - support Amazon linux
v1.1.0
- [COOK-543] - php.ini template should be configurable
- [COOK-1067] - support for PECL zend extensions
- [COOK-1193] - update package names for EPEL 6
- [COOK-1348] - rescue Mixlib::ShellOut::ShellCommandFailed (chef 0.10.10)
- [COOK-1465] - fix pear extension template
v1.0.2
- [COOK-993] Add mhash-devel to centos php source libs
- [COOK-989] - bump version of php to 5.3.10
- Also download the .tar.gz instead of .tar.bz2 as bzip2 may not be in the base OS (e.g., CentOS 6 minimal)
Collaborator Number Metric
5.1.0 passed this metric
Contributing File Metric
5.1.0 passed this metric
Foodcritic Metric
5.1.0 passed this metric
License Metric
5.1.0 passed this metric
No Binaries Metric
5.1.0 passed this metric
Testing File Metric
5.1.0 passed this metric
Version Tag Metric
5.1.0 passed this metric
5.1.0 passed this metric
5.1.0 passed this metric
Foodcritic Metric
5.1.0 passed this metric
License Metric
5.1.0 passed this metric
No Binaries Metric
5.1.0 passed this metric
Testing File Metric
5.1.0 passed this metric
Version Tag Metric
5.1.0 passed this metric
5.1.0 passed this metric
5.1.0 passed this metric
No Binaries Metric
5.1.0 passed this metric
Testing File Metric
5.1.0 passed this metric
Version Tag Metric
5.1.0 passed this metric
5.1.0 passed this metric
5.1.0 passed this metric
Version Tag Metric
5.1.0 passed this metric
5.1.0 passed this metric