-package SQL::Translator::Object::Trigger;
-use Moose;
-use MooseX::Types::Moose qw(Str);
-use SQL::Translator::Types qw();
+use MooseX::Declare;
+class SQL::Translator::Object::Trigger extends SQL::Translator::Object {
+ use MooseX::Types::Moose qw(Any ArrayRef HashRef Str);
+ use MooseX::MultiMethods;
+ use SQL::Translator::Types qw(Column Schema Table);
-has 'name' => (is => 'ro', isa => Str, required => 1);
+ has 'schema' => (
+ is => 'rw',
+ isa => Schema,
+ weak_ref => 1,
+ );
-1;
+ has 'table' => (
+ is => 'rw',
+ isa => Table,
+ weak_ref => 1,
+ );
+
+ has 'name' => (
+ is => 'ro',
+ isa => Str,
+ required => 1
+ );
+
+ has 'columns' => (
+ traits => ['Hash'],
+ is => 'rw',
+ isa => HashRef[Column],
+ handles => {
+ exists_column => 'exists',
+ column_ids => 'keys',
+ get_columns => 'values',
+ get_column => 'get',
+ add_column => 'set',
+ clear_columns => 'clear',
+ },
+ default => sub { my %hash = (); tie %hash, 'Tie::IxHash'; return \%hash },
+ );
+
+ has 'on_table' => (
+ is => 'rw',
+ isa => Str,
+ required => 1,
+# trigger => sub { my ($self, $new, $old) = @_; $self->table($self->schema->get_table($new)) },
+ );
+
+ has 'action' => (
+ is => 'rw',
+ isa => Any
+ );
+
+ has 'perform_action_when' => (
+ is => 'rw',
+ isa => Str,
+ required => 1
+ );
+
+ has '_database_events' => (
+ is => 'rw',
+ traits => ['Array'],
+ isa => ArrayRef,
+ handles => {
+ _database_eventss => 'elements',
+ add_database_event => 'push',
+ remove_last_database_option => 'pop',
+ },
+ default => sub { [] },
+ required => 1,
+ );
+
+ around add_column(Column $column) { $self->$orig($column->name, $column) }
+
+ multi method database_events(Str $database_event) { $self->add_database_event($database_event); $self->database_events }
+ multi method database_events(ArrayRef $database_events) { $self->add_database_event($_) for @$database_events; $self->database_events }
+ multi method database_events { wantarray ? $self->_database_events : $self->_database_events }
+}