3 Commits
0.0.5 ... 0.0.6

Author SHA1 Message Date
Meritoo
b3b0e66fb3 ConnectionConfiguration - add $verifySslCertificate property - if is set to true, the SSL certificate verification is turned on, otherwise - turned off
It's useful while running application with custom, non-official SSL certificate, e.g. while development process.
2017-09-27 21:32:28 +02:00
Meritoo
0fbfc9780d Remove composer.lock 2017-09-27 21:29:51 +02:00
Meritoo
92315bd853 Minor refactoring 2017-09-27 12:28:51 +02:00
6 changed files with 106 additions and 3624 deletions

1
.gitignore vendored
View File

@@ -11,6 +11,7 @@
# ---------------------------------------------------------------------------------------------------------------------- # ----------------------------------------------------------------------------------------------------------------------
### Composer ### Composer
# ---------------------------------------------------------------------------------------------------------------------- # ----------------------------------------------------------------------------------------------------------------------
/composer.lock
/composer.phar /composer.phar
# ---------------------------------------------------------------------------------------------------------------------- # ----------------------------------------------------------------------------------------------------------------------

View File

@@ -3,7 +3,7 @@
"description": "Client of LimeSurvey API", "description": "Client of LimeSurvey API",
"type": "library", "type": "library",
"license": "MIT", "license": "MIT",
"version": "0.0.5", "version": "0.0.6",
"authors": [ "authors": [
{ {
"name": "Meritoo", "name": "Meritoo",

3581
composer.lock generated

File diff suppressed because it is too large Load Diff

View File

@@ -59,15 +59,26 @@ class ConnectionConfiguration
*/ */
private $debugMode = false; private $debugMode = false;
/**
* If is set to true, the SSL certificate verification is turned on. Otherwise - turned off.
* It's useful while running application with custom, non-official SSL certificate, e.g. while development process.
*
* @var bool
*/
private $verifySslCertificate = true;
/** /**
* Class constructor * Class constructor
* *
* @param string $baseUrl Base url. Protocol & domain. * @param string $baseUrl Base url. Protocol & domain.
* @param string $username Name of user used to authenticate to LimeSurvey * @param string $username Name of user used to authenticate to LimeSurvey
* @param string $password Password used to authenticate to LimeSurvey * @param string $password Password used to authenticate to LimeSurvey
* @param bool $debugMode (optional) If is set to true, the "debug" mode is turned on. Otherwise - turned off. * @param bool $debugMode (optional) If is set to true, the "debug" mode is turned on. Otherwise -
* turned off.
* @param bool $verifySslCertificate (optional) If is set to true, the SSL certificate verification is turned
* on. Otherwise - turned off.
*/ */
public function __construct($baseUrl, $username, $password, $debugMode = false) public function __construct($baseUrl, $username, $password, $debugMode = false, $verifySslCertificate = true)
{ {
$this $this
->setBaseUrl($baseUrl) ->setBaseUrl($baseUrl)
@@ -201,6 +212,30 @@ class ConnectionConfiguration
return $this; return $this;
} }
/**
* Returns information if the SSL certificate verification is turned on
*
* @return bool
*/
public function isVerifySslCertificateOn()
{
return $this->verifySslCertificate;
}
/**
* Sets information if the SSL certificate verification is turned on
*
* @param bool $verifySslCertificate (optional) If is set to true, the SSL certificate verification is turned on.
* Otherwise - turned off.
* @return $this
*/
public function setVerifySslCertificate($verifySslCertificate = true)
{
$this->verifySslCertificate = $verifySslCertificate;
return $this;
}
/* /*
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
* Additional / extra methods (neither getters, nor setters) * Additional / extra methods (neither getters, nor setters)

View File

@@ -85,7 +85,20 @@ class JsonRpcClientManager
* The "debug" mode is turned on? * The "debug" mode is turned on?
*/ */
if ($this->connectionConfiguration->isDebugModeOn()) { if ($this->connectionConfiguration->isDebugModeOn()) {
$this->rpcClient->getHttpClient()->withDebug(); $this
->rpcClient
->getHttpClient()
->withDebug();
}
/*
* The SSL certificate verification is turned off?
*/
if (!$this->connectionConfiguration->isVerifySslCertificateOn()) {
$this
->rpcClient
->getHttpClient()
->withoutSslVerification();
} }
} }

View File

@@ -22,9 +22,16 @@ use Meritoo\LimeSurvey\ApiClient\Configuration\ConnectionConfiguration;
*/ */
class ConnectionConfigurationTest extends BaseTestCase class ConnectionConfigurationTest extends BaseTestCase
{ {
/**
* Simple instance of the configuration
*
* @var ConnectionConfiguration
*/
private $simpleConfiguration;
public function testConstructorVisibilityAndArguments() public function testConstructorVisibilityAndArguments()
{ {
static::assertConstructorVisibilityAndArguments(ConnectionConfiguration::class, OopVisibilityType::IS_PUBLIC, 4, 3); static::assertConstructorVisibilityAndArguments(ConnectionConfiguration::class, OopVisibilityType::IS_PUBLIC, 5, 3);
} }
/** /**
@@ -49,69 +56,67 @@ class ConnectionConfigurationTest extends BaseTestCase
public function testConstructor() public function testConstructor()
{ {
$configuration = new ConnectionConfiguration('http://test.com', 'test1', 'test2'); static::assertEquals('http://test.com', $this->simpleConfiguration->getBaseUrl());
static::assertEquals('test1', $this->simpleConfiguration->getUsername());
static::assertEquals('http://test.com', $configuration->getBaseUrl()); static::assertEquals('test2', $this->simpleConfiguration->getPassword());
static::assertEquals('test1', $configuration->getUsername()); static::assertFalse($this->simpleConfiguration->isDebugModeOn());
static::assertEquals('test2', $configuration->getPassword());
static::assertFalse($configuration->isDebugModeOn());
} }
public function testSetBaseUrl() public function testSetBaseUrl()
{ {
$configuration = new ConnectionConfiguration('http://test.com', 'test1', 'test2'); $this->simpleConfiguration->setBaseUrl('http://lorem.ipsum');
static::assertEquals('http://lorem.ipsum', $this->simpleConfiguration->getBaseUrl());
$configuration->setBaseUrl('http://lorem.ipsum'); $this->simpleConfiguration->setBaseUrl('http://lorem.ipsum/');
static::assertEquals('http://lorem.ipsum', $configuration->getBaseUrl()); static::assertEquals('http://lorem.ipsum', $this->simpleConfiguration->getBaseUrl());
$configuration->setBaseUrl('http://lorem.ipsum/');
static::assertEquals('http://lorem.ipsum', $configuration->getBaseUrl());
} }
public function testSetRemoteControlUrl() public function testSetRemoteControlUrl()
{ {
$configuration = new ConnectionConfiguration('http://test.com', 'test1', 'test2'); $this->simpleConfiguration->setRemoteControlUrl('/lorem/ipsum');
$configuration->setRemoteControlUrl('/lorem/ipsum'); static::assertEquals('/lorem/ipsum', $this->simpleConfiguration->getRemoteControlUrl());
static::assertEquals('/lorem/ipsum', $configuration->getRemoteControlUrl());
} }
public function testSetUsername() public function testSetUsername()
{ {
$configuration = new ConnectionConfiguration('http://test.com', 'test1', 'test2'); $this->simpleConfiguration->setUsername('lorem');
$configuration->setUsername('lorem'); static::assertEquals('lorem', $this->simpleConfiguration->getUsername());
static::assertEquals('lorem', $configuration->getUsername());
} }
public function testSetPassword() public function testSetPassword()
{ {
$configuration = new ConnectionConfiguration('http://test.com', 'test1', 'test2'); $this->simpleConfiguration->setPassword('ipsum');
$configuration->setPassword('ipsum'); static::assertEquals('ipsum', $this->simpleConfiguration->getPassword());
static::assertEquals('ipsum', $configuration->getPassword());
} }
public function testSetDebugMode() public function testSetDebugMode()
{ {
$configuration = new ConnectionConfiguration('http://test.com', 'test1', 'test2'); $this->simpleConfiguration->setDebugMode();
static::assertFalse($this->simpleConfiguration->isDebugModeOn());
$configuration->setDebugMode(); $this->simpleConfiguration->setDebugMode(false);
static::assertFalse($configuration->isDebugModeOn()); static::assertFalse($this->simpleConfiguration->isDebugModeOn());
$configuration->setDebugMode(false); $this->simpleConfiguration->setDebugMode(true);
static::assertFalse($configuration->isDebugModeOn()); static::assertTrue($this->simpleConfiguration->isDebugModeOn());
}
$configuration->setDebugMode(true); public function testSetVerifySslCertificate()
static::assertTrue($configuration->isDebugModeOn()); {
$this->simpleConfiguration->setVerifySslCertificate();
static::assertTrue($this->simpleConfiguration->isVerifySslCertificateOn());
$this->simpleConfiguration->setVerifySslCertificate(false);
static::assertFalse($this->simpleConfiguration->isVerifySslCertificateOn());
$this->simpleConfiguration->setVerifySslCertificate(true);
static::assertTrue($this->simpleConfiguration->isVerifySslCertificateOn());
} }
public function testGetFullUrl() public function testGetFullUrl()
{ {
$configuration = new ConnectionConfiguration('http://test.com', 'test1', 'test2'); $this->simpleConfiguration->setRemoteControlUrl('lorem/ipsum');
$configuration->setRemoteControlUrl('lorem/ipsum'); static::assertEquals('http://test.com/lorem/ipsum', $this->simpleConfiguration->getFullUrl());
static::assertEquals('http://test.com/lorem/ipsum', $configuration->getFullUrl());
} }
/** /**
@@ -149,4 +154,13 @@ class ConnectionConfigurationTest extends BaseTestCase
'htp:/dolor.com', 'htp:/dolor.com',
]; ];
} }
/**
* {@inheritdoc}
*/
protected function setUp()
{
parent::setUp();
$this->simpleConfiguration = new ConnectionConfiguration('http://test.com', 'test1', 'test2');
}
} }