getSessionState(); $this->assertFalse($sessionState->isAuthenticated()); $this->assertTrue($sessionState->containsFlag(SessionFlags::REGISTRATION_REQUIRED)); foreach($rpcClient->getSessionState()->getFlags() as $sessionFlag) { if(SessionFlags::tryFrom($sessionFlag) === null) { $this->fail('Unknown session flag: ' . $sessionFlag); } } $this->assertTrue($rpcClient->settingsAddInformationField(InformationFieldName::DISPLAY_NAME, 'Test User')); $this->assertEquals('Test User', $rpcClient->settingsGetInformationField(InformationFieldName::DISPLAY_NAME)->getValue()); $this->assertFalse($rpcClient->getSessionState()->containsFlag(SessionFlags::SET_DISPLAY_NAME)); $this->assertTrue($rpcClient->settingsAddInformationField(InformationFieldName::FIRST_NAME, 'John')); $this->assertEquals('John', $rpcClient->settingsGetInformationField(InformationFieldName::FIRST_NAME)->getValue()); $this->assertFalse($rpcClient->getSessionState()->containsFlag(SessionFlags::SET_FIRST_NAME)); $this->assertTrue($rpcClient->settingsAddInformationField(InformationFieldName::LAST_NAME, 'Doe')); $this->assertEquals('Doe', $rpcClient->settingsGetInformationField(InformationFieldName::LAST_NAME)->getValue()); $this->assertFalse($rpcClient->getSessionState()->containsFlag(SessionFlags::SET_LAST_NAME)); $this->assertTrue($rpcClient->settingsAddInformationField(InformationFieldName::EMAIL_ADDRESS, 'johndoe@example.com')); $this->assertEquals('johndoe@example.com', $rpcClient->settingsGetInformationField(InformationFieldName::EMAIL_ADDRESS)->getValue()); $this->assertFalse($rpcClient->getSessionState()->containsFlag(SessionFlags::SET_EMAIL)); $this->assertTrue($rpcClient->settingsSetPassword('SecuredTestingPassword123')); $this->assertFalse($rpcClient->getSessionState()->containsFlag(SessionFlags::SET_PASSWORD)); $this->assertTrue($rpcClient->getSessionState()->isAuthenticated()); } /** * @throws RpcException * @throws ResolutionException * @throws CryptographyException * @throws DatabaseOperationException */ public function testPeerResolution(): void { $johnClient = Helper::generateRandomClient(COFFEE_DOMAIN, prefix: 'johnDoe'); $johnClient->settingsAddInformationField(InformationFieldName::DISPLAY_NAME, 'Test User'); $this->assertEquals('Test User', $johnClient->settingsGetInformationField(InformationFieldName::DISPLAY_NAME)->getValue()); $johnClient->settingsAddInformationField(InformationFieldName::FIRST_NAME, 'John'); $this->assertEquals('John', $johnClient->settingsGetInformationField(InformationFieldName::FIRST_NAME)->getValue()); $johnClient->settingsAddInformationField(InformationFieldName::LAST_NAME, 'Doe'); $this->assertEquals('Doe', $johnClient->settingsGetInformationField(InformationFieldName::LAST_NAME)->getValue()); $johnClient->settingsSetPassword('SecuredTestingPassword123'); $this->assertTrue($johnClient->getSessionState()->isAuthenticated()); $this->assertFalse($johnClient->getSessionState()->containsFlag(SessionFlags::REGISTRATION_REQUIRED)); $this->assertFalse($johnClient->getSessionState()->containsFlag(SessionFlags::AUTHENTICATION_REQUIRED)); $aliceClient = Helper::generateRandomClient(COFFEE_DOMAIN, prefix: 'aliceSmith'); $aliceClient->settingsAddInformationField(InformationFieldName::DISPLAY_NAME, 'Test User'); $this->assertEquals('Test User', $aliceClient->settingsGetInformationField(InformationFieldName::DISPLAY_NAME)->getValue()); $aliceClient->settingsAddInformationField(InformationFieldName::FIRST_NAME, 'Alice'); $this->assertEquals('Alice', $aliceClient->settingsGetInformationField(InformationFieldName::FIRST_NAME)->getValue()); $aliceClient->settingsAddInformationField(InformationFieldName::LAST_NAME, 'Smith'); $this->assertEquals('Smith', $aliceClient->settingsGetInformationField(InformationFieldName::LAST_NAME)->getValue()); $aliceClient->settingsSetPassword('SecuredTestingPassword123'); $this->assertTrue($aliceClient->getSessionState()->isAuthenticated()); $this->assertFalse($aliceClient->getSessionState()->containsFlag(SessionFlags::REGISTRATION_REQUIRED)); $this->assertFalse($aliceClient->getSessionState()->containsFlag(SessionFlags::AUTHENTICATION_REQUIRED)); $aliceResolved = $aliceClient->resolvePeer($aliceClient->getSelf()->getPeerAddress()); foreach($aliceResolved->getInformationFields() as $informationField) { switch($informationField->getName()) { case InformationFieldName::DISPLAY_NAME: $this->assertEquals('Test User', $informationField->getValue()); break; case InformationFieldName::FIRST_NAME: $this->assertEquals('Alice', $informationField->getValue()); break; case InformationFieldName::LAST_NAME: $this->assertEquals('Smith', $informationField->getValue()); break; default: $this->fail('Unexpected information field: ' . $informationField->getName()->value); } } $johnResolved = $aliceClient->resolvePeer($johnClient->getSelf()->getPeerAddress()); foreach($johnResolved->getInformationFields() as $informationField) { switch($informationField->getName()) { case InformationFieldName::DISPLAY_NAME: $this->assertEquals('Test User', $informationField->getValue()); break; case InformationFieldName::FIRST_NAME: $this->assertEquals('John', $informationField->getValue()); break; case InformationFieldName::LAST_NAME: $this->assertEquals('Doe', $informationField->getValue()); break; default: $this->fail('Unexpected information field: ' . $informationField->getName()->value); } } $this->assertEquals($johnClient->getSelf()->getPeerAddress(), $johnResolved->getPeerAddress()); $this->assertEquals($aliceClient->getSelf()->getPeerAddress(), $aliceResolved->getPeerAddress()); } /** * @throws ResolutionException * @throws RpcException * @throws CryptographyException * @throws DatabaseOperationException */ public function testIncorrectLogin(): void { $rpcClient = Helper::generateRandomClient(COFFEE_DOMAIN, prefix: 'incorrectLogin'); $generatedPeer = $rpcClient->getIdentifiedAs(); $rpcClient->settingsAddInformationField(InformationFieldName::DISPLAY_NAME, 'Test User'); $rpcClient->settingsSetPassword('SecuredTestingPassword123'); $this->assertTrue($rpcClient->getSessionState()->isAuthenticated()); $rpcClient = new SocialClient($generatedPeer); $this->assertFalse($rpcClient->getSessionState()->isAuthenticated()); $this->assertTrue($rpcClient->getSessionState()->containsFlag(SessionFlags::AUTHENTICATION_REQUIRED)); $this->assertTrue($rpcClient->getSessionState()->containsFlag(SessionFlags::VER_PASSWORD)); $this->assertFalse($rpcClient->verificationPasswordAuthentication('IncorrectPassword')); $this->assertTrue($rpcClient->getSessionState()->containsFlag(SessionFlags::AUTHENTICATION_REQUIRED)); $this->assertTrue($rpcClient->getSessionState()->containsFlag(SessionFlags::VER_PASSWORD)); } /** * @throws DatabaseOperationException * @throws ResolutionException * @throws CryptographyException * @throws RpcException */ public function testCorrectLogin(): void { $rpcClient = Helper::generateRandomClient(COFFEE_DOMAIN, prefix: 'incorrectLogin'); $generatedPeer = $rpcClient->getIdentifiedAs(); $rpcClient->settingsAddInformationField(InformationFieldName::DISPLAY_NAME, 'Test User'); $rpcClient->settingsSetPassword('SecuredTestingPassword123'); $this->assertTrue($rpcClient->getSessionState()->isAuthenticated()); $rpcClient = new SocialClient($generatedPeer); $this->assertFalse($rpcClient->getSessionState()->isAuthenticated()); $this->assertTrue($rpcClient->getSessionState()->containsFlag(SessionFlags::AUTHENTICATION_REQUIRED)); $this->assertTrue($rpcClient->getSessionState()->containsFlag(SessionFlags::VER_PASSWORD)); $this->assertTrue($rpcClient->verificationPasswordAuthentication('SecuredTestingPassword123')); $this->assertFalse($rpcClient->getSessionState()->containsFlag(SessionFlags::AUTHENTICATION_REQUIRED)); $this->assertFalse($rpcClient->getSessionState()->containsFlag(SessionFlags::VER_PASSWORD)); } }