The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package Pg::CLI::pg_restore;
{
  $Pg::CLI::pg_restore::VERSION = '0.10';
}

use Moose;

use namespace::autoclean;

use MooseX::Params::Validate qw( validated_list );
use MooseX::SemiAffordanceAccessor;
use MooseX::Types::Moose qw( ArrayRef Bool Str );

with qw( Pg::CLI::Role::Connects Pg::CLI::Role::Executable );

sub _database_at_end {
    return 0;
}

sub _run_options {
    my $self     = shift;
    my $database = shift;

    return ( '-d', $database );
}

__PACKAGE__->meta()->make_immutable();

1;

# ABSTRACT: Wrapper for the F<pg_restore> utility

__END__

=pod

=head1 NAME

Pg::CLI::pg_restore - Wrapper for the F<pg_restore> utility

=head1 VERSION

version 0.10

=head1 SYNOPSIS

  my $pg_restore = Pg::CLI::pg_restore->new(
      username => 'foo',
      password => 'bar',
      host     => 'pg.example.com',
      port     => 5433,
  );

  $pg_restore->run(
      database => 'database',
      options  => [ '-C' ],
  );

  my $sql;
  $pg_restore->run(
      database => 'database',
      options  => ['-C'],
      stdin    => \$sql,
  );

=head1 DESCRIPTION

This class provides a wrapper for the F<pg_restore> utility.

=head1 METHODS

This class provides the following methods:

=head2 Pg::CLI::pg_restore->new( ... )

The constructor accepts a number of parameters:

=over 4

=item * executable

The path to F<pg_restore>. By default, this will look for F<pg_restore> in your path
and throw an error if it cannot be found.

=item * username

The username to use when connecting to the database. Optional.

=item * password

The password to use when connecting to the database. Optional.

=item * host

The host to use when connecting to the database. Optional.

=item * port

The port to use when connecting to the database. Optional.

=item * require_ssl

If this is true, then the C<PGSSLMODE> environment variable will be set to
"require" when connecting to the database.

=back

=head2 $pg_restore->run( database => ..., options => [ ... ] )

This method restores the specified database. Any values passed in C<options> will
be passed on to pg_restore.

This method also accepts optional C<stdin>, C<stdout>, and C<stderr>
parameters. These parameters can be any defined value that could be passed as
the relevant parameter to L<IPC::Run3>'s C<run3> subroutine.

Notably, you can capture the restore output in a scalar reference for the
C<stdout> output.

=head2 $pg_restore->version()

Returns a the three part version as a string.

=head2 $pg_restore->two_part_version()

Returns the first two decimal numbers in the version.

=head1 BUGS

See L<Pg::CLI> for bug reporting details.

=head1 AUTHOR

Dave Rolsky <autarch@urth.org>

=head1 COPYRIGHT AND LICENSE

This software is Copyright (c) 2013 by Dave Rolsky.

This is free software, licensed under:

  The Artistic License 2.0 (GPL Compatible)

=cut