use Moose;
-sub config {
- return {provision_backend => 'Oyster::Provision::Rackspace'};
-}
+has 'api_username' => ( is => 'ro', isa => 'Str');
+has 'api_password' => ( is => 'ro', isa => 'Str');
+has 'name' => ( is => 'ro', isa => 'Str');
+has 'size' => ( is => 'ro', isa => 'Str');
+has 'image' => ( is => 'ro', isa => 'Str');
+has 'pub_ssh' => ( is => 'ro', isa => 'Str');
+has 'provision_backend' => (is => 'rw', isa => 'Str', required => 1, default => 'Oyster::Provision::Rackspace' );
+
+# TODO after provision, add the server's name with "oyster-" prefixed to the
+# user's ~/.ssh/ssh_config file so any part of Oyster can ssh there
+# passwordlessly for deploying or whatnot
sub BUILD {
my $self = shift;
- my $role = $self->config()->{provision_backend};
+ my $role = $self->provision_backend;
eval "use $role";
"$role"->meta->apply($self);