This cookbook installs Homebrew and replaces MacPorts as the default package provider for the package resource on OS X systems.
This cookbook is now maintained by Opscode. The original author, maintainer and copyright holder is Graeme Mathieson. The cookbook remains licensed under the Apache License version 2.
In order for this recipe to work, your userid must own /usr/local
.
This is outside the scope of the cookbook because it's anticipated
that you'll run the cookbook as your own user, not root and you'd have
to be root to take ownership of the directory. Easiest way to get
started:
sudo chown -R `whoami`:staff /usr/local
Bear in mind that this will take ownership of the entire folder and its
contents, so if you've already got stuff in there (eg MySQL owned by a
mysql
user) you'll need to be a touch more careful. This is a
recommendation from the Homebrew
- Mac OS X (10.6+)
The only platform supported by Homebrew itself at the time of this writing is Mac OS X. It should work fine on Server edition as well, and on platforms that Homebrew supports in the future.
This cookbook provides a package provider called homebrew_package
which will install/remove packages using Homebrew. This becomes the
default provider for package
if your platform is Mac OS X.
As this extends the built-in package resource/provider in Chef, it has all the resource attributes and actions available to the package resource. However, a couple notes:
- Homebrew itself doesn't have a notion of "upgrade" per se. The "upgrade" action will simply perform an install, and if the Homebrew Formula for the package is newer, it will upgrade.
- Likewise, Homebrew doesn't have a purge, but the "purge" action will act like "remove".
package "mysql" do
action :install
end
homebrew_package "mysql"
package "mysql" do
provider Chef::Provider::Package::Homebrew
end
LWRP for brew tap
, a Homebrew command used to add additional formula
repositories. From the brew
man page:
tap [tap]
Tap a new formula repository from GitHub, or list existing taps.
tap is of the form user/repo, e.g. brew tap homebrew/dupes.
Default action is :tap
which enables the repository. Use :untap
to
disable a tapped repository.
homebrew_tap "homebrew/dupes"
homebrew_tap "homebrew/dupes" do
action :untap
end
LWRP for brew cask
, a Homebrew-style CLI workflow for the administration
of Mac applications distributed as binaries. It's implemented as a homebrew
"external command" called cask.
You must have the homebrew-cask repository tapped.
homebrew_tap 'phinze/cask'
And then install the homebrew cask package before using this LWRP.
package "brew-cask" do
action :install
end
homebrew_cask "google-chrome"
homebrew_tap "google-chrome" do
action :uncask
end
Default action is :cask
which installs the Application binary . Use :uncask
to
uninstall a an Application.
View the list of available Casks
We strongly recommend that you put "recipe[homebrew]" in your node's run list, to ensure that it is available on the system and that Homebrew itself gets installed. Putting an explicit dependency in the metadata will cause the cookbook to be downloaded and the library loaded, thus resulting in changing the package provider on Mac OS X, so if you have systems you want to use the default (Mac Ports), they would be changed to Homebrew.
The default itself ensures that Homebrew is installed and up to date.
Author:: Graeme Mathieson ([email protected]) Author:: Joshua Timberman ([email protected])
Copyright:: 2011, Graeme Mathieson Copyright:: 2012, Opscode, Inc [email protected]
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.