- for my $name ( keys %$updates ){
- if($object->can($name)){
- my $value = $updates->{$name};
-
- # updating relations that that should be done before the row is inserted into the database
- # like belongs_to
- if( $object->result_source->has_relationship($name)
- and
- ref $value
- ){
- my $info = $object->result_source->relationship_info( $name );
- if( $info and not $info->{attrs}{accessor} eq 'multi'
- and
- _master_relation_cond( $object, $info->{cond}, $self->_get_pk_for_related( $name ) )
- ){
- my $related_result = $object->related_resultset( $name );
- my $sub_object = $related_result->recursive_update( $value );
- $object->set_from_related( $name, $sub_object );
- }
- }
- # columns and other accessors
- elsif( $object->result_source->has_column($name)
- or
- !$object->can( 'set_' . $name )
- ) {
- $object->$name($value);
- }
- }
- #warn Dumper($object->{_column_data}); use Data::Dumper;
+ # first update columns and other accessors - so that later related records can be found
+ for my $name ( keys %columns ){
+ $object->$name( $updates->{$name} );
+ }
+ for my $name ( keys %pre_updates ){
+ my $info = $object->result_source->relationship_info( $name );
+ $self->update_relation( $name, $updates, $object, $info );