#
# Copyright 2014 MongoDB, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Encapsulate index list operation; returns array ref of index documents
use version;
our $VERSION = 'v1.1.0'; # TRIAL
use Moo;
InstanceOf
Str
);
has db_name => (
is => 'ro',
required => 1,
isa => Str,
);
has coll_name => (
is => 'ro',
required => 1,
isa => Str,
);
has client => (
is => 'ro',
required => 1,
isa => InstanceOf ['MongoDB::MongoClient'],
);
with $_ for qw(
MongoDB::Role::_PrivateConstructor
MongoDB::Role::_ReadOp
MongoDB::Role::_CommandCursorOp
);
sub execute {
my ( $self, $link, $topology ) = @_;
my $res =
$link->accepts_wire_version(3)
? $self->_command_list_indexes( $link, $topology )
: $self->_legacy_list_indexes( $link, $topology );
return $res;
}
sub _command_list_indexes {
my ( $self, $link, $topology ) = @_;
my $op = MongoDB::Op::_Command->_new(
db_name => $self->db_name,
query => Tie::IxHash->new( listIndexes => $self->coll_name, cursor => {} ),
query_flags => {},
read_preference => $self->read_preference,
bson_codec => $self->bson_codec,
);
my $res = try {
$op->execute( $link, $topology );
}
catch {
if ( $_->$_isa("MongoDB::DatabaseError") ) {
return undef if $_->code == NAMESPACE_NOT_FOUND();
}
die $_;
};
return $res ? $self->_build_result_from_cursor($res) : $self->_empty_query_result($link);
}
sub _legacy_list_indexes {
my ( $self, $link, $topology ) = @_;
my $ns = $self->db_name . "." . $self->coll_name;
my $op = MongoDB::Op::_Query->_new(
modifiers => {},
allow_partial_results => 0,
batch_size => 0,
comment => '',
cursor_type => 'non_tailable',
limit => 0,
max_time_ms => 0,
no_cursor_timeout => 0,
oplog_replay => 0,
projection => undef,
skip => 0,
sort => undef,
db_name => $self->db_name,
coll_name => 'system.indexes',
bson_codec => $self->bson_codec,
client => $self->client,
read_preference => $self->read_preference,
filter => Tie::IxHash->new( ns => $ns ),
);
return $op->execute( $link, $topology );
}
1;