Linux iad1-shared-b7-18 6.6.49-grsec-jammy+ #10 SMP Thu Sep 12 23:23:08 UTC 2024 x86_64
Apache
: 67.205.6.31 | : 216.73.216.47
Cant Read [ /etc/named.conf ]
8.2.29
fernandoquevedo
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
usr /
share /
perl5 /
MongoDB /
Op /
[ HOME SHELL ]
Name
Size
Permission
Action
_Aggregate.pm
5.73
KB
-rw-r--r--
_BatchInsert.pm
3.4
KB
-rw-r--r--
_BulkWrite.pm
15.12
KB
-rw-r--r--
_ChangeStream.pm
6.22
KB
-rw-r--r--
_Command.pm
4.25
KB
-rw-r--r--
_Count.pm
2.08
KB
-rw-r--r--
_CreateIndexes.pm
3.26
KB
-rw-r--r--
_Delete.pm
3.45
KB
-rw-r--r--
_Distinct.pm
2.67
KB
-rw-r--r--
_DropCollection.pm
1.85
KB
-rw-r--r--
_DropDatabase.pm
1.48
KB
-rw-r--r--
_DropIndexes.pm
2.38
KB
-rw-r--r--
_EndTxn.pm
2.68
KB
-rw-r--r--
_Explain.pm
2.85
KB
-rw-r--r--
_FSyncUnlock.pm
2.63
KB
-rw-r--r--
_FindAndDelete.pm
2.82
KB
-rw-r--r--
_FindAndUpdate.pm
3.34
KB
-rw-r--r--
_GetMore.pm
2.78
KB
-rw-r--r--
_InsertOne.pm
2.58
KB
-rw-r--r--
_KillCursors.pm
4.29
KB
-rw-r--r--
_ListCollections.pm
4.16
KB
-rw-r--r--
_ListIndexes.pm
3.28
KB
-rw-r--r--
_ParallelScan.pm
1.86
KB
-rw-r--r--
_Query.pm
16.89
KB
-rw-r--r--
_RenameCollection.pm
1.73
KB
-rw-r--r--
_Update.pm
6.36
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : _Explain.pm
# Copyright 2015 - present 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 # # http://www.apache.org/licenses/LICENSE-2.0 # # 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. use strict; use warnings; package MongoDB::Op::_Explain; # Encapsulate code path for explain commands/queries use version; our $VERSION = 'v2.2.2'; use Moo; use MongoDB::Op::_Command; use Types::Standard qw( InstanceOf ); use Tie::IxHash; use boolean; use namespace::clean; has query => ( is => 'ro', required => 1, isa => InstanceOf['MongoDB::Op::_Query'], ); with $_ for qw( MongoDB::Role::_PrivateConstructor MongoDB::Role::_CollectionOp MongoDB::Role::_ReadOp ); sub execute { my ( $self, $link, $topology ) = @_; my $res = $link->supports_explain_command ? $self->_command_explain( $link, $topology ) : $self->_legacy_explain( $link, $topology ); return $res; } sub _command_explain { my ( $self, $link, $topology ) = @_; my $cmd = Tie::IxHash->new( @{ $self->query->_as_command } ); # XXX need to standardize error here if ($self->query->has_hint) { # cannot use hint on explain, throw error MongoDB::Error->throw( message => "cannot use 'hint' with 'explain'", ); } my $op = MongoDB::Op::_Command->_new( db_name => $self->db_name, query => [ explain => $cmd, @{ $self->read_concern->as_args( $self->session ) } ], query_flags => {}, read_preference => $self->read_preference, bson_codec => $self->bson_codec, session => $self->session, monitoring_callback => $self->monitoring_callback, ); my $res = $op->execute( $link, $topology ); return $res->{output}; } sub _legacy_explain { my ( $self, $link, $topology ) = @_; my $orig_query = $self->query; my $cloned_opts = { %{ $orig_query->options } }; $cloned_opts->{explain} = 1; # per David Storch, drivers *must* send a negative limit to instruct # the query planner analysis module to add a LIMIT stage. For older # explain implementations, it also ensures a cursor isn't left open. $cloned_opts->{limit} = ( -1 * abs( $cloned_opts->{limit} ) ); my $new_query = MongoDB::Op::_Query->_new( %$orig_query, # override options from original options => $cloned_opts ); return $new_query->execute( $link, $topology )->next; } 1;
Close