private function sendGenTestDataBridge() { $dirName1 = 'testdir_client1_' . date('Ymd_His') . '_' . uniqid('', true); $dirName2 = 'testdir_client2_' . date('Ymd_His') . '_' . uniqid('', true); $dirName3 = 'testdir_client3_' . date('Ymd_His') . '_' . uniqid('', true); $filesystem = new Filesystem(); $filesystem->mkdir('test_data/' . $dirName1, $mode = 0777); $filesystem->mkdir('test_data/' . $dirName2, $mode = 0777); $filesystem->mkdir('test_data/' . $dirName3, $mode = 0777); file_put_contents('test_data/' . $dirName1 . '/id_rsa.prv', static::NODE_LOCAL_SSL_KEY_PRV1); file_put_contents('test_data/' . $dirName1 . '/id_rsa.pub', static::NODE_LOCAL_SSL_KEY_PUB1); file_put_contents('test_data/' . $dirName2 . '/id_rsa.prv', static::NODE_LOCAL_SSL_KEY_PRV2); file_put_contents('test_data/' . $dirName2 . '/id_rsa.pub', static::NODE_LOCAL_SSL_KEY_PUB2); file_put_contents('test_data/' . $dirName3 . '/id_rsa.prv', static::NODE_LOCAL_SSL_KEY_PRV3); file_put_contents('test_data/' . $dirName3 . '/id_rsa.pub', static::NODE_LOCAL_SSL_KEY_PUB3); $localNode1 = new Node(); $localNode1->setUri('tcp://127.0.0.1:25000'); $localNode1->setIdHexStr('cafed00d-2131-4159-8e11-0b4dbadb1738'); $table1 = new Table('test_data/' . $dirName1 . '/table.yml'); $table1->setDatadirBasePath('test_data/' . $dirName1); $table1->setLocalNode($localNode1); $table1->setDataChanged(true); $table1->save(); $localNode2 = new Node(); $localNode2->setUri('tcp://127.0.0.2:25000'); $localNode2->setIdHexStr('cafed00d-2131-4159-8e11-0b4dbadb1739'); $table2 = new Table('test_data/' . $dirName2 . '/table.yml'); $table2->setDatadirBasePath('test_data/' . $dirName2); $table2->setLocalNode($localNode2); $table2->setDataChanged(true); $table2->save(); $localNode3 = new Node(); $localNode3->setUri('tcp://127.0.0.3:25000'); $localNode3->setIdHexStr('cafed00d-2131-4159-8e11-0b4dbadb1740'); $table3 = new Table('test_data/' . $dirName3 . '/table.yml'); $table3->setDatadirBasePath('test_data/' . $dirName3); $table3->setLocalNode($localNode3); $table3->setDataChanged(true); $table3->save(); $settings1 = new Settings(); $settings1->data['datadir'] = 'test_data/' . $dirName1; $settings1->data['firstRun'] = false; $settings1->data['timeCreated'] = time(); $settings1->data['node']['uriLocal'] = 'tcp://127.0.0.1'; $settings1->data['node']['id'] = Node::genIdHexStr(static::NODE_LOCAL_SSL_KEY_PUB1); $settings1->data['node']['sslKeyPrvPass'] = '******'; $settings1->data['node']['sslKeyPrvPath'] = 'test_data/' . $dirName1 . '/id_rsa.prv'; $settings1->data['node']['sslKeyPubPath'] = 'test_data/' . $dirName1 . '/id_rsa.pub'; $settings1->data['user']['nickname'] = 'user1'; $settings1->data['node']['bridge']['client']['enabled'] = true; $settings2 = new Settings(); $settings2->data['datadir'] = 'test_data/' . $dirName2; $settings2->data['firstRun'] = false; $settings2->data['timeCreated'] = time(); $settings2->data['node']['uriLocal'] = 'tcp://127.0.0.2'; $settings2->data['node']['id'] = Node::genIdHexStr(static::NODE_LOCAL_SSL_KEY_PUB2); $settings2->data['node']['sslKeyPrvPass'] = '******'; $settings2->data['node']['sslKeyPrvPath'] = 'test_data/' . $dirName2 . '/id_rsa.prv'; $settings2->data['node']['sslKeyPubPath'] = 'test_data/' . $dirName2 . '/id_rsa.pub'; $settings2->data['user']['nickname'] = 'user2'; $settings2->data['node']['bridge']['server']['enabled'] = true; $settings3 = new Settings(); $settings3->data['datadir'] = 'test_data/' . $dirName3; $settings3->data['firstRun'] = false; $settings3->data['timeCreated'] = time(); $settings3->data['node']['uriLocal'] = 'tcp://127.0.0.3'; $settings3->data['node']['id'] = Node::genIdHexStr(static::NODE_LOCAL_SSL_KEY_PUB2); $settings3->data['node']['sslKeyPrvPass'] = '******'; $settings3->data['node']['sslKeyPrvPath'] = 'test_data/' . $dirName3 . '/id_rsa.prv'; $settings3->data['node']['sslKeyPubPath'] = 'test_data/' . $dirName3 . '/id_rsa.pub'; $settings3->data['user']['nickname'] = 'user3'; $settings3->data['node']['bridge']['client']['enabled'] = true; $log1 = new Logger('client_1'); $log1->pushHandler(new LoggerStreamHandler('php://stdout', Logger::DEBUG)); $log2 = new Logger('client_2'); $log2->pushHandler(new LoggerStreamHandler('php://stdout', Logger::DEBUG)); $log3 = new Logger('client_2'); $log3->pushHandler(new LoggerStreamHandler('php://stdout', Logger::DEBUG)); $kernel1 = new Kernel(); $kernel1->setLog($log1); $kernel1->setSettings($settings1); $kernel1->init(); $kernel2 = new Kernel(); $kernel2->setLog($log2); $kernel2->setSettings($settings2); $kernel2->init(); $kernel3 = new Kernel(); $kernel3->setLog($log3); $kernel3->setSettings($settings3); $kernel3->init(); $server1 = $kernel1->getServer(); $server1->setLog($log1); $server2 = $kernel2->getServer(); $server2->setLog($log2); $server3 = $kernel3->getServer(); $server3->setLog($log3); $client1 = new Client(); $client1->debug = true; $client1->setSslPrv($settings1->data['node']['sslKeyPrvPath'], $settings1->data['node']['sslKeyPrvPass']); $client1->setId(1); $client1->setUri($settings1->data['node']['uriLocal']); $client1->setServer($server1); $this->assertEquals($settings1->data['node']['uriLocal'], 'tcp://' . $client1->getUri()->getHost()); #fwrite(STDOUT, 'ip1: /'.$client1->getUri()->getHost().'/'."\n"); $client2 = new Client(); $client2->debug = true; $client2->setSslPrv($settings2->data['node']['sslKeyPrvPath'], $settings2->data['node']['sslKeyPrvPass']); $client2->setId(2); $client2->setUri($settings2->data['node']['uriLocal']); $client2->setServer($server2); $this->assertEquals($settings2->data['node']['uriLocal'], 'tcp://' . $client2->getUri()->getHost()); #fwrite(STDOUT, 'ip2: /'.$client2->getUri()->getHost().'/'."\n"); $client3 = new Client(); $client3->debug = true; $client3->setSslPrv($settings3->data['node']['sslKeyPrvPath'], $settings3->data['node']['sslKeyPrvPass']); $client3->setId(3); $client3->setUri($settings3->data['node']['uriLocal']); $client3->setServer($server3); $this->assertEquals($settings3->data['node']['uriLocal'], 'tcp://' . $client3->getUri()->getHost()); #fwrite(STDOUT, 'ip3: /'.$client3->getUri()->getHost().'/'."\n"); return array($client1, $client2, $client3); }
/** * @dataProvider providerLevel */ public function testLevel($const, $number, $name) { $this->assertEquals($const, $number); $this->assertEquals($name, Logger::getLevelNameByNumber($number)); }
print "FATAL ERROR: you must first run 'composer install'.\nVisit https://getcomposer.org\n"; exit(1); } require_once __DIR__ . '/vendor/autoload.php'; use Rhumsaa\Uuid\Uuid; use Rhumsaa\Uuid\Exception\UnsatisfiedDependencyException; use Symfony\Component\Filesystem\Filesystem; use Zend\Uri\UriFactory; use TheFox\Logger\Logger; use TheFox\Logger\StreamHandler; use TheFox\PhpChat\Settings; use TheFox\Dht\Kademlia\Node; $filesystem = new Filesystem(); $filesystem->mkdir('log', 0700); $filesystem->mkdir('pid', 0700); $log = new Logger('main'); $log->pushHandler(new StreamHandler('php://stdout', Logger::INFO)); $log->pushHandler(new StreamHandler('log/bootstrap.log', Logger::DEBUG)); UriFactory::registerScheme('tcp', 'TheFox\\PhpChat\\TcpUri'); UriFactory::registerScheme('http', 'TheFox\\PhpChat\\HttpUri'); $settings = new Settings(__DIR__ . '/settings.yml'); if (isset($settings->data['datadir']) && !file_exists($settings->data['datadir'])) { $log->info('create datadir: ' . $settings->data['datadir']); $filesystem->mkdir($settings->data['datadir'], 0700); } if (!$settings->data['node']['sslKeyPrvPass']) { $sslKeyPrvPass = ''; try { $log->info('ssl: generate private key password'); $sslKeyPrvPass = (string) Uuid::uuid4(); } catch (UnsatisfiedDependencyException $e) {