قرینه از
https://github.com/matomo-org/matomo.git
synced 2025-08-22 15:07:44 +00:00

* [Coding Style] Enable rule PSR1.Methods.CamelCapsMethodName.NotCamelCaps * [Coding Style] Use camel case for method names in API plugin tests (#22145) * [Coding Style] Use camel case for method names in Core* plugin tests (#22147) * [Coding Style] Use camel case for method names in core Unit tests (#22149) * [Coding Style] Use camel case for method names in Actions and BulkTracking plugin tests (#22146) * [Coding Style] Use camel case for method names in CustomDimensions and CustomJSTracker plugin tests (#22148) * [Coding Style] Use camel case for method names in core Integration tests (#22151) * [Coding Style] Use camel case for method names in more core plugin tests (#22153) * [Coding Style] Use camel case for method names in more core plugin tests (#22157) * [Coding Style] Use camel case for method names in more core plugin tests * Update plugins/Monolog/tests/Unit/Processor/ExceptionToTextProcessorTest.php Co-authored-by: Michal Kleiner <michal@innocraft.com> --------- Co-authored-by: Michal Kleiner <michal@innocraft.com> * [Coding Style] Use camel case for method names in more core plugin tests (#22159) * [Coding Style] Use camel case for method names in remaining tests (#22160) * [Coding Style] Use camel case for method names in remaining tests * rename expected test files --------- Co-authored-by: Michal Kleiner <michal@innocraft.com>
96 خطوط
2.9 KiB
PHP
96 خطوط
2.9 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Matomo - free/libre analytics platform
|
|
*
|
|
* @link https://matomo.org
|
|
* @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
|
|
*/
|
|
|
|
namespace Piwik\Plugins\UsersManager\tests\Integration;
|
|
|
|
use Piwik\Plugins\UsersManager\API as UsersManagerAPI;
|
|
use Piwik\Plugins\UsersManager\Model as UsersManagerModel;
|
|
use Piwik\Tests\Framework\Fixture;
|
|
use Piwik\Tests\Framework\TestCase\IntegrationTestCase;
|
|
|
|
/**
|
|
* @group UsersManager
|
|
* @group TokenSecureOnlyTest
|
|
*/
|
|
class TokenSecureOnlyTest extends IntegrationTestCase
|
|
{
|
|
protected static $tokenSecureOnly = 'f3fa8c38fd277a9af0fab7e35f9736fe';
|
|
|
|
public static function beforeTableDataCached()
|
|
{
|
|
self::createUserAndTokens();
|
|
}
|
|
|
|
private static function createUserAndTokens()
|
|
{
|
|
if (!Fixture::siteCreated($idSite = 1)) {
|
|
Fixture::createWebsite('2021-01-01');
|
|
}
|
|
|
|
if (!UsersManagerAPI::getInstance()->userExists('user1')) {
|
|
UsersManagerAPI::getInstance()->addUser('user1', 'user1password', 'user@limited.com');
|
|
UsersManagerAPI::getInstance()->setUserAccess('user1', 'view', [1]);
|
|
|
|
$userModel = new UsersManagerModel();
|
|
$userModel->addTokenAuth(
|
|
'user1',
|
|
self::$tokenSecureOnly,
|
|
'Secure Only',
|
|
'2020-01-02 03:04:05',
|
|
null,
|
|
false,
|
|
true
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Secure only tokens should return a 401 code if used in a GET request
|
|
*/
|
|
public function testSecureOnlyTokenAccessDeniedIfGet()
|
|
{
|
|
$url = Fixture::getTestRootUrl() . '?' . http_build_query([
|
|
'module' => 'API',
|
|
'method' => 'API.getMatomoVersion',
|
|
'token_auth' => self::$tokenSecureOnly,
|
|
]);
|
|
|
|
$ch = curl_init();
|
|
curl_setopt($ch, CURLOPT_URL, $url);
|
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
|
$out = curl_exec($ch);
|
|
$responseInfo = curl_getinfo($ch);
|
|
curl_close($ch);
|
|
|
|
$this->assertEquals(401, $responseInfo["http_code"]);
|
|
$this->assertStringContainsString("or is required to be sent as a POST parameter", $out);
|
|
}
|
|
|
|
/**
|
|
* Secure only tokens should return a 200 code if used in a POST request
|
|
*/
|
|
public function testSecureOnlyTokenAccessGrantedIfPost()
|
|
{
|
|
$url = Fixture::getTestRootUrl() . '?' . http_build_query([
|
|
'module' => 'API',
|
|
'method' => 'API.getMatomoVersion'
|
|
]);
|
|
|
|
$ch = curl_init();
|
|
curl_setopt($ch, CURLOPT_POSTFIELDS, ['token_auth' => self::$tokenSecureOnly]);
|
|
curl_setopt($ch, CURLOPT_URL, $url);
|
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
|
curl_exec($ch);
|
|
$responseInfo = curl_getinfo($ch);
|
|
curl_close($ch);
|
|
|
|
$this->assertEquals(200, $responseInfo["http_code"]);
|
|
}
|
|
}
|