skeleton insert code
[dbsrgits/DBIx-Data-Store-old.git] / lib / DBIx / Data / Store / CRUD.pm
CommitLineData
65b76960 1package DBIx::Data::Store::CRUD;
2
3use Moose;
4use Method::Signatures::Simple;
5
6has raw_store => (is => 'ro', required => 1); # DBIx::Data::Store object
7
8foreach my $type (qw(select insert update delete)) {
9 has "${type}_sql" => (is => 'ro', predicate => "has_${type}_sql");
3347c67e 10 has "${type}_argument_order" => (is => 'ro', default => sub { [] });
65b76960 11}
12
3a2e7c1c 13has 'insert_command_constructor' => (is => 'ro');
14
3347c67e 15has "select_column_order" => (is => 'ro');
16
65b76960 17method new_select_command ($args) {
18 die "$self->has_select_sql" unless $self->has_select_sql;
3347c67e 19 $self->raw_store->new_stream_command(
20 $self->select_sql,
21 $self->_unwrap_args_for(select => $args),
22 $self->select_column_order
23 );
24}
25
26method _unwrap_args_for ($type, $args) {
27 [ @{$args}{@{$self->${\"${type}_argument_order"}}} ]
28}
29
3a2e7c1c 30method _new_command ($builder, $type, $args) {
3347c67e 31 my $has_meth = "has_${type}_sql";
32 die "${self}->${has_meth}" unless $self->$has_meth;
3a2e7c1c 33 $self->$builder(
3347c67e 34 $self->${\"${type}_sql"},
3a2e7c1c 35 $self->_unwrap_args_for($type => $args),
36 );
37}
38
39method _new_call_command ($type, $args) {
40 $self->_new_command(
41 sub { shift->raw_store->new_call_command(@_) },
42 $type => $args,
3347c67e 43 );
65b76960 44}
45
46method new_insert_command ($args) {
3a2e7c1c 47 my $builder = $self->insert_command_constructor;
48 $builder
49 ? $self->_new_command($builder => insert => $args)
50 : $self->_new_call_command(insert => $args);
65b76960 51}
52
53method new_update_command ($args) {
3347c67e 54 $self->_new_call_command(update => $args);
65b76960 55}
56
57method new_delete_command ($args) {
3347c67e 58 $self->_new_call_command(delete => $args);
65b76960 59}
60
61__PACKAGE__->meta->make_immutable;
62
631;