⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.74
Server IP:
41.128.143.86
Server:
Linux host.raqmix.cloud 6.8.0-1025-azure #30~22.04.1-Ubuntu SMP Wed Mar 12 15:28:20 UTC 2025 x86_64
Server Software:
Apache
PHP Version:
8.3.23
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
usr
/
local
/
psa
/
phpMyAdmin
/
libraries
/
classes
/
View File Name :
Replication.php
isMySql() && $dbi->getVersion() >= 80022 || $dbi->isMariaDB() && $dbi->getVersion() >= 100501) { return $dbi->tryQuery($action . ' REPLICA ' . $control . ';', $link); } return $dbi->tryQuery($action . ' SLAVE ' . $control . ';', $link); } /** * Changes primary for replication replica * * @param string $user replication user on primary * @param string $password password for the user * @param string $host primary's hostname or IP * @param int $port port, where mysql is running * @param array $pos position of mysql replication, array should contain fields File and Position * @param bool $stop shall we stop replica? * @param bool $start shall we start replica? * @param int $link mysql link * * @return ResultInterface|false output of CHANGE MASTER mysql command */ public function replicaChangePrimary( $user, $password, $host, $port, array $pos, bool $stop, bool $start, int $link ) { global $dbi; if ($stop) { $this->replicaControl('STOP', null, $link); } if ($dbi->isMySql() && $dbi->getVersion() >= 80023) { $out = $dbi->tryQuery( 'CHANGE REPLICATION SOURCE TO ' . 'SOURCE_HOST=\'' . $host . '\',' . 'SOURCE_PORT=' . ($port * 1) . ',' . 'SOURCE_USER=\'' . $user . '\',' . 'SOURCE_PASSWORD=\'' . $password . '\',' . 'SOURCE_LOG_FILE=\'' . $pos['File'] . '\',' . 'SOURCE_LOG_POS=' . $pos['Position'] . ';', $link ); } else { $out = $dbi->tryQuery( 'CHANGE MASTER TO ' . 'MASTER_HOST=\'' . $host . '\',' . 'MASTER_PORT=' . ($port * 1) . ',' . 'MASTER_USER=\'' . $user . '\',' . 'MASTER_PASSWORD=\'' . $password . '\',' . 'MASTER_LOG_FILE=\'' . $pos['File'] . '\',' . 'MASTER_LOG_POS=' . $pos['Position'] . ';', $link ); } if ($start) { $this->replicaControl('START', null, $link); } return $out; } /** * This function provides connection to remote mysql server * * @param string $user mysql username * @param string $password password for the user * @param string $host mysql server's hostname or IP * @param int $port mysql remote port * @param string $socket path to unix socket * * @return mixed mysql link on success */ public function connectToPrimary( $user, $password, $host = null, $port = null, $socket = null ) { global $dbi; $server = []; $server['user'] = $user; $server['password'] = $password; $server['host'] = Core::sanitizeMySQLHost($host); $server['port'] = $port; $server['socket'] = $socket; // 5th parameter set to true means that it's an auxiliary connection // and we must not go back to login page if it fails return $dbi->connect(DatabaseInterface::CONNECT_AUXILIARY, $server); } /** * Fetches position and file of current binary log on primary * * @param int $link mysql link * * @return array an array containing File and Position in MySQL replication * on primary server, useful for {@see Replication::replicaChangePrimary()}. * @phpstan-return array{'File'?: string, 'Position'?: string} */ public function replicaBinLogPrimary(int $link): array { global $dbi; $data = $dbi->fetchResult(Compatibility::getShowBinLogStatusStmt($dbi), null, null, $link); $output = []; if (! empty($data)) { $output['File'] = $data[0]['File']; $output['Position'] = $data[0]['Position']; } return $output; } }