mirror of
https://github.com/Mibew/tray.git
synced 2025-01-22 18:10:34 +03:00
Implemented Mibew API
This commit is contained in:
parent
5bd6f22cab
commit
555898e446
167
src/messenger/tests/webim/libs/MibewAPIExecutionContextTest.php
Normal file
167
src/messenger/tests/webim/libs/MibewAPIExecutionContextTest.php
Normal file
@ -0,0 +1,167 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/../../../webim/libs/mibew_api.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class for MibewAPIExecutionContext.
|
||||||
|
* Generated by PHPUnit on 2012-07-27 at 15:47:53.
|
||||||
|
*/
|
||||||
|
class MibewAPIExecutionContextTest extends PHPUnit_Framework_TestCase {
|
||||||
|
|
||||||
|
public function testStoreFunctionResults() {
|
||||||
|
$context = new MibewAPIExecutionContext();
|
||||||
|
// Create 'function' array. See Mibew API for details.
|
||||||
|
$function = array(
|
||||||
|
'function' => 'test_function',
|
||||||
|
'arguments' => array(
|
||||||
|
'return' => array('microtime' => 'time'),
|
||||||
|
'references' => array()
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Wrong function's results
|
||||||
|
$wrong_results = array();
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::VARIABLE_IS_UNDEFINED_IN_RESULT code
|
||||||
|
try {
|
||||||
|
$context->storeFunctionResults($function, $wrong_results);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch(MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::VARIABLE_IS_UNDEFINED_IN_RESULT,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Correct function's results
|
||||||
|
$results = array(
|
||||||
|
'microtime' => 'some_microtime_value'
|
||||||
|
);
|
||||||
|
|
||||||
|
$context->storeFunctionResults($function, $results);
|
||||||
|
return $context;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testStoreFunctionResults
|
||||||
|
*/
|
||||||
|
public function testGetResults(MibewAPIExecutionContext $context) {
|
||||||
|
$results = $context->getResults();
|
||||||
|
$this->assertEquals(
|
||||||
|
array('time' => 'some_microtime_value'),
|
||||||
|
$results
|
||||||
|
);
|
||||||
|
//return $context;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testStoreFunctionResults
|
||||||
|
*/
|
||||||
|
public function testGetArgumentsList(MibewAPIExecutionContext $context) {
|
||||||
|
// Function with wrong references arguments. See Mibew API for details of 'function'
|
||||||
|
// array
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'test',
|
||||||
|
'arguments' => array(
|
||||||
|
'return' => array(),
|
||||||
|
'references' => array(
|
||||||
|
// Wrong function number. Execution does not have to many
|
||||||
|
// functons results
|
||||||
|
'x' => 12
|
||||||
|
),
|
||||||
|
'x' => 'microtime'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::WRONG_FUNCTION_NUM_IN_REFERENCE code
|
||||||
|
try {
|
||||||
|
$context->getArgumentsList($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch(MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::WRONG_FUNCTION_NUM_IN_REFERENCE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'test',
|
||||||
|
'arguments' => array(
|
||||||
|
'return' => array(),
|
||||||
|
'references' => array(
|
||||||
|
// Wrong argument 'x'. This function does not have this
|
||||||
|
// argument
|
||||||
|
'x' => 1
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::EMPTY_VARIABLE_IN_REFERENCE code
|
||||||
|
try {
|
||||||
|
$context->getArgumentsList($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch(MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_VARIABLE_IN_REFERENCE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'test',
|
||||||
|
'arguments' => array(
|
||||||
|
'return' => array(),
|
||||||
|
'references' => array(
|
||||||
|
'x' => 1
|
||||||
|
),
|
||||||
|
// Wrong reference name.
|
||||||
|
'x' => 'wrong_result'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::VARIABLE_IS_UNDEFINED_IN_REFERENCE code
|
||||||
|
try {
|
||||||
|
$context->getArgumentsList($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch(MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::VARIABLE_IS_UNDEFINED_IN_REFERENCE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Correct function.
|
||||||
|
$correct_function = array(
|
||||||
|
'function' => 'test',
|
||||||
|
'arguments' => array(
|
||||||
|
'return' => array(),
|
||||||
|
'references' => array(
|
||||||
|
'x' => 1
|
||||||
|
),
|
||||||
|
'x' => 'microtime'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$arguments = $context->getArgumentsList($correct_function);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
array(
|
||||||
|
'x' => 'some_microtime_value',
|
||||||
|
'return' => array(),
|
||||||
|
'references' => array(
|
||||||
|
'x' => 1
|
||||||
|
)
|
||||||
|
),
|
||||||
|
$arguments
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
619
src/messenger/tests/webim/libs/MibewAPITest.php
Normal file
619
src/messenger/tests/webim/libs/MibewAPITest.php
Normal file
@ -0,0 +1,619 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once dirname(__FILE__) . '/../../../webim/libs/mibew_api.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class for MibewAPI.
|
||||||
|
* Generated by PHPUnit on 2012-07-27 at 15:47:47.
|
||||||
|
*/
|
||||||
|
class MibewAPITest extends PHPUnit_Framework_TestCase {
|
||||||
|
|
||||||
|
public function testGetAPI() {
|
||||||
|
$mibew_api = MibewAPI::getAPI('base');
|
||||||
|
$this->assertEquals($mibew_api, MibewAPI::getAPI('base'));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testGetAPI
|
||||||
|
*/
|
||||||
|
public function testCheckFunction() {
|
||||||
|
$api = MibewAPI::getAPI('base');
|
||||||
|
|
||||||
|
// Wrong function. Function name is absent
|
||||||
|
$wrong_function = array();
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::VARIABLE_IS_UNDEFINED_IN_RESULT code
|
||||||
|
try {
|
||||||
|
$api->checkFunction($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_FUNCTION_NAME,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function. It have reserved name and second argument in
|
||||||
|
// MibewAPI::checkFunction() will be true.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'result'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::FUNCTION_NAME_RESERVED
|
||||||
|
// code
|
||||||
|
try {
|
||||||
|
$api->checkFunction($wrong_function, true);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::FUNCTION_NAME_RESERVED,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function. It have reserved name, but second argument in
|
||||||
|
// MibewAPI::checkFunction() will be false as default. Also it have no 'arguments'
|
||||||
|
// element.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'result'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_ARGUMENTS code
|
||||||
|
try {
|
||||||
|
$api->checkFunction($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_ARGUMENTS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function. 'arguments' element is an empty array.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'wrong_function',
|
||||||
|
'arguments' => array()
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_ARGUMENTS code
|
||||||
|
try {
|
||||||
|
$api->checkFunction($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_ARGUMENTS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function. 'arguments' element is not array.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'wrong_function',
|
||||||
|
'arguments' => 'not an array'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::WRONG_ARGUMENTS_TYPE code
|
||||||
|
try {
|
||||||
|
$api->checkFunction($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::WRONG_ARGUMENTS_TYPE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function. The obligatary arguments missed.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'wrong_function',
|
||||||
|
'arguments' => array(
|
||||||
|
'x' => 11
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::OBLIGATORY_ARGUMENTS_MISSED code
|
||||||
|
try {
|
||||||
|
$api->checkFunction($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::OBLIGATORY_ARGUMENTS_MISSED,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Another wrong function. Some of the obligatary arguments missed.
|
||||||
|
$wrong_function = array(
|
||||||
|
'function' => 'wrong_function',
|
||||||
|
'arguments' => array(
|
||||||
|
'x' => 11,
|
||||||
|
'return' => array()
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::OBLIGATORY_ARGUMENTS_MISSED code
|
||||||
|
try {
|
||||||
|
$api->checkFunction($wrong_function);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::OBLIGATORY_ARGUMENTS_MISSED,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Correct function
|
||||||
|
$correct_function = array(
|
||||||
|
'function' => 'correct_function',
|
||||||
|
'arguments' => array(
|
||||||
|
'return' => array('name' => 'alias'),
|
||||||
|
'references' => array('x' => 1),
|
||||||
|
'x' => 'argument_from_first_function',
|
||||||
|
'argument_key' => 'argument_value'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$api->checkFunction($correct_function);
|
||||||
|
|
||||||
|
return $correct_function;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testCheckFunction
|
||||||
|
*/
|
||||||
|
public function testCheckRequest($correct_function) {
|
||||||
|
$api = MibewAPI::getAPI('base');
|
||||||
|
|
||||||
|
// Wrong request. Its 'token' element is absent.
|
||||||
|
$wrong_request = array();
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_TOKEN code
|
||||||
|
try {
|
||||||
|
$api->checkRequest($wrong_request);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_TOKEN,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong request. Its 'token' element is empty.
|
||||||
|
$wrong_request = array('token' => '');
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_TOKEN code
|
||||||
|
try {
|
||||||
|
$api->checkRequest($wrong_request);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_TOKEN,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong request. Its 'function' element is absent.
|
||||||
|
$wrong_request = array(
|
||||||
|
'token' => 'some_test_token'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_FUNCTIONS code
|
||||||
|
try {
|
||||||
|
$api->checkRequest($wrong_request);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_FUNCTIONS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong request. Its 'function' element is empty.
|
||||||
|
$wrong_request = array(
|
||||||
|
'token' => 'some_test_token',
|
||||||
|
'functions' => array()
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_FUNCTIONS code
|
||||||
|
try {
|
||||||
|
$api->checkRequest($wrong_request);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_FUNCTIONS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Correct request
|
||||||
|
$correct_request = array(
|
||||||
|
'token' => 'some_test_token',
|
||||||
|
'functions' => array($correct_function, $correct_function)
|
||||||
|
);
|
||||||
|
|
||||||
|
$api->checkRequest($correct_request);
|
||||||
|
|
||||||
|
return $correct_request;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testCheckRequest
|
||||||
|
*/
|
||||||
|
public function testCheckPackage($correct_request) {
|
||||||
|
$api = MibewAPI::getAPI('base');
|
||||||
|
|
||||||
|
$trusted_signatures = array('some_trusted_signature');
|
||||||
|
// Wrong package. Signature element is absent.
|
||||||
|
$wrong_package = array();
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_SIGNATURE code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_SIGNATURE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. Signature element is empty.
|
||||||
|
$wrong_package = array('signature' => '');
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_SIGNATURE code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_SIGNATURE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. Signature is wrong.
|
||||||
|
$wrong_package = array('signature' => 'wrong_signature');
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::UNTRUSTED_SIGNATURE code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::UNTRUSTED_SIGNATURE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. Protocol is absent.
|
||||||
|
$wrong_package = array(
|
||||||
|
'signature' => 'some_trusted_signature'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_PROTOCOL code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_PROTOCOL,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. Protocol is empty.
|
||||||
|
$wrong_package = array(
|
||||||
|
'signature' => 'some_trusted_signature',
|
||||||
|
'proto' => ''
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_PROTOCOL code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_PROTOCOL,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. Protocol is wrong.
|
||||||
|
$wrong_package = array(
|
||||||
|
'signature' => 'some_trusted_signature',
|
||||||
|
'proto' => 'wrong_protocol'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::WRONG_PROTOCOL_VERSION
|
||||||
|
// code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::WRONG_PROTOCOL_VERSION,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. 'async' flag is absent.
|
||||||
|
$wrong_package = array(
|
||||||
|
'signature' => 'some_trusted_signature',
|
||||||
|
'proto' => MibewAPI::PROTOCOL_VERSION
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::ASYNC_FLAG_MISSED code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::ASYNC_FLAG_MISSED,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. 'async' flag is wrong.
|
||||||
|
$wrong_package = array(
|
||||||
|
'signature' => 'some_trusted_signature',
|
||||||
|
'proto' => MibewAPI::PROTOCOL_VERSION,
|
||||||
|
'async' => 'wrong_async_flag'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::WRONG_ASYNC_FLAG_VALUE
|
||||||
|
// code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::WRONG_ASYNC_FLAG_VALUE,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. Requests is absent.
|
||||||
|
$wrong_package = array(
|
||||||
|
'signature' => 'some_trusted_signature',
|
||||||
|
'proto' => MibewAPI::PROTOCOL_VERSION,
|
||||||
|
'async' => false
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_REQUESTS code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_REQUESTS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong package. Requests is empty.
|
||||||
|
$wrong_package = array(
|
||||||
|
'signature' => 'some_trusted_signature',
|
||||||
|
'proto' => MibewAPI::PROTOCOL_VERSION,
|
||||||
|
'async' => false,
|
||||||
|
'requests' => array()
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::EMPTY_REQUESTS code
|
||||||
|
try {
|
||||||
|
$api->checkPackage($wrong_package, $trusted_signatures);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::EMPTY_REQUESTS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Correct package.
|
||||||
|
$correct_package = array(
|
||||||
|
'signature' => 'some_trusted_signature',
|
||||||
|
'proto' => MibewAPI::PROTOCOL_VERSION,
|
||||||
|
'async' => false,
|
||||||
|
'requests' => array($correct_request, $correct_request)
|
||||||
|
);
|
||||||
|
|
||||||
|
$api->checkPackage($correct_package, $trusted_signatures);
|
||||||
|
|
||||||
|
return $correct_package;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testCheckPackage
|
||||||
|
*/
|
||||||
|
public function testEncodePackage($correct_package) {
|
||||||
|
$api = MibewAPI::getAPI('base');
|
||||||
|
|
||||||
|
// Get package values
|
||||||
|
$requests = $correct_package['requests'];
|
||||||
|
$signature = $correct_package['signature'];
|
||||||
|
$async = $correct_package['async'];
|
||||||
|
// Encode package
|
||||||
|
$encoded_package = $api->encodePackage($requests, $signature, $async);
|
||||||
|
$this->assertEquals(
|
||||||
|
urlencode(json_encode($correct_package)),
|
||||||
|
$encoded_package
|
||||||
|
);
|
||||||
|
return array(
|
||||||
|
'package' => $correct_package,
|
||||||
|
'encoded_package' => $encoded_package
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testEncodePackage
|
||||||
|
*/
|
||||||
|
public function testDecodePackage($vars) {
|
||||||
|
$api = MibewAPI::getAPI('base');
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with MibewAPIException::NOT_VALID_JSON code
|
||||||
|
try {
|
||||||
|
$api->decodePackage(
|
||||||
|
substr(
|
||||||
|
$vars['encoded_package'],
|
||||||
|
// Break package
|
||||||
|
ceil(strlen($vars['encoded_package']) / 2)
|
||||||
|
),
|
||||||
|
array('some_trusted_signature')
|
||||||
|
);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::NOT_VALID_JSON,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
$vars['package'],
|
||||||
|
$api->decodePackage(
|
||||||
|
$vars['encoded_package'],
|
||||||
|
array('some_trusted_signature')
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testGetAPI
|
||||||
|
*/
|
||||||
|
public function testGetResultFunction() {
|
||||||
|
$api = MibewAPI::getAPI('base');
|
||||||
|
|
||||||
|
// Wrong functions list. More than one result function.
|
||||||
|
$functions_list = array(
|
||||||
|
array(
|
||||||
|
'function' => 'result',
|
||||||
|
'num' => 1
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'function' => 'result',
|
||||||
|
'num' => 2
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::RESULT_FUNCTION_ALREADY_EXISTS code
|
||||||
|
try {
|
||||||
|
$api->getResultFunction($functions_list, null);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::RESULT_FUNCTION_ALREADY_EXISTS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong functions list. Result function not exists, but getResultFunction's second
|
||||||
|
// argument is true
|
||||||
|
$functions_list = array();
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::NO_RESULT_FUNCTION code
|
||||||
|
try {
|
||||||
|
$api->getResultFunction($functions_list, true);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::NO_RESULT_FUNCTION,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Wrong functions list. Result function exists, but getResultFunction's second
|
||||||
|
// argument is false
|
||||||
|
$functions_list = array(
|
||||||
|
array(
|
||||||
|
'function' => 'result',
|
||||||
|
'num' => 1
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Try to catch MibewAPIException with
|
||||||
|
// MibewAPIException::RESULT_FUNCTION_EXISTS code
|
||||||
|
try {
|
||||||
|
$api->getResultFunction($functions_list, false);
|
||||||
|
$this->fail("Exception must be thrown");
|
||||||
|
} catch (MibewAPIException $e) {
|
||||||
|
$this->assertEquals(
|
||||||
|
MibewAPIException::RESULT_FUNCTION_EXISTS,
|
||||||
|
$e->getCode()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Correct functions list. Result function not exists and getResultFunction's second
|
||||||
|
// argument is false
|
||||||
|
$functions_list = array();
|
||||||
|
|
||||||
|
$this->assertEquals(null, $api->getResultFunction($functions_list, false));
|
||||||
|
|
||||||
|
// Correct functions list. Result function exists and getResultFunction's second
|
||||||
|
// argument is true
|
||||||
|
$functions_list = array(
|
||||||
|
array(
|
||||||
|
'function' => 'result',
|
||||||
|
'num' => 1
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
$functions_list[0],
|
||||||
|
$api->getResultFunction($functions_list, true)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Correct functions list. Result function not exists and getResultFunction's second
|
||||||
|
// argument is null
|
||||||
|
$functions_list = array();
|
||||||
|
|
||||||
|
$this->assertEquals(null, $api->getResultFunction($functions_list, null));
|
||||||
|
|
||||||
|
// Correct functions list. Result function exists and getResultFunction's second
|
||||||
|
// argument is null
|
||||||
|
$functions_list = array(
|
||||||
|
array(
|
||||||
|
'function' => 'result',
|
||||||
|
'num' => 1
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
$functions_list[0],
|
||||||
|
$api->getResultFunction($functions_list, null)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @depends testGetAPI
|
||||||
|
*/
|
||||||
|
public function testBuildResult() {
|
||||||
|
$api = MibewAPI::getAPI('base');
|
||||||
|
|
||||||
|
$token = 'some_test_token';
|
||||||
|
$package = array(
|
||||||
|
'token' => $token,
|
||||||
|
'functions' => array(
|
||||||
|
array(
|
||||||
|
'function' => 'result',
|
||||||
|
'arguments' => array(
|
||||||
|
'references' => array(),
|
||||||
|
'return' => array(),
|
||||||
|
'test_argument' => 'test_value'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
$package,
|
||||||
|
$api->buildResult($token, array('test_argument' => 'test_value'))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
567
src/messenger/webim/libs/mibew_api.php
Normal file
567
src/messenger/webim/libs/mibew_api.php
Normal file
@ -0,0 +1,567 @@
|
|||||||
|
<?php
|
||||||
|
/*
|
||||||
|
* Copyright 2005-2013 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implements Mibew API specification version 1.0
|
||||||
|
*
|
||||||
|
* @todo May be use regular methods instead of static one
|
||||||
|
*/
|
||||||
|
Class MibewAPI {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Version of the MIBEW API protocol implemented by the class
|
||||||
|
*/
|
||||||
|
const PROTOCOL_VERSION = '1.0';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Array of MibewAPI objects
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected static $interactions = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An object that encapsulates type of the interaction
|
||||||
|
*
|
||||||
|
* @var MibewAPIInteraction
|
||||||
|
*/
|
||||||
|
protected $interaction = NULL;
|
||||||
|
|
||||||
|
public static function getAPI($interaction_type) {
|
||||||
|
$class_name = "MibewAPI". ucfirst($interaction_type) . "Interaction";
|
||||||
|
if (! class_exists($class_name)) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Wrong interaction type",
|
||||||
|
MibewAPIException::WRONG_INTERACTION_TYPE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if (empty(self::$interactions[$interaction_type])) {
|
||||||
|
self::$interactions[$interaction_type] = new self(new $class_name());
|
||||||
|
}
|
||||||
|
return self::$interactions[$interaction_type];
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function __construct(MibewAPIInteraction $interaction_type) {
|
||||||
|
$this->interaction = $interaction_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate package
|
||||||
|
*
|
||||||
|
* @param array $package Package array. See Mibew API for details.
|
||||||
|
* @param array $trusted_signatures Array of trusted signatures.
|
||||||
|
* @throws MibewAPIException
|
||||||
|
*/
|
||||||
|
public function checkPackage($package, $trusted_signatures) {
|
||||||
|
// Check signature
|
||||||
|
if (empty($package['signature'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Package signature is empty",
|
||||||
|
MibewAPIException::EMPTY_SIGNATURE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if (! in_array($package['signature'], $trusted_signatures)) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Package signed with untrusted signature",
|
||||||
|
MibewAPIException::UNTRUSTED_SIGNATURE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check protocol
|
||||||
|
if (empty($package['proto'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Package protocol is empty",
|
||||||
|
MibewAPIException::EMPTY_PROTOCOL
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if ($package['proto'] != self::PROTOCOL_VERSION) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Wrong package protocol version '{$package['proto']}'",
|
||||||
|
MibewAPIException::WRONG_PROTOCOL_VERSION
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check async flag
|
||||||
|
if (! isset($package['async'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"'async' flag is missed",
|
||||||
|
MibewAPIException::ASYNC_FLAG_MISSED
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if (! is_bool($package['async'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Wrong 'async' flag value",
|
||||||
|
MibewAPIException::WRONG_ASYNC_FLAG_VALUE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Package must have at least one request
|
||||||
|
if (empty($package['requests'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Empty requests set",
|
||||||
|
MibewAPIException::EMPTY_REQUESTS
|
||||||
|
);
|
||||||
|
}
|
||||||
|
// Check requests in package
|
||||||
|
foreach ($package['requests'] as $request) {
|
||||||
|
$this->checkRequest($request);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate request
|
||||||
|
*
|
||||||
|
* @param array $request Request array. See Mibew API for details.
|
||||||
|
* @throws MibewAPIException
|
||||||
|
*/
|
||||||
|
public function checkRequest($request) {
|
||||||
|
// Check token
|
||||||
|
if (empty($request['token'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Empty request token",
|
||||||
|
MibewAPIException::EMPTY_TOKEN
|
||||||
|
);
|
||||||
|
}
|
||||||
|
// Request must have at least one function
|
||||||
|
if (empty($request['functions'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Empty functions set",
|
||||||
|
MibewAPIException::EMPTY_FUNCTIONS
|
||||||
|
);
|
||||||
|
}
|
||||||
|
// Check functions in request
|
||||||
|
foreach ($request['functions'] as $function) {
|
||||||
|
$this->checkFunction($function);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate function
|
||||||
|
*
|
||||||
|
* @param array $function Function array. See Mibew API for details.
|
||||||
|
* @param boolean $filter_reserved_functions Determine if function name must not be in
|
||||||
|
* reserved list
|
||||||
|
* @throws MibewAPIException
|
||||||
|
*/
|
||||||
|
public function checkFunction($function, $filter_reserved_functions = false) {
|
||||||
|
// Check function name
|
||||||
|
if (empty($function['function'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
'Cannot call for function with empty name',
|
||||||
|
MibewAPIException::EMPTY_FUNCTION_NAME
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if ($filter_reserved_functions) {
|
||||||
|
if (in_array(
|
||||||
|
$function['function'],
|
||||||
|
$this->interaction->reservedFunctionNames
|
||||||
|
)) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"'{$function['function']}' is reserved function name",
|
||||||
|
MibewAPIException::FUNCTION_NAME_RESERVED
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Check function's arguments
|
||||||
|
if (empty($function['arguments'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"There are no arguments in '{$function['function']}' function",
|
||||||
|
MibewAPIException::EMPTY_ARGUMENTS
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if (! is_array($function['arguments'])) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Arguments must be an array",
|
||||||
|
MibewAPIException::WRONG_ARGUMENTS_TYPE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$unset_arguments = array_diff(
|
||||||
|
$this->interaction->obligatoryArguments,
|
||||||
|
array_keys($function['arguments'])
|
||||||
|
);
|
||||||
|
if (! empty($unset_arguments)) {
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Arguments '" . implode("', '", $unset_arguments) . "' must be set",
|
||||||
|
MibewAPIException::OBLIGATORY_ARGUMENTS_MISSED
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Encodes package
|
||||||
|
*
|
||||||
|
* @param array $requests Requests array. See Mibew API for details.
|
||||||
|
* @param string $signature Sender signature.
|
||||||
|
* @param boolean $async true for asynchronous request and false for synchronous request
|
||||||
|
* @return string Ready for transfer encoded package
|
||||||
|
*/
|
||||||
|
public function encodePackage($requests, $signature, $async) {
|
||||||
|
$package = array();
|
||||||
|
$package['signature'] = $signature;
|
||||||
|
$package['proto'] = self::PROTOCOL_VERSION;
|
||||||
|
$package['async'] = $async;
|
||||||
|
$package['requests'] = $requests;
|
||||||
|
return urlencode(json_encode($package));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Decodes package and validate package structure
|
||||||
|
*
|
||||||
|
* @param string $package Encoded package
|
||||||
|
* @param array $trusted_signatures List of trusted signatures
|
||||||
|
* @return array Decoded package array. See Mibew API for details.
|
||||||
|
* @throws MibewAPIException
|
||||||
|
*/
|
||||||
|
public function decodePackage($package, $trusted_signatures) {
|
||||||
|
$decoded_package = urldecode($package);
|
||||||
|
// JSON regular expression
|
||||||
|
$pcre_regex = '/
|
||||||
|
(?(DEFINE)
|
||||||
|
(?<number> -? (?= [1-9]|0(?!\d) ) \d+ (\.\d+)? ([eE] [+-]? \d+)? )
|
||||||
|
(?<boolean> true | false | null )
|
||||||
|
(?<string> " ([^"\\\\]* | \\\\ ["\\\\bfnrt\/] | \\\\ u [0-9a-f]{4} )* " )
|
||||||
|
(?<array> \[ (?: (?&json) (?: , (?&json) )* )? \s* \] )
|
||||||
|
(?<pair> \s* (?&string) \s* : (?&json) )
|
||||||
|
(?<object> \{ (?: (?&pair) (?: , (?&pair) )* )? \s* \} )
|
||||||
|
(?<json> \s* (?: (?&number) | (?&boolean) | (?&string) | (?&array) | (?&object) ) \s* )
|
||||||
|
)
|
||||||
|
\A (?&json) \Z
|
||||||
|
/six';
|
||||||
|
// Check JSON
|
||||||
|
if (!preg_match($pcre_regex, $decoded_package)) {
|
||||||
|
// Not valid JSON
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Package have not valid json structure",
|
||||||
|
MibewAPIException::NOT_VALID_JSON
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$decoded_package = json_decode($decoded_package, true);
|
||||||
|
$this->checkPackage($decoded_package, $trusted_signatures);
|
||||||
|
return $decoded_package;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Builds result package
|
||||||
|
*
|
||||||
|
* @param string $token Token of the result package
|
||||||
|
* @param array $result_arguments Arguments of result function
|
||||||
|
* @return Result package
|
||||||
|
*/
|
||||||
|
public function buildResult($token, $result_arguments) {
|
||||||
|
$arguments = $result_arguments + $this->interaction->getDefaultObligatoryArguments();
|
||||||
|
$package = array(
|
||||||
|
'token' => $token,
|
||||||
|
'functions' => array(
|
||||||
|
array(
|
||||||
|
'function' => 'result',
|
||||||
|
'arguments' => $arguments
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
return $package;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Search 'result' function in $function_list. If request contains more than one result
|
||||||
|
* functions throws an MibewAPIException
|
||||||
|
*
|
||||||
|
* @param array $functions_list Array of functions. See MibewAPI for function structure
|
||||||
|
* details
|
||||||
|
* @param mixed $existance Control existance of the 'result' function in request.
|
||||||
|
* Use boolean true if 'result' function must exists in request, boolean false if must not
|
||||||
|
* and null if it doesn't matter.
|
||||||
|
* @return mixed Function array if 'result' function found and NULL otherwise
|
||||||
|
* @throws MibewAPIException
|
||||||
|
*/
|
||||||
|
public function getResultFunction ($functions_list, $existence) {
|
||||||
|
$result_function = null;
|
||||||
|
// Try to find 'result' function
|
||||||
|
foreach ($functions_list as $function) {
|
||||||
|
if ($function['function'] == 'result') {
|
||||||
|
if (! is_null($result_function)) {
|
||||||
|
// Another 'result' function found
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Function 'result' already exists in request",
|
||||||
|
MibewAPIException::RESULT_FUNCTION_ALREADY_EXISTS
|
||||||
|
);
|
||||||
|
}
|
||||||
|
// Furst 'result' function found
|
||||||
|
$result_function = $function;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($existence === true && is_null($result_function)) {
|
||||||
|
// 'result' function must present in request
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"There is no 'result' function in request",
|
||||||
|
MibewAPIException::NO_RESULT_FUNCTION
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if ($existence === false && !is_null($result_function)) {
|
||||||
|
// 'result' function must not present in request
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"There is 'result' function in request",
|
||||||
|
MibewAPIException::RESULT_FUNCTION_EXISTS
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return $result_function;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implements functions execution context
|
||||||
|
*/
|
||||||
|
Class MibewAPIExecutionContext {
|
||||||
|
/**
|
||||||
|
* Values which returns after execution of all functions in request
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $return = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Results of execution of all function in request
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $functions_results = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns requets results
|
||||||
|
*
|
||||||
|
* @return array Request results
|
||||||
|
* @see MibewAPIExecutionContext::$return
|
||||||
|
*/
|
||||||
|
public function getResults () {
|
||||||
|
return $this->return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Build arguments list by replace all references by values of execution context
|
||||||
|
*
|
||||||
|
* @param array $function Function array. See MibewAPI for details.
|
||||||
|
* @return array Arguments list
|
||||||
|
* @throws MibewAPIException
|
||||||
|
*/
|
||||||
|
public function getArgumentsList ($function) {
|
||||||
|
$arguments = $function['arguments'];
|
||||||
|
$references = $function['arguments']['references'];
|
||||||
|
foreach ($references as $variable => $func_num) {
|
||||||
|
// Check target function in context
|
||||||
|
if (! isset($this->functions_results[$func_num - 1])) {
|
||||||
|
// Wrong function num
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Wrong reference in '{$function['function']}' function. " .
|
||||||
|
"Function #{$func_num} does not call yet.",
|
||||||
|
MibewAPIException::WRONG_FUNCTION_NUM_IN_REFERENCE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check reference
|
||||||
|
if (empty($arguments[$variable])) {
|
||||||
|
// Empty argument that should contains reference
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Wrong reference in '{$function['function']}' function. " .
|
||||||
|
"Empty {$variable} argument.",
|
||||||
|
MibewAPIException::EMPTY_VARIABLE_IN_REFERENCE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$reference_to = $arguments[$variable];
|
||||||
|
|
||||||
|
// Check target value
|
||||||
|
if (! isset($this->functions_results[$func_num - 1][$reference_to])) {
|
||||||
|
// Undefined target value
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Wrong reference in '{$function['function']}' function. " .
|
||||||
|
"There is no '{$reference_to}' argument in #{$func_num} " .
|
||||||
|
"function results",
|
||||||
|
MibewAPIException::VARIABLE_IS_UNDEFINED_IN_REFERENCE
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Replace reference by target value
|
||||||
|
$arguments[$variable] = $this->functions_results[$func_num - 1][$reference_to];
|
||||||
|
}
|
||||||
|
return $arguments;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Stores functions results in execution context and add values to request result
|
||||||
|
*
|
||||||
|
* @param array $function Function array. See MibewAPI for details.
|
||||||
|
* @param array $results Associative array of the function results.
|
||||||
|
* @throws MibewAPIException
|
||||||
|
*/
|
||||||
|
public function storeFunctionResults ($function, $results) {
|
||||||
|
// Add value to request results
|
||||||
|
foreach ($function['arguments']['return'] as $name => $alias) {
|
||||||
|
if (! isset($results[$name])) {
|
||||||
|
// Value that defined in 'return' argument is undefined
|
||||||
|
throw new MibewAPIException(
|
||||||
|
"Variable with name '{$name}' is undefined in the " .
|
||||||
|
"results of the '{$function['function']}' function",
|
||||||
|
MibewAPIException::VARIABLE_IS_UNDEFINED_IN_RESULT
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$this->return[$alias] = $results[$name];
|
||||||
|
}
|
||||||
|
// Store function results in execution context
|
||||||
|
$this->functions_results[] = $results;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Encapsulates interaction type
|
||||||
|
*/
|
||||||
|
abstract class MibewAPIInteraction {
|
||||||
|
/**
|
||||||
|
* Abligatory arguments in called functions
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public $obligatoryArguments;
|
||||||
|
/**
|
||||||
|
* Reserved function names
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public $reservedFunctionNames;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns default values of obligatory arguments
|
||||||
|
*
|
||||||
|
* @return array Associative array with keys are obligatory arguments and values are default
|
||||||
|
* values of them
|
||||||
|
*/
|
||||||
|
abstract public function getDefaultObligatoryArguments();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implements Base Mibew Interaction
|
||||||
|
*/
|
||||||
|
class MibewAPIBaseInteraction extends MibewAPIInteraction {
|
||||||
|
public $obligatoryArguments = array(
|
||||||
|
'references',
|
||||||
|
'return'
|
||||||
|
);
|
||||||
|
|
||||||
|
public $reservedFunctionNames = array(
|
||||||
|
'result'
|
||||||
|
);
|
||||||
|
|
||||||
|
public function getDefaultObligatoryArguments() {
|
||||||
|
return array(
|
||||||
|
'references' => array(),
|
||||||
|
'return' => array()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mibew API Exception class.
|
||||||
|
*/
|
||||||
|
class MibewAPIException extends Exception {
|
||||||
|
/**
|
||||||
|
* Async flag is missed.
|
||||||
|
*/
|
||||||
|
const ASYNC_FLAG_MISSED = 1;
|
||||||
|
/**
|
||||||
|
* There are no arguments in function
|
||||||
|
*/
|
||||||
|
const EMPTY_ARGUMENTS = 2;
|
||||||
|
/**
|
||||||
|
* Cannot call for function with empty name
|
||||||
|
*/
|
||||||
|
const EMPTY_FUNCTION_NAME = 3;
|
||||||
|
/**
|
||||||
|
* Functions set is empty
|
||||||
|
*/
|
||||||
|
const EMPTY_FUNCTIONS = 4;
|
||||||
|
/**
|
||||||
|
* Package protocol is empty
|
||||||
|
*/
|
||||||
|
const EMPTY_PROTOCOL = 5;
|
||||||
|
/**
|
||||||
|
* Requests set is empty
|
||||||
|
*/
|
||||||
|
const EMPTY_REQUESTS = 6;
|
||||||
|
/**
|
||||||
|
* Package signature is empty
|
||||||
|
*/
|
||||||
|
const EMPTY_SIGNATURE = 7;
|
||||||
|
/**
|
||||||
|
* Request token is empty
|
||||||
|
*/
|
||||||
|
const EMPTY_TOKEN = 8;
|
||||||
|
/**
|
||||||
|
* Wrong reference. Reference variable is empty
|
||||||
|
*/
|
||||||
|
const EMPTY_VARIABLE_IN_REFERENCE = 9;
|
||||||
|
/**
|
||||||
|
* This function name is reserved
|
||||||
|
*/
|
||||||
|
const FUNCTION_NAME_RESERVED = 10;
|
||||||
|
/**
|
||||||
|
* There is no result function
|
||||||
|
*/
|
||||||
|
const NO_RESULT_FUNCTION = 11;
|
||||||
|
/**
|
||||||
|
* Package have not valid JSON structure
|
||||||
|
*/
|
||||||
|
const NOT_VALID_JSON = 12;
|
||||||
|
/**
|
||||||
|
* Some of the function's obligatory arguments are missed
|
||||||
|
*/
|
||||||
|
const OBLIGATORY_ARGUMENTS_MISSED = 13;
|
||||||
|
/**
|
||||||
|
* Request contains more than one result functions
|
||||||
|
*/
|
||||||
|
const RESULT_FUNCTION_ALREADY_EXISTS = 14;
|
||||||
|
/**
|
||||||
|
* There is 'result' function in request
|
||||||
|
*/
|
||||||
|
const RESULT_FUNCTION_EXISTS = 15;
|
||||||
|
/**
|
||||||
|
* Package signed with untrusted signature
|
||||||
|
*/
|
||||||
|
const UNTRUSTED_SIGNATURE = 16;
|
||||||
|
/**
|
||||||
|
* Wrong reference. Variable is undefined in functions results
|
||||||
|
*/
|
||||||
|
const VARIABLE_IS_UNDEFINED_IN_REFERENCE = 17;
|
||||||
|
/**
|
||||||
|
* Variable is undefined in function's results
|
||||||
|
*/
|
||||||
|
const VARIABLE_IS_UNDEFINED_IN_RESULT = 18;
|
||||||
|
/**
|
||||||
|
* Arguments must be an array
|
||||||
|
*/
|
||||||
|
const WRONG_ARGUMENTS_TYPE = 19;
|
||||||
|
/**
|
||||||
|
* Async flag value is wrong
|
||||||
|
*/
|
||||||
|
const WRONG_ASYNC_FLAG_VALUE = 20;
|
||||||
|
/**
|
||||||
|
* Wrong reference. Function with this number does not call yet
|
||||||
|
*/
|
||||||
|
const WRONG_FUNCTION_NUM_IN_REFERENCE = 21;
|
||||||
|
/**
|
||||||
|
* Wrong interaction type
|
||||||
|
*/
|
||||||
|
const WRONG_INTERACTION_TYPE = 22;
|
||||||
|
/**
|
||||||
|
* Wrong package protocol version
|
||||||
|
*/
|
||||||
|
const WRONG_PROTOCOL_VERSION = 23;
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
Loading…
Reference in New Issue
Block a user