You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
terraform/vendor/github.com/go-chef/chef
Donald Guy 36b4b1acb2
vendor: update go-chef, fixes #8382
10 years ago
..
LICENSE Vendor all dependencies w/ Godep 10 years ago
README.md Vendor all dependencies w/ Godep 10 years ago
acl.go Vendor all dependencies w/ Godep 10 years ago
authentication.go Vendor all dependencies w/ Godep 10 years ago
build.sh vendor: update go-chef, fixes #8382 10 years ago
client.go Vendor all dependencies w/ Godep 10 years ago
cookbook.go vendor: update go-chef, fixes #8382 10 years ago
databag.go Vendor all dependencies w/ Godep 10 years ago
debug.go Vendor all dependencies w/ Godep 10 years ago
doc.go Vendor all dependencies w/ Godep 10 years ago
environment.go Vendor all dependencies w/ Godep 10 years ago
http.go vendor: update go-chef, fixes #8382 10 years ago
node.go vendor: update go-chef, fixes #8382 10 years ago
principal.go vendor: update go-chef, fixes #8382 10 years ago
reader.go Vendor all dependencies w/ Godep 10 years ago
release.go Vendor all dependencies w/ Godep 10 years ago
role.go vendor: update go-chef, fixes #8382 10 years ago
run_list.go Vendor all dependencies w/ Godep 10 years ago
sandbox.go Vendor all dependencies w/ Godep 10 years ago
search.go Vendor all dependencies w/ Godep 10 years ago
wercker.yml vendor: update go-chef, fixes #8382 10 years ago

README.md

Stories in Ready Build Status Coverage Status

Chef Server API Client Library in Golang

This is a Library that you can use to write tools to interact with the chef server.

Install

go get github.com/go-chef/chef

Test

go get -t github.com/go-chef/chef
go test -v github.com/go-chef/chef

SSL

If you run into an SSL verification problem when trying to connect to a ssl server with self signed certs setup your config object with SkipSSL: true

Usage

This example is setting up a basic client that you can use to interact with all the service endpoints (clients, nodes, cookbooks, etc.) More usage examples can be found in the examples directory.

 package main
 
 import (
 	"encoding/json"
 	"fmt"
 	"io/ioutil"
 	"log"
 	"os"
 
 	"github.com/go-chef/chef"
 )
 
 func main() {
 	// read a client key
 	key, err := ioutil.ReadFile("key.pem")
 	if err != nil {
 		fmt.Println("Couldn't read key.pem:", err)
     os.Exit(1)
   }
 
 	// build a client
 	client, err := chef.NewClient(&chef.Config{
 		Name: "foo",
 		Key:  string(key),
 		// goiardi is on port 4545 by default. chef-zero is 8889
 		BaseURL: "http://localhost:4545",
 	})
 	if err != nil {
 		fmt.Println("Issue setting up client:", err)
   }
 
   // List Cookbooks
   cookList, err := client.Cookbooks.List()
   if err != nil {
     fmt.Println("Issue listing cookbooks:", err)
   }
 
   // Print out the list
   fmt.Println(cookList)
 }

CONTRIBUTING

If you feel like contributing, great! Just fork the repo, make your improvements, and submit a pull request. Tests would, of course, be appreciated. Adding tests where there are no tests currently would be even more appreciated. At least, though, try and not break anything worse than it is. Test coverage has improved, but is still an ongoing concern.

AUTHORS

Jesse Nelson @spheromak
AJ Christensen @fujin
Brad Beam @bradbeam
Kraig Amador @bigkraig

Copyright 2013-2014, Jesse Nelson

LICENSE

Like many Chef ecosystem programs, go-chef/chef is licensed under the Apache 2.0 License. See the LICENSE file for details.

Chef is copyright (c) 2008-2014 Chef, Inc. and its various contributors.

Thanks go out to the fine folks of Opscode and the Chef community for all their hard work.