0.01
No commit activity in last 3 years
No release in over 3 years
Extenstions for berkshelf
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

~> 1.3.1
>= 0
 Project Readme

Berkshelf Ext

Berkshelf extensions to add features to berkshelf.

Usage

Via Bundler

If using via bundler, just add an entry in the Gemfile:

gem 'berkshelf_ext'

and it will auto inject itself.

Direct

Since bundler does some special loading that rubygems proper does not, we can't auto-inject ourselves in. Instead, just call the custom executable:

berks_ext

Which will add the extensions to berkshelf, and then initialize it as usual.

Current extensions

These extensions are auto loaded by default.

  • Resolution via nested berksfiles (nested_berksfiles)[1]
  • Proper berksfile path when loading berksfiles (berksfile_loader_context)[2]
  • Proper dependency resolution (dependency_chains)[3]
  • Do not include recommends entries in cookbook dependencies (non_recommends_depends)

Prevent extension loading

You can explicitly define what is allowed or not allowed to load via environment variables

  • BERKSHELF_EXT_EXCEPT="nested_berksfiles"
  • BERKSHELF_EXT_ONLY="nested_berksfiles,berksfile_loader_context"

Current addons

Addons are extensions that must be explicitly enabled via environment variable:

  • BERKSHELF_EXT_ADDONS="knife_uploader"

It is important to note that these addons will generally make use of Chef internals to do things.

Available addons

  • Knife based cookbook uploading (disables Ridley)[4]
  • Faster dependency resolution via faster cached cookbook handling (fast_resolution)

Load all the things!

If you want to just load everything that is available without explicitly defining all the addons, just set the everything env variable:

  • BERKSHELF_EXT_EVERYTHING="true"

References

  1. berkshelf/berkshelf#304
  2. berkshelf/berkshelf#304
  3. berkshelf/berkshelf#302
  4. berkshelf/berkshelf#291

Contributors

Info