19 require_once(
'./libs/composer/vendor/autoload.php');
21 require_once(
'./Services/WebAccessChecker/classes/class.ilWACSignedPath.php');
22 require_once(
'./Services/WebAccessChecker/classes/class.ilWebAccessChecker.php');
23 require_once(
'./Services/WebAccessChecker/classes/class.ilWACSignedPath.php');
24 require_once(
'./Services/WebAccessChecker/classes/class.ilWACToken.php');
99 protected function setUp() : void
103 $this->root = vfs\vfsStream::setup(
'ilias.de');
104 $this->file_one = vfs\vfsStream::newFile(
'data/client_name/mobs/mm_123/dummy.jpg')
105 ->at($this->root)->setContent(
'dummy');
106 $this->file_one_subfolder = vfs\vfsStream::newFile(
'data/client_name/mobs/mm_123/mobile/dummy.jpg')
107 ->at($this->root)->setContent(
'dummy');
108 $this->file_one_subfolder_two = vfs\vfsStream::newFile(
'data/client_name/mobs/mm_123/mobile/device/dummy.jpg')
109 ->at($this->root)->setContent(
'dummy');
110 $this->file_two = vfs\vfsStream::newFile(
'data/client_name/mobs/mm_123/dummy2.jpg')
111 ->at($this->root)->setContent(
'dummy2');
112 $this->file_three = vfs\vfsStream::newFile(
'data/client_name/mobs/mm_124/dummy.jpg')
113 ->at($this->root)->setContent(
'dummy');
114 $this->file_four = vfs\vfsStream::newFile(
'data/client_name/sec/ilBlog/mm_124/dummy.jpg')
115 ->at($this->root)->setContent(
'dummy');
120 return Mockery::mock(GlobalHttpState::class);
128 $this->cookieFactory = Mockery::mock(CookieFactoryImpl::class);
131 $this->cookieFactory->shouldDeferMissing();
141 $cookieJar = Mockery::mock(CookieJar::class);
144 ->shouldReceive(
'getAll')
149 $this->
http->shouldReceive(
'cookieJar')
152 ->andReturn($cookieJar);
154 $request = Mockery::mock(Psr\Http\Message\RequestInterface::class);
155 $request->shouldReceive(
'getCookieParams')
158 $this->
http->shouldReceive(
'request')
160 ->andReturn($request);
162 $this->assertFalse($ilWACSignedPath->isSignedPath());
163 $this->assertFalse($ilWACSignedPath->isSignedPathValid());
164 $this->assertFalse($ilWACSignedPath->isFolderSigned());
165 $this->assertFalse($ilWACSignedPath->isFolderTokenValid());
173 .
$query,
false), $this->
http, $this->cookieFactory);
175 $this->assertEquals(
'dummy.jpg', $ilWACSignedPath->getPathObject()->getFileName());
176 $this->assertEquals(
$query, $ilWACSignedPath->getPathObject()->getQuery());
178 .
'/sec/ilBlog/mm_124/', $ilWACSignedPath->getPathObject()
180 $this->assertEquals(
'ilBlog', $ilWACSignedPath->getPathObject()->getSecurePathId());
181 $this->assertFalse($ilWACSignedPath->getPathObject()->isStreamable());
187 $ilWacPath =
new ilWacPath($this->file_four->url(),
false);
190 $this->assertEquals(
'SALT-client_name-123456-20', $ilWACToken->getRawToken());
191 $this->assertEquals(
'./data/client_name/sec/ilBlog/mm_124/dummy.jpg', $ilWACToken->getId());
195 $this->assertEquals(
'b541e2bae42ee222f9be959b7ad2ab8844cbb05b', $ilWACToken->getToken());
196 $this->assertEquals(
'e45b98f267dc891c8206c844f7df29ea', $ilWACToken->getHashedId());
202 $this->markTestSkipped(
'unable to use http cookies at this point');
203 $expected_cookies = [
204 '19ab58dae37d8d8cf931727c35514642',
205 '19ab58dae37d8d8cf931727c35514642ts',
206 '19ab58dae37d8d8cf931727c35514642ttl',
209 $cookieJar = Mockery::mock(CookieJar::class);
211 $response = Mockery::mock(ResponseInterface::class);
214 ->shouldReceive(
'response')
221 ->shouldReceive(
'with')
227 ->shouldReceive(
'with')
233 ->shouldReceive(
'with')
239 $this->
http->shouldReceive(
'cookieJar')
241 ->andReturn($cookieJar);
262 $this->assertTrue($ilWACSignedPath->isSignedPath());
263 $this->assertTrue($ilWACSignedPath->isSignedPathValid());
264 $this->assertEquals($ilWACSignedPath->getPathObject()->getClient(),
self::CLIENT_NAME);
265 $this->assertFalse($ilWACSignedPath->getPathObject()->isInSecFolder());
266 $this->assertTrue($ilWACSignedPath->getPathObject()->isImage());
267 $this->assertFalse($ilWACSignedPath->getPathObject()->isAudio());
268 $this->assertFalse($ilWACSignedPath->getPathObject()->isVideo());
269 $this->assertTrue($ilWACSignedPath->getPathObject()->hasTimestamp());
270 $this->assertTrue($ilWACSignedPath->getPathObject()->hasToken());
274 sleep($lifetime + self::ADDITIONAL_TIME);
276 $this->assertTrue($ilWACSignedPath->isSignedPath());
277 $this->assertFalse($ilWACSignedPath->isSignedPathValid());
290 $this->assertTrue($ilWACSignedPath->isSignedPath());
291 $this->assertTrue($ilWACSignedPath->isSignedPathValid());
303 $this->assertTrue($ilWACSignedPath->isSignedPath());
304 $this->assertFalse($ilWACSignedPath->isSignedPathValid());
313 * -1, 0),
false), $this->
http, $this->cookieFactory);
314 $this->assertTrue($ilWACSignedPath->isSignedPath());
315 $this->assertFalse($ilWACSignedPath->isSignedPathValid());
324 $this->assertTrue($ilWACSignedPath->isSignedPath());
325 $this->assertFalse($ilWACSignedPath->isSignedPathValid());
334 $this->assertTrue($ilWACSignedPath->isSignedPath());
335 $this->assertFalse($ilWACSignedPath->isSignedPathValid());
344 $this->assertTrue($ilWACSignedPath->isSignedPath());
345 $this->assertFalse($ilWACSignedPath->isSignedPathValid());
360 $parts = parse_url($signed_path);
361 $path = $parts[
'path'];
363 parse_str(
$query, $query_array);
364 $token = $override_token ? $override_token : $query_array[
'il_wac_token'];
365 $ttl = (int) $query_array[
'il_wac_ttl'];
366 $ts = (int) $query_array[
'il_wac_ts'];
367 $path_with_token = $path .
'?il_wac_token=' .
$token;
369 $modified_ttl = $ttl + $add_ttl;
370 $modified_ts = $ts + $add_timestamp;
372 return $path_with_token .
'&il_wac_ttl=' . $modified_ttl .
'&il_wac_ts=' . $modified_ts;
getModifiedSignedPath($add_ttl=0, $add_timestamp=0, $override_token=null)
testModifiedTimestampAddTime()
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
TestCase for the ilWACTokenTest.
static signFolderOfStartFile($start_file_path)
testModifiedTimestampSubTime()
static http()
Fetches the global http state from ILIAS.
if(!defined('PATH_SEPARATOR')) $GLOBALS['_PEAR_default_error_mode']
testModifiedTTLAndTimestamp()
static signFile($path_to_file)
testModifiedTimestampNoMod()
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static setTokenMaxLifetimeInSeconds($token_max_lifetime_in_seconds)
static getTokenMaxLifetimeInSeconds()
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...