X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDBIx%2FClass%2FStorage%2FDBI%2FReplicated%2FPool.pm;h=e5fa1a10f14c620d49c16372a5c6823a48fcd971;hb=b09e9528b306fe3394ad0b588c36ebbc2b89c6fb;hp=c31cd4d8c6e9bc8c4e612dc07c670d968bd165b3;hpb=0bd8e0585b592d2583f28b6922b47afa78559cf4;p=dbsrgits%2FDBIx-Class-Historic.git diff --git a/lib/DBIx/Class/Storage/DBI/Replicated/Pool.pm b/lib/DBIx/Class/Storage/DBI/Replicated/Pool.pm index c31cd4d..e5fa1a1 100644 --- a/lib/DBIx/Class/Storage/DBI/Replicated/Pool.pm +++ b/lib/DBIx/Class/Storage/DBI/Replicated/Pool.pm @@ -138,6 +138,16 @@ has 'replicants' => ( }, ); +has next_unknown_replicant_id => ( + is => 'rw', + metaclass => 'Counter', + isa => Int, + default => 1, + provides => { + inc => 'inc_unknown_replicant_id' + }, +); + =head1 METHODS This class defines the following methods. @@ -159,32 +169,45 @@ sub connect_replicants { $connect_info = [ $connect_info ] if reftype $connect_info ne 'ARRAY'; - my $replicant = $self->connect_replicant($schema, $connect_info); - my $connect_coderef = (reftype($connect_info->[0])||'') eq 'CODE' ? $connect_info->[0] : (reftype($connect_info->[0])||'') eq 'HASH' && $connect_info->[0]->{dbh_maker}; my $dsn; - if (not $connect_coderef) { - $dsn = $connect_info->[0]; - $dsn = $dsn->{dsn} if (reftype($dsn)||'') eq 'HASH'; - } - else { -# yes this is evil, but it only usually happens once + my $replicant = do { +# yes this is evil, but it only usually happens once (for coderefs) +# this will fail if the coderef does not actually DBI::connect no warnings 'redefine'; my $connect = \&DBI::connect; local *DBI::connect = sub { $dsn = $_[1]; goto $connect; }; - $connect_coderef->(); + $self->connect_replicant($schema, $connect_info); + }; + + my $key; + + if (!$dsn) { + if (!$connect_coderef) { + $dsn = $connect_info->[0]; + $dsn = $dsn->{dsn} if (reftype($dsn)||'') eq 'HASH'; + } + else { + # all attempts to get the DSN failed + $key = "UNKNOWN_" . $self->next_unknown_replicant_id; + $self->inc_unknown_replicant_id; + } + } + if ($dsn) { + $replicant->dsn($dsn); + ($key) = ($dsn =~ m/^dbi\:.+\:(.+)$/i); } - $replicant->dsn($dsn); - my ($key) = ($dsn =~ m/^dbi\:.+\:(.+)$/i); + $replicant->id($key); $self->set_replicant($key => $replicant); + push @newly_created, $replicant; }