NAME

Pantry::Model::Node - Pantry data model for nodes

VERSION

version 0.006

SYNOPSIS

my $pantry = Pantry::Model::Pantry->new;
my $node = $pantry->node("foo.example.com");

$node->append_to_run_list('recipe[nginx]');
$node->set_attribute('nginx.port' => 80);
$node->save;

DESCRIPTION

Models the configuration data for a specific server.

ATTRIBUTES

name

This attribute is the canonical name of the node, generally a fully-qualified domain name

run_list

This attribute is provided by the Pantry::Role::Runlist role and holds a list of recipes (or roles) to be configured by chef-solo.

attributes

This attribute holds node attribute data as key-value pairs. Keys may be separated by a period to indicate nesting (literal periods must be escaped by a backslash). Values should be scalars or array references.

pantry_host

This optional attribute holds an alternate hostname or IP address to use for the SSH connection within pantry sync. In all other respects, the node will still be referenced by the name attribute.

pantry_port

This optional attribute holds an alternate port number to use for the SSH connection within pantry sync.

pantry_user

This optional attribute holds an alternate user for the SSH connection within pantry sync. (The default is root.) This user must have password-less sudo permissions.

METHODS

set_attribute

$node->set_attribute("nginx.port", 80);

Sets the node attribute for the given key to the given value.

get_attribute

my $port = $node->get_attribute("nginx.port");

Returns the node attribute for the given key.

delete_attribute

$node->delete_attribute("nginx.port");

Deletes the node attribute for the given key.

save

Saves the node to a file in the pantry. If the private _path attribute has not been set, an exception is thrown.

AUTHOR

David Golden <dagolden@cpan.org>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2011 by David Golden.

This is free software, licensed under:

The Apache License, Version 2.0, January 2004