Repository is archived
No commit activity in last 3 years
No release in over 3 years
A knife plugin to support the PagerDuty Chef workflow
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 0
~> 11
~> 3

Runtime

~> 12
~> 1
 Project Readme

Deprecated

This repository is no longer maintained.

PagerDuty::ChefServer::Sync

This gem provides a Knife plugin (knife pd sync) which supports the PagerDuty Chef workflow.

PagerDuty Chef Workflow

PagerDuty uses a monolithic Chef repo, and does not bother with cookbook versioning. Instead, every time we make a change to our Chef repo, we delete all changed cookbooks and re-upload them, maintaining parity between our Git repo and Chef server. There are many reasons that we have adopted this workflow, though I'm too lazy to stroll through memory lane at the moment. You can learn more about it here.

This plugin supports the aforementioned workflow. It integrates directly with Berkshelf. Invoking this plugin will:

  • Run berks vendor
  • Pull cookbook manifest from Chef server
  • Look for local changes
  • Loop through all changed cookbooks, first deleting all versions of it on Chef server, then uploading the version on disk
  • Upload all data bags
  • Upload all environments
  • Upload all roles

Installation

Simply include this gem in the Gemfile in your Chef repo:

gem 'pagerduty-pd_sync'

Usage

knife pd sync

License

Apache 2

Contributing

  1. Fork it ( https://github.com/PagerDuty/pd-sync-chef/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request