Chef - Bibliotecas

As bibliotecas no Chef fornecem um local para encapsular a lógica compilada para que as receitas do livro de receitas permaneçam organizadas e limpas.

Criação da biblioteca

Step 1 - Crie um método auxiliar na biblioteca do livro de receitas.

[email protected]:~/chef-repo $ subl cookbooks/my_cookbook/libraries/ipaddress.rb 
class Chef::Recipe 
def netmask(ipaddress) 
IPAddress(ipaddress).netmask 
end 
end

Step 2 - Use o método auxiliar.

[email protected]:~/chef-repo $ subl cookbooks/my_cookbook/recipes/default.rb 
ip = '10.10.0.0/24' 
mask = netmask(ip) # here we use the library method 
Chef::Log.info("Netmask of #{ip}: #{mask}")

Step 3 - Carregue o livro de receitas modificado para o Chef Server.

[email protected]:~/chef-repo $ knife cookbook upload my_cookbook 
Uploading my_cookbook [0.1.0]

Testando a Biblioteca

[email protected] $ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-01-18T14:38:26+00:00] INFO: Netmask of 10.10.0.0/24: 
255.255.255.0 
...TRUNCATED OUTPUT...

Método de trabalho

O código da biblioteca Chef pode abrir a classe chef :: Recipe e adicionar novos métodos conforme feito na Etapa 1. Esta etapa não é a mais limpa, mas a maneira mais simples de fazê-lo.

class Chef::Recipe 
def netmask(ipaddress) 
... 
end 
end

Melhores Práticas

Assim que abrirmos a classe chef :: recipe, haverá mudanças que ela ficará poluída. Como prática recomendada, é sempre a melhor maneira de introduzir uma nova subclasse dentro da biblioteca e definir um método como método de classe. Isso evita puxar o namespace chef :: recipe.

[email protected]:~/chef-repo $ subl cookbooks/my_cookbook/libraries/ipaddress.rb 
class Chef::Recipe::IPAddress 
def self.netmask(ipaddress) 
IPAddress(ipaddress).netmask 
end 
end

Podemos usar o método dentro da receita como

IPAddress.netmask(ip)