make action Any for the time being
[dbsrgits/SQL-Translator-2.0-ish.git] / lib / SQL / Translator / Object / Trigger.pm
index 2f98b41..6696e62 100644 (file)
@@ -1,12 +1,55 @@
-package SQL::Translator::Object::Trigger;
-use Moose;
-use MooseX::Types::Moose qw(Str);
-use SQL::Translator::Types qw();
-extends 'SQL::Translator::Object';
+use MooseX::Declare;
+class SQL::Translator::Object::Trigger {
+    use MooseX::Types::Moose qw(Any ArrayRef HashRef Str);
+    use MooseX::AttributeHelpers;
+    use SQL::Translator::Types qw(Column);
+    extends 'SQL::Translator::Object';
+    
+    has 'name' => (
+        is => 'ro',
+        isa => Str,
+        required => 1
+    );
 
-has 'name' => (is => 'ro', isa => Str, required => 1);
+    has 'columns' => (
+        metaclass => 'Collection::Hash',
+        is => 'rw',
+        isa => HashRef[Column],
+        provides => {
+            exists => 'exists_column',
+            keys   => 'column_ids',
+            values => 'get_columns',
+            get    => 'get_column',
+            set    => 'add_column',
+        },
+        default => sub { my %hash = (); tie %hash, 'Tie::IxHash'; return \%hash },
+    );
 
-no Moose;
-__PACKAGE__->meta->make_immutable;
+    has 'on_table' => (
+        is => 'rw', 
+        isa => Str,
+        required => 1
+    );
 
-1;
+    has 'action' => (
+        is => 'rw',
+        isa => Any
+    );
+
+    has 'perform_action_when' => (
+        is => 'rw',
+        isa => Str,
+        required => 1
+    );
+
+    has 'database_events' => (
+        is => 'rw',
+        isa => ArrayRef,
+        required => 1
+    );
+
+    around add_column(Column $column) { $self->$orig($column->name, $column) }
+
+    method get_fields { $self->get_columns }
+    method fields { $self->column_ids }
+}