Assumptions: You have a working knife configuration.
The initial user story that prompted me to figure out how to interact with Chef Server REST API was this:
- As a System Administrator
- I want to be able to see what IP addresses are being used
- In order for me to correctly assign a free IP to a new machine.
In order to access the Chef Server programmatically I first had to figure out authentication. Unfortunately, I couldn’t find any good examples of how to actually do this. The Chef Server API wiki page has some basic requirements and concepts, but no concrete examples.
However, it gave me a good starting place—the Chef::REST library. The REST library that comes bundled with Chef in every version > 0.9.0. Let’s just make sure that we actually have that version:
Now that we know the version is ok we’re basically done. All we have to do is load the knife configuration file and then we can use the built in rest library. Here’s the code I ended up with:
1 2 3 4 5 6 7
Now you can do something like:
1 2 3
So now we just print each IP address that is being used and we can figure out the next free IP address in any given range. That completes this user story!
There was only one gotcha in the whole process. Trying to print a node just throws an ArgumentError: