Remove non-functional part of ::Storage::DBI::Sybase::_ping
[dbsrgits/DBIx-Class.git] / lib / DBIx / Class / Storage / DBI / Sybase.pm
CommitLineData
f68f4d44 1package DBIx::Class::Storage::DBI::Sybase;
2
3use strict;
4use warnings;
ddcc02d1 5use DBIx::Class::_Util 'dbic_internal_try';
ed7ab0f4 6use Try::Tiny;
fd323bf1 7use namespace::clean;
2ad62d97 8
057db5ce 9use base qw/DBIx::Class::Storage::DBI/;
d867eeda 10
11=head1 NAME
12
95787afe 13DBIx::Class::Storage::DBI::Sybase - Base class for drivers using
14L<DBD::Sybase>
d867eeda 15
16=head1 DESCRIPTION
17
057db5ce 18This is the base class/dispatcher for Storage's designed to work with
19L<DBD::Sybase>
d867eeda 20
21=head1 METHODS
22
23=cut
f68f4d44 24
b0c42bbc 25sub _rebless { shift->_determine_connector_driver('Sybase') }
26
27sub _get_rdbms_name {
d867eeda 28 my $self = shift;
d29565e0 29
ddcc02d1 30 dbic_internal_try {
b0c42bbc 31 my $name = $self->_get_dbh->selectrow_arrayref('sp_server_info @attribute_id=1')->[2];
d867eeda 32
b0c42bbc 33 if ($name) {
34 $name =~ s/\W/_/gi;
057db5ce 35
b0c42bbc 36 # saner class name
37 $name = 'ASE' if $name eq 'SQL_Server';
d867eeda 38 }
b0c42bbc 39
40 $name; # RV
41 } catch {
42 $self->throw_exception("Unable to establish connection to determine database type: $_")
43 };
d867eeda 44}
45
c1e5a9ac 46sub _init {
47 # once the driver is determined see if we need to insert the DBD::Sybase w/ FreeTDS fixups
48 # this is a dirty version of "instance role application", \o/ DO WANT Moo \o/
49 my $self = shift;
aca3b4c3 50 if (! $self->isa('DBIx::Class::Storage::DBI::Sybase::FreeTDS') and $self->_using_freetds) {
c1e5a9ac 51 require DBIx::Class::Storage::DBI::Sybase::FreeTDS;
52
53 my @isa = @{mro::get_linear_isa(ref $self)};
54 my $class = shift @isa; # this is our current ref
55
56 my $trait_class = $class . '::FreeTDS';
57 mro::set_mro ($trait_class, 'c3');
58 no strict 'refs';
59 @{"${trait_class}::ISA"} = ($class, 'DBIx::Class::Storage::DBI::Sybase::FreeTDS', @isa);
60
61 bless ($self, $trait_class);
62
63 Class::C3->reinitialize() if DBIx::Class::_ENV_::OLD_MRO;
64
65 $self->_init(@_);
66 }
67
68 $self->next::method(@_);
69}
70
057db5ce 71sub _ping {
d867eeda 72 my $self = shift;
d867eeda 73
057db5ce 74 my $dbh = $self->_dbh or return 0;
0a9a9955 75
057db5ce 76 local $dbh->{RaiseError} = 1;
77 local $dbh->{PrintError} = 0;
0a9a9955 78
82c5f916 79 ( dbic_internal_try { $dbh->do('select 1'); 1 } )
80 ? 1
81 : 0
82 ;
0a9a9955 83}
84
057db5ce 85sub _set_max_connect {
d867eeda 86 my $self = shift;
057db5ce 87 my $val = shift || 256;
d867eeda 88
057db5ce 89 my $dsn = $self->_dbi_connect_info->[0];
d867eeda 90
057db5ce 91 return if ref($dsn) eq 'CODE';
81a10d8d 92
057db5ce 93 if ($dsn !~ /maxConnect=/) {
94 $self->_dbi_connect_info->[0] = "$dsn;maxConnect=$val";
95 my $connected = defined $self->_dbh;
96 $self->disconnect;
97 $self->ensure_connected if $connected;
d867eeda 98 }
99}
100
aca3b4c3 101# Whether or not DBD::Sybase was compiled against FreeTDS. If false, it means
102# the Sybase OpenClient libraries were used.
103sub _using_freetds {
d867eeda 104 my $self = shift;
c1e5a9ac 105 return ($self->_get_dbh->{syb_oc_version}||'') =~ /freetds/i;
a964a928 106}
107
aca3b4c3 108# Either returns the FreeTDS version against which DBD::Sybase was compiled,
109# 0 if can't be determined, or undef otherwise
110sub _using_freetds_version {
111 my $inf = shift->_get_dbh->{syb_oc_version};
112 return undef unless ($inf||'') =~ /freetds/i;
113 return $inf =~ /v([0-9\.]+)/ ? $1 : 0;
114}
115
a2bd3796 116=head1 FURTHER QUESTIONS?
f68f4d44 117
a2bd3796 118Check the list of L<additional DBIC resources|DBIx::Class/GETTING HELP/SUPPORT>.
47d9646a 119
a2bd3796 120=head1 COPYRIGHT AND LICENSE
f68f4d44 121
a2bd3796 122This module is free software L<copyright|DBIx::Class/COPYRIGHT AND LICENSE>
123by the L<DBIx::Class (DBIC) authors|DBIx::Class/AUTHORS>. You can
124redistribute it and/or modify it under the same terms as the
125L<DBIx::Class library|DBIx::Class/COPYRIGHT AND LICENSE>.
f68f4d44 126
127=cut
a2bd3796 128
1291;
130