<?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==