Use ruby-build for Mastodon, update cookbooks

This uses the ruby_build provider for Mastodon, installing Ruby 2.4.1
currently. It also updates some other cookbooks and the runlists.
This commit is contained in:
2017-04-17 11:40:31 +02:00
parent 4530190df6
commit 54332db8de
96 changed files with 2830 additions and 903 deletions

View File

@@ -1,7 +1,34 @@
# homebrew Cookbook CHANGELOG
This file is used to list changes made in each version of the homebrew cookbook.
## 3.0.0 (2016-12-19)
- The homebrew package provider has been removed from this cookbook. It ships with Chef 12.0+. This cookbook now requires a minimum of Chef 12.1 or later.
- This cookbook no longer depends on build-essential as it wasn't using it directly
- Properly define the chefspec matchers
- Add chef_version metadata and remove OS X server which isn't an actual platform from ohai
- Don't grab homebrew_go script if homebrew is already installed.
- Add ability to disable sending analytics data via a new attribute
- Move testing to a test cookbook to make it easier to expand in the future. Also convert integration tests to InSpec from ServerSpec
## 2.1.2 (2016-09-07)
- Allow passing custom options to brew packages
## 2.1.1 (2016-09-06)
- Run chefspecs as OS X
- Update cask recipe to not create /opt/homebrew-cask and /opt/homebrew-cask/Caskroom
- Update tests
## v2.1.0 (2016-03-29)
- Make homebrew install script url configurable
- Make package_info more efficient
## v2.0.5 (2016-01-25)
- Updated execute resources to pass in the HOME/USER environmental variables so homebrew commands are properly executed
- Removed redundant code from recipes and providers
- Removed brew-cask installation and the upgade execute that are no longer necessary
@@ -9,22 +36,27 @@ This file is used to list changes made in each version of the homebrew cookbook.
- Updated creation of /opt/homebrew-cask to be recursive in case /opt hasn't been created yet
## v2.0.4 (2016-01-20)
- Use the officially supported method of querying homebrew data vs. unsupported internal APIs
- Fixed environmental variables in the homebrew command execution
## v2.0.3 (2015-12-09)
- Fixed poor name matching in determining if a cask had been installed already, which prevented some casks from installing
## v2.0.2 (2015-12-04)
- Prevents casks from installing on every chef run
## v2.0.1 (2015-12-03)
- Fixed already-installed casks breaking builds
## v2.0.0 (2015-12-01)
- Removed all Chef 10 compatibility code
- #77 Update the tap provider to properly notify on changes
- #73 Allow specifying versions (or HEAD) of formulas (see readme for usage)
- 77 Update the tap provider to properly notify on changes
- 73 Allow specifying versions (or HEAD) of formulas (see readme for usage)
- Updated contributing, testing, and maintainers docs
- Updated contents of chefignore and .gitignore files
- Updated development dependencies in the Gemfile
@@ -32,109 +64,136 @@ This file is used to list changes made in each version of the homebrew cookbook.
- Added Chef standard rubocop file and resolved all warnings
- Added super metadata for Supermarket
- Added testing in Travis CI
- #75 Fix Chefspecs to properly run on Linux hosts (like Travis)
- 75 Fix Chefspecs to properly run on Linux hosts (like Travis)
- Add Rakefile for simplified testing
- Resolved all foodcritic warnings
## v1.13.0 (2015-06-23)
- #72 Massage Chef12HomebrewUser.find_homebrew_uid into username
- #69 Add options to cask
- 72 Massage Chef12HomebrewUser.find_homebrew_uid into username
- 69 Add options to cask
## v1.12.0 (2015-01-29)
- #67 Add attribute and recipe for installing homebrew taps
- 67 Add attribute and recipe for installing homebrew taps
## v1.11.0 (2015-01-12)
- #59 Update Homebrew Cask if auto-update attribute is true
- #52 Manage Homebrew Cask's install directories
- #56 Fix check for existing casks
- #61 Fix owner class for Chef 12
- 59 Update Homebrew Cask if auto-update attribute is true
- 52 Manage Homebrew Cask's install directories
- 56 Fix check for existing casks
- 61 Fix owner class for Chef 12
- Depend on build-essential cookbook 2.1.2+ to support OS X 10.10
- #64, #66 add and fix ChefSpec tests for default recipe
- 64, #66 add and fix ChefSpec tests for default recipe
## v1.10.0 (2014-12-09)
- #55 This cookbook no longer sets its `homebrew_package` as the
- 55 This cookbook no longer sets its `homebrew_package` as the
- `package` provider for OS X when running under Chef 12
- List CHEF as the maintainer instead of Chef.
## v1.9.2 (2014-10-09)
Bug Fixes:
- #57 Update url per homebrew error: Upstream, the homebrew project
- 57 Update url per homebrew error: Upstream, the homebrew project
- has changed the URL for the installation script. All users of this
- cookbook are advised to update to this version.
## v1.9.0 (2014-07-29)
Improvements:
- #35 Modernize the cask provider (use why run mode, inline resources)
- #43 Use `brew cask list` to determine if casks are installed
- #45 Add `default_action` and print warning messages on earlier
- 35 Modernize the cask provider (use why run mode, inline resources)
- 43 Use `brew cask list` to determine if casks are installed
- 45 Add `default_action` and print warning messages on earlier
- versions of Chef (10.10)
New Features:
- #44 Add `:install` and `:uninstall` actions and alias previous `:cask`,
- 44 Add `:install` and `:uninstall` actions and alias previous `:cask`,
- `:uncask` actions to them
Bug Fixes:
- #27 Fix name for taps adding the `/homebrew` prefix
- #28 Set `RUBYOPT` to `nil` so Chef can execute in a bundle (bundler
- 27 Fix name for taps adding the `/homebrew` prefix
- 28 Set `RUBYOPT` to `nil` so Chef can execute in a bundle (bundler
- sets `RUBYOPT` and this can cause issues when running the
- underlying `brew` commands)
- #40 Fix regex for cask to match current homebrew conventions
- #42 Fix attribute for list of formulas to match the README and
- 40 Fix regex for cask to match current homebrew conventions
- 42 Fix attribute for list of formulas to match the README and
- maintain backward compat for 6 day old version
## v1.8.0 (2014-07-23)
- Add recipes to install an array of formulas/casks
## v1.7.2 (2014-06-26)
- Implement attribute to control auto-update
## v1.7.0 (2014-06-26)
#38 - Add homebrew::cask recipe
# 38 - Add homebrew::cask recipe
## v1.6.6 (2014-05-29)
- [COOK-3283] Use homebrew_owner for cask and tap
- [COOK-4670] homebrew_tap provider is not idempotent
- [COOK-4671] Syntax Error in README
## v1.6.4 (2014-05-08)
- Fixing cask provider correctly this time. "brew cask list"
## v1.6.2 (2014-05-08)
- Fixing typo in cask provider: 's/brew brew/brew/'
## v1.6.0 (2014-04-23)
- [COOK-3960] Added LWRP for brew cask
- [COOK-4508] Add ChefSpec matchers for homebrew_tap
- [COOK-4566] Guard against "HEAD only" formulae
## v1.5.4
- [COOK-4023] Fix installer script's URL.
- Fixing up style for rubocop
## v1.5.2
- [COOK-3825] setting $HOME on homebrew_package
## v1.5.0
### Bug
- **[COOK-3589](https://tickets.chef.io/browse/COOK-3589)** - Add homebrew as the default package manager on OS X Server
## v1.4.0
### Bug
- **[COOK-3283](https://tickets.chef.io/browse/COOK-3283)** - Support running homebrew cookbook as root user, with sudo, or a non-privileged user
## v1.3.2
- [COOK-1793] - use homebrew "go" script to install homebrew
- [COOK-1821] - Discovered version using Homebrew Formula factory fails check that verifies that version is a String
- [COOK-1843] - Homebrew README.md contains non-ASCII characters, triggering same issue as COOK-522
## v1.3.0
- [COOK-1425] - use new json output format for formula
- [COOK-1578] - Use shell_out! instead of popen4
## v1.2.0
Chef Software has taken maintenance of this cookbook as the original author has other commitments. This is the initial release with Chef Software as maintainer.
Changes in this release:
- [pull/2] - support for option passing to brew
- [pull/3] - add brew upgrade and control return value from command
- [pull/9] - added LWRP for "brew tap"

View File

@@ -1,19 +1,15 @@
<!-- This is a generated file. Please do not edit directly -->
# Maintainers
This file lists how this cookbook project is maintained. When making changes to the system, this
file tells you who needs to review your patch - you need a simple majority of maintainers
for the relevant subsystems to provide a :+1: on your pull request. Additionally, you need
to not receive a veto from a Lieutenant or the Project Lead.
Check out [How Cookbooks are Maintained](https://github.com/chef-cookbooks/community_cookbook_documentation/blob/master/CONTRIBUTING.MD)
for details on the process and how to become a maintainer or the project lead.
This file lists how this cookbook project is maintained. When making changes to the system, this file tells you who needs to review your patch - you need a review from an existing maintainer for the cookbook to provide a :+1: on your pull request. Additionally, you need to not receive a veto from a Lieutenant or the Project Lead.
Check out [How Cookbooks are Maintained](https://github.com/chef-cookbooks/community_cookbook_documentation/blob/master/CONTRIBUTING.MD) for details on the process and how to become a maintainer or the project lead.
# Project Maintainer
* [Tim Smith](https://github.com/tas50)
# Maintainers
* [Jennifer Davis](https://github.com/sigje)
* [Sean OMeara](https://github.com/someara)
* [Tim Smith](https://github.com/tas50)
* [Thom May](https://github.com/thommay)

View File

@@ -1,36 +1,29 @@
# Homebrew Cookbook
[![Build Status](https://travis-ci.org/chef-cookbooks/homebrew.svg?branch=master)](http://travis-ci.org/chef-cookbooks/homebrew) [![Cookbook Version](https://img.shields.io/cookbook/v/homebrew.svg)](https://supermarket.chef.io/cookbooks/homebrew)
This cookbook installs [Homebrew](http://mxcl.github.com/homebrew/) and under Chef 11 and earlier versions, its package provider replaces MacPorts as the _default package provider_ for the package resource on OS X systems.
This cookbook installs [Homebrew](http://brew.sh/) and provides resources for working with taps and casks
# Requirements
Chef 12: The package provider is not necessary on Chef 12, as the default [OS X package provider](https://github.com/chef/chef-rfc/blob/master/rfc016-homebrew-osx-package-provider.md) is homebrew.
## Requirements
Chef <= 11: The package provider will be set as the default provider for OS X.
### Platforms
## Prerequisites
In order for this recipe to work, your userid must own `/usr/local`. This is outside the scope of the cookbook because it's possible 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:
- macOS
```bash
sudo chown -R `whoami`:staff /usr/local
```
### Chef
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 project.
- Chef 12.1+
**Note** This cookbook _only_ supports installing in `/usr/local`. While the Homebrew project itself allows for alternative installations, this cookbook doesn't.
### Cookbooks
## Platform
- Mac OS X (10.6+)
- none
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.
## Attributes
## Cookbooks
- build-essential: homebrew itself doesn't work well if XCode is not installed.
# Attributes
- `node['homebrew']['owner']` - The user that will own the Homebrew installation and packages. Setting this will override the default behavior which is to use the non-privileged user that has invoked the Chef run (or the `SUDO_USER` if invoked with sudo). The default is `nil`.
- `node['homebrew']['auto-update']` - Whether the default recipe should automatically update homebrew each run or not. The default is `true` to maintain compatibility. Set to false or nil to disable. Note that disabling this feature may cause formula to not work.
- `node['homebrew']['formulas']` - An Array of formula that should be installed using homebrew by default, used only in the `homebrew::install_formulas` recipe.
- `node['homebrew']['auto-update']` - Whether the default recipe should automatically update Homebrew each run or not. The default is `true` to maintain compatibility. Set to false or nil to disable. Note that disabling this feature may cause formula to not work.
- `node['homebrew']['formulas']` - An Array of formula that should be installed using Homebrew by default, used only in the `homebrew::install_formulas` recipe.
- To install the most recent version, include just the recipe name: `- simple_formula`
- To install a specific version, specify both its name and version:
@@ -46,38 +39,21 @@ The only platform supported by Homebrew itself at the time of this writing is Ma
head: true
```
- To provide other options, specify both its name and options
```
- name: formula-with-options
options: --with-option-1 --with-other-option
```
- `node['homebrew']['casks']` - An Array of casks that should be installed using brew cask by default, used only in the `homebrew::install_casks` recipe.
- `node['homebrew']['taps']` - An Array of taps that should be installed using brew tap by default, used only in the `homebrew::install_taps` recipe.
# Resources and Providers
This cookbook includes a package resource provider to use homebrew. Under Chef 12+, this is not necessary, and the code doesn't actually get used on Chef 12+. This was preserved to maintain backwards compatiblity with older versions of Chef.
## Resources (provider)
## package / homebrew\_package
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.
### homebrew_tap
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".
### Examples
```ruby
package 'mysql' do
action :install
end
homebrew_package 'mysql'
package 'mysql' do
provider Chef::Provider::Package::Homebrew
end
package 'wireshark' do
options '--with-qt --devel'
end
```
### homebrew\_tap
LWRP for `brew tap`, a Homebrew command used to add additional formula repositories. From the `brew` man page:
```text
@@ -99,12 +75,14 @@ homebrew_tap 'homebrew/dupes' do
end
```
## homebrew\_cask
### homebrew_cask
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.
[homebrew-cask on GitHub](https://github.com/caskroom/homebrew-cask)
### Prerequisites
#### Prerequisites
You must have the homebrew-cask repository tapped.
```ruby
@@ -136,11 +114,13 @@ Default action is `:cask` which installs the Application binary . Use `:uncask`
[View the list of available Casks](https://github.com/caskroom/homebrew-cask/tree/master/Casks)
# Usage
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 recipe also ensures that Homebrew is installed and up to date if the auto update attribute (above) is true (default).
# License and Authors
## License and Authors
This cookbook is maintained by CHEF. The original author, maintainer and copyright holder is Graeme Mathieson. The cookbook remains licensed under the Apache License version 2.
[Original blog post by Graeme](https://woss.name/articles/converging-your-home-directory-with-chef/)
@@ -151,7 +131,7 @@ Author:: Joshua Timberman ([joshua@chef.io](mailto:joshua@chef.io))
```text
Copyright:: 2011, Graeme Mathieson
Copyright:: 2012-2015, Chef Software, Inc. <legal@chef.io>
Copyright:: 2012-2016, Chef Software, Inc. <legal@chef.io>
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.

View File

@@ -1,10 +1,10 @@
#
# Author:: Joshua Timberman (<jtimberman@chef.io>)
# Author:: Graeme Mathieson (<mathie@woss.name>)
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Attributes:: default
#
# Copyright 2011-2013, Chef Software, Inc.
# Copyright:: 2011-2016, 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.
@@ -18,9 +18,12 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
default['homebrew']['owner'] = nil
# only used if auto detection fails
default['homebrew']['owner'] = nil # only used if auto detection fails
default['homebrew']['auto-update'] = true
default['homebrew']['casks'] = []
default['homebrew']['formulas'] = node['homebrew']['formula'] || []
default['homebrew']['taps'] = []
default['homebrew']['installer']['url'] = 'https://raw.githubusercontent.com/Homebrew/install/master/install'
default['homebrew']['installer']['checksum'] = nil
default['homebrew']['enable-analytics'] = true

View File

@@ -1,10 +1,10 @@
#
# Author:: Joshua Timberman (<jtimberman@chef.io>)
# Author:: Graeme Mathieson (<mathie@woss.name>)
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Libraries:: homebrew_mixin
#
# Copyright 2011-2013, Chef Software, Inc.
# Copyright:: 2011-2016, 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.
@@ -18,26 +18,19 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Include the mixin from Chef 12 if its defined, when we get to the
# #homebrew_owner method below...
class Chef12HomebrewUser
include Chef::Mixin::HomebrewUser if defined?(Chef::Mixin::HomebrewUser)
include Chef::Mixin::HomebrewUser
end
module Homebrew
# Homebrew
module Mixin
def homebrew_owner
if defined?(Chef::Mixin::HomebrewUser)
begin
require 'etc'
@homebrew_owner ||= ::Etc.getpwuid(Chef12HomebrewUser.new.find_homebrew_uid).name
rescue Chef::Exceptions::CannotDetermineHomebrewOwner
@homebrew_owner ||= calculate_owner
end
else
@homebrew_owner ||= calculate_owner
end
require 'etc'
@homebrew_owner ||= ::Etc.getpwuid(Chef12HomebrewUser.new.find_homebrew_uid).name
rescue Chef::Exceptions::CannotDetermineHomebrewOwner
@homebrew_owner ||= calculate_owner
end
private
@@ -45,7 +38,7 @@ module Homebrew
def calculate_owner
owner = homebrew_owner_attr || sudo_user || current_user
if owner == 'root'
fail Chef::Exceptions::User,
raise Chef::Exceptions::User,
"Homebrew owner is 'root' which is not supported. " \
"To set an explicit owner, please set node['homebrew']['owner']."
end
@@ -65,3 +58,6 @@ module Homebrew
end
end
end
Chef::Resource.send(:include, Homebrew::Mixin)
Chef::Recipe.send(:include, Homebrew::Mixin)

View File

@@ -1,102 +0,0 @@
#
# Author:: Joshua Timberman (<jtimberman@chef.io>)
# Author:: Graeme Mathieson (<mathie@woss.name>)
# Cookbook Name:: homebrew
# Libraries:: homebrew_package
#
# Copyright 2011-2013, 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.
#
# cookbook libraries are unconditionally included if the cookbook is
# present on a node. This approach should avoid creating this class if
# the node already has Chef::Provider::Package::Homebrew, such as with
# Chef 12.
# https://github.com/chef/chef-rfc/blob/master/rfc016-homebrew-osx-package-provider.md
unless defined?(Chef::Provider::Package::Homebrew) && Chef::Platform.find('mac_os_x', nil)[:package] == Chef::Provider::Package::Homebrew
require 'chef/provider/package'
require 'chef/resource/package'
require 'chef/platform'
require 'chef/mixin/shell_out'
class Chef
class Provider
class Package
# Package
class Homebrew < Package
# Homebrew packagex
include Chef::Mixin::ShellOut
include ::Homebrew::Mixin
def load_current_resource
@current_resource = Chef::Resource::Package.new(@new_resource.name)
@current_resource.package_name(@new_resource.package_name)
@current_resource.version(current_installed_version)
@current_resource
end
def install_package(name, _version)
brew('install', @new_resource.options, name)
end
def upgrade_package(name, _version)
brew('upgrade', name)
end
def remove_package(name, _version)
brew('uninstall', @new_resource.options, name)
end
# Homebrew doesn't really have a notion of purging, so just remove.
def purge_package(name, version)
@new_resource.options = ((@new_resource.options || '') << ' --force').strip
remove_package(name, version)
end
protected
def brew(*args)
get_response_from_command("brew #{args.join(' ')}")
end
def current_installed_version
versions = package_info['installed'].map { |v| v['version'] }
versions.join(' ') unless versions.empty?
end
def candidate_version
package_info['versions']['stable'] ? package_info['versions']['stable'].to_s : package_info['versions'].find { |_k, v| v if v.is_a?(String) }
end
def package_info
require 'json'
JSON.parse(brew('info', @new_resource.package_name, '--json=v1'))[0]
end
def get_response_from_command(command)
require 'etc'
home_dir = Etc.getpwnam(homebrew_owner).dir
Chef::Log.debug "Executing '#{command}' as #{homebrew_owner}"
output = shell_out!(command, user: homebrew_owner, environment: { 'USER' => homebrew_owner, 'HOME' => home_dir, 'RUBYOPT' => nil })
output.stdout
end
end
end
end
end
Chef::Platform.set platform: :mac_os_x_server, resource: :package, provider: Chef::Provider::Package::Homebrew
Chef::Platform.set platform: :mac_os_x, resource: :package, provider: Chef::Provider::Package::Homebrew
end

View File

@@ -1,20 +1,5 @@
if defined?(ChefSpec)
def install_homebrew_package(pkg)
ChefSpec::Matchers::ResourceMatcher.new(:homebrew_package, :install, pkg)
end
def upgrade_homebrew_package(pkg)
ChefSpec::Matchers::ResourceMatcher.new(:homebrew_package, :upgrade, pkg)
end
def remove_homebrew_package(pkg)
ChefSpec::Matchers::ResourceMatcher.new(:homebrew_package, :remove, pkg)
end
def purge_homebrew_package(pkg)
ChefSpec::Matchers::ResourceMatcher.new(:homebrew_package, :purge, pkg)
end
ChefSpec.define_matcher :homebrew_package
def tap_homebrew_tap(tap)
ChefSpec::Matchers::ResourceMatcher.new(:homebrew_tap, :tap, tap)

File diff suppressed because one or more lines are too long

View File

@@ -1,8 +1,8 @@
#
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Providers:: cask
#
# Copyright 2011-2015, Chef Software, Inc.
# Copyright:: 2011-2016, 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.

View File

@@ -1,10 +1,10 @@
#
# Author:: Joshua Timberman (<jtimberman@chef.io>)
# Author:: Graeme Mathieson (<mathie@woss.name>)
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Providers:: tap
#
# Copyright 2011-2015, Chef Software, Inc.
# Copyright:: 2011-2016, 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.

View File

@@ -1,8 +1,8 @@
#
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Recipes:: cask
#
# Copyright 2014-2015, Chef Software, Inc <legal@chef.io>
# Copyright:: 2014-2016, Chef Software, Inc <legal@chef.io>
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
@@ -16,23 +16,11 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
Chef::Resource.send(:include, Homebrew::Mixin)
homebrew_tap 'caskroom/cask'
directory '/Library/Caches/Homebrew/Casks' do
owner homebrew_owner
mode 00775
mode '775'
only_if { ::Dir.exist?('/Library/Caches/Homebrew') }
end
directory '/opt/homebrew-cask' do
owner homebrew_owner
mode 00775
recursive true
end
directory '/opt/homebrew-cask/Caskroom' do
owner homebrew_owner
mode 00775
end

View File

@@ -1,10 +1,10 @@
#
# Author:: Joshua Timberman (<jtimberman@chef.io>)
# Author:: Graeme Mathieson (<mathie@woss.name>)
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Recipe:: default
#
# Copyright 2011-2015, Chef Software, Inc.
# Copyright:: 2011-2016, 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.
@@ -19,16 +19,15 @@
# limitations under the License.
#
Chef::Resource.send(:include, Homebrew::Mixin)
Chef::Recipe.send(:include, Homebrew::Mixin)
homebrew_go = "#{Chef::Config[:file_cache_path]}/homebrew_go"
Chef::Log.debug("Homebrew owner is '#{homebrew_owner}'")
remote_file homebrew_go do
source 'https://raw.githubusercontent.com/Homebrew/install/master/install'
mode 00755
source node['homebrew']['installer']['url']
checksum node['homebrew']['installer']['checksum'] unless node['homebrew']['installer']['checksum'].nil?
mode '755'
not_if { ::File.exist? '/usr/local/bin/brew' }
end
execute 'install homebrew' do
@@ -38,6 +37,13 @@ execute 'install homebrew' do
not_if { ::File.exist? '/usr/local/bin/brew' }
end
execute 'set analytics' do
environment lazy { { 'HOME' => ::Dir.home(homebrew_owner), 'USER' => homebrew_owner } }
user homebrew_owner
command "/usr/local/bin/brew analytics #{node['homebrew']['enable-analytics'] ? 'on' : 'off'}"
only_if { shell_out('/usr/local/bin/brew analytics state', user: homebrew_owner).stdout.include?('enabled') != node['homebrew']['enable-analytics'] }
end
if node['homebrew']['auto-update']
package 'git' do
not_if 'which git'

View File

@@ -1,8 +1,8 @@
#
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Recipe:: install_casks
#
# Copyright 2014-2015, Chef Software, Inc <legal@chef.io>
# Copyright:: 2014-2016, Chef Software, Inc <legal@chef.io>
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.

View File

@@ -1,8 +1,8 @@
#
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Recipes:: install_casks
#
# Copyright 2014-2015, Chef Software, Inc <legal@chef.io>
# Copyright:: 2014-2016, Chef Software, Inc <legal@chef.io>
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
@@ -21,8 +21,10 @@ include_recipe 'homebrew'
node['homebrew']['formulas'].each do |formula|
if formula.class == Chef::Node::ImmutableMash
formula_options = formula.fetch(:options, '')
formula_options += ' --HEAD' if formula.fetch(:head, false)
package formula.fetch(:name) do
options '--HEAD' if formula.fetch(:head, false)
options formula_options.strip
version formula['version'] if formula.fetch(:version, false)
end
else

View File

@@ -1,8 +1,8 @@
#
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Recipes:: install_taps
#
# Copyright 2015, Chef Software, Inc <legal@chef.io>
# Copyright:: 2015-2016, Chef Software, Inc <legal@chef.io>
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.

View File

@@ -1,10 +1,10 @@
#
# Author:: Joshua Timberman (<jtimberman@chef.io>)
# Author:: Graeme Mathieson (<mathie@woss.name>)
# Cookbook Name:: homebrew
# Cookbook:: homebrew
# Resources:: tap
#
# Copyright 2011-2013, Chef Software, Inc.
# Copyright:: 2011-2016, 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.