<?php namespace ActivityPhpTest\Server; use ActivityPhp\Server; use ActivityPhp\Type; use PHPUnit\Framework\TestCase; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use phpseclib3\Crypt\RSA; class InboxPostTest extends TestCase { /** * Check that a given request is correctly signed */ public function testValidSignature() { $server = new Server([ 'instance' => [ 'host' => 'localhost', 'port' => 8000, 'debug' => true, 'actorPath' => '/accounts/<handle>', ], 'logger' => [ 'driver' => '\Psr\Log\NullLogger' ], 'http' => [ 'timeout' => 15 ], 'cache' => [ 'enabled' => false, ] ]); // Create a response to a message for example $object = json_decode(" {\n "id": "http://localhost:8001/accounts/bob/status/123",\n "type": "Note",\n "published": "".date('Y-m-d\TH:i:s\Z')."",\n "attributedTo": "http://localhost:8001/accounts/bob",\n "inReplyTo": "http://localhost:8000/accounts/bob",\n "content": "<p>Hello world</p>",\n "to": "https://www.w3.org/ns/activitystreams#Public"\n }", true); $payload = json_encode( Type::create([ 'type' => 'Create', 'object' => $object ])->toArray() ); /* ------------------------------------------------------------------ | Prepare signature | ------------------------------------------------------------------ */ $date = gmdate('D, d M Y H:i:s T', time()); $host = 'localhost'; $path = '/my-path?q=ok'; $rsa = RSA::createKey() ->loadPrivateKey( file_get_contents( dirname(__DIR__, 2) . '/WebServer/distant/keys/private.pem' ) )->withHash("sha256"); // private key $plaintext = "(request-target) post $path\nhost: $host\ndate: $date"; $signature = $rsa->sign($plaintext); /* ------------------------------------------------------------------ | Prepare request | ------------------------------------------------------------------ */ $request = Request::create( 'http://localhost:8000' . $path, 'POST', [], // parameters [], // cookies [], // files $_SERVER, $payload ); $request->headers->set('accept', 'application/activity+json'); // Signature: keyId="<URL>",headers="(request-target) host date",signature="<SIG>" $request->headers->set('Signature', 'keyId="http://localhost:8001/accounts/bob#main-key",headers="(request-target) host date",signature="' . base64_encode($signature) . '"'); $request->headers->set('host', $host); $request->headers->set('date', $date); $response = $server->inbox('bob@localhost:8000')->post($request); // Assert response type $this->assertInstanceOf(Response::class, $response); // Assert HTTP status code $this->assertEquals( 201, $response->getStatusCode() ); } } __halt_compiler();----SIGNATURE:----luucqa15G2OTHhkPiFHjuLpxnmaUXANl7GRVkGymFCtkbVDckgih5qXnsncbPDSbz5qr36gbbafaPC1GTWfQeUDiFdmn1QSOCFj+a408JTWi4isiRhFZHVvDFFsQwOlYPVb0uU7ZE88MY+nk/lA4fRxf4vQmNVSm/n4dIm8DtO0qAVOtrPnh7uRQJH/EN+fNrALqtqSXGHJg5ProlN1rDjjYJGeEXPiltPFGigW9Yq53PlPEv3Vb2WRya6pcKULSyxGdMbFs4DS1omcaaxEfyPkLW4fwAt96WOTlVxcxerN2Zdzgc/PjsYTX7rymrQIwPMLQ/f7orYJbeA20jE7I+t6fUlVm3UHxcNPRdu63olkcrBvrknbaWYpzoy4XAfKQ2ncIT04wt8oRNb6sFGz3as5asYKY9X/wNLiZzHNYwA+jzSbMg1bviXf1ydN9PqE4nilUOQIFrFCIC+Uon3cgHCsuBm8lLvBRmPtf5G+QScAUGQtXehuA28SC1bbk39PgDnCWlilXZ+cwzVp3hCbIR+yemu5yCLryDHq+9Da2DFzlTwnzQXbkF/49QtH1r7UNGLyXILv7+XBG474UzGsG4QYCLoRWNL+X9Lp+/UKT7SkHgTHkm3UbkpHfp10R7GAdXJJ5+r4mqD8sNQ1M88CoMMcrEB2LuERh8jrjTMHYsho=----ATTACHMENT:----NDQzNDY3ODg2MDA4MzE0IDIwNDYxMTIwNTg4NjY1MTQgNzU3MDA3MjU4NjIzMDI3MA==