Add ExternalTaskManager class
This commit is contained in:
@@ -17,6 +17,7 @@ use Pimple\Container;
|
|||||||
* @property \Kanboard\Analytic\AverageTimeSpentColumnAnalytic $averageTimeSpentColumnAnalytic
|
* @property \Kanboard\Analytic\AverageTimeSpentColumnAnalytic $averageTimeSpentColumnAnalytic
|
||||||
* @property \Kanboard\Core\Action\ActionManager $actionManager
|
* @property \Kanboard\Core\Action\ActionManager $actionManager
|
||||||
* @property \Kanboard\Core\ExternalLink\ExternalLinkManager $externalLinkManager
|
* @property \Kanboard\Core\ExternalLink\ExternalLinkManager $externalLinkManager
|
||||||
|
* @property \Kanboard\Core\ExternalTask\ExternalTaskManager $externalTaskManager
|
||||||
* @property \Kanboard\Core\Cache\MemoryCache $memoryCache
|
* @property \Kanboard\Core\Cache\MemoryCache $memoryCache
|
||||||
* @property \Kanboard\Core\Cache\BaseCache $cacheDriver
|
* @property \Kanboard\Core\Cache\BaseCache $cacheDriver
|
||||||
* @property \Kanboard\Core\Event\EventManager $eventManager
|
* @property \Kanboard\Core\Event\EventManager $eventManager
|
||||||
|
|||||||
14
app/Core/ExternalTask/AccessForbiddenException.php
Normal file
14
app/Core/ExternalTask/AccessForbiddenException.php
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kanboard\Core\ExternalTask;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class AccessForbiddenException
|
||||||
|
*
|
||||||
|
* @package Kanboard\Core\ExternalTask
|
||||||
|
*/
|
||||||
|
class AccessForbiddenException extends Exception
|
||||||
|
{
|
||||||
|
}
|
||||||
53
app/Core/ExternalTask/ExternalTaskManager.php
Normal file
53
app/Core/ExternalTask/ExternalTaskManager.php
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kanboard\Core\ExternalTask;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class ExternalTaskManager
|
||||||
|
*
|
||||||
|
* @package Kanboard\Core\ExternalTask
|
||||||
|
* @author Frederic Guillot
|
||||||
|
*/
|
||||||
|
class ExternalTaskManager
|
||||||
|
{
|
||||||
|
protected $providers = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Register a new task provider
|
||||||
|
*
|
||||||
|
* @param ExternalTaskProviderInterface $externalTaskProvider
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function register(ExternalTaskProviderInterface $externalTaskProvider)
|
||||||
|
{
|
||||||
|
$this->providers[$externalTaskProvider->getName()] = $externalTaskProvider;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get task provider
|
||||||
|
*
|
||||||
|
* @param string $name
|
||||||
|
* @return ExternalTaskProviderInterface|null
|
||||||
|
* @throws ProviderNotFoundException
|
||||||
|
*/
|
||||||
|
public function getProvider($name)
|
||||||
|
{
|
||||||
|
if (isset($this->providers[$name])) {
|
||||||
|
return $this->providers[$name];
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new ProviderNotFoundException('Unable to load this provider: '.$name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get list of task providers
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function getProvidersList()
|
||||||
|
{
|
||||||
|
$providers = array_keys($this->providers);
|
||||||
|
return array_combine($providers, $providers);
|
||||||
|
}
|
||||||
|
}
|
||||||
50
app/Core/ExternalTask/ExternalTaskProviderInterface.php
Normal file
50
app/Core/ExternalTask/ExternalTaskProviderInterface.php
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kanboard\Core\ExternalTask;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Interface ExternalTaskProviderInterface
|
||||||
|
*
|
||||||
|
* @package Kanboard\Core\ExternalTask
|
||||||
|
* @author Frederic Guillot
|
||||||
|
*/
|
||||||
|
interface ExternalTaskProviderInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get templates
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getCreationFormTemplate();
|
||||||
|
public function getModificationFormTemplate();
|
||||||
|
public function getTaskViewTemplate();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get provider name (visible in the user interface)
|
||||||
|
*
|
||||||
|
* @access public
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getName();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve task from external system or cache
|
||||||
|
*
|
||||||
|
* @access public
|
||||||
|
* @throws \Kanboard\Core\ExternalTask\AccessForbiddenException
|
||||||
|
* @throws \Kanboard\Core\ExternalTask\NotFoundException
|
||||||
|
* @param string $uri
|
||||||
|
* @return array Dict that will populate the form
|
||||||
|
*/
|
||||||
|
public function retrieve($uri);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Save the task to the external system and/or update the cache
|
||||||
|
*
|
||||||
|
* @access public
|
||||||
|
* @param string $uri
|
||||||
|
* @param array $data
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function persist($uri, array $data);
|
||||||
|
}
|
||||||
15
app/Core/ExternalTask/NotFoundException.php
Normal file
15
app/Core/ExternalTask/NotFoundException.php
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kanboard\Core\ExternalTask;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class NotFoundException
|
||||||
|
*
|
||||||
|
* @package Kanboard\Core\ExternalTask
|
||||||
|
* @author Frederic Guillot
|
||||||
|
*/
|
||||||
|
class NotFoundException extends Exception
|
||||||
|
{
|
||||||
|
}
|
||||||
15
app/Core/ExternalTask/ProviderNotFoundException.php
Normal file
15
app/Core/ExternalTask/ProviderNotFoundException.php
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kanboard\Core\ExternalTask;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class ProviderNotFoundException
|
||||||
|
*
|
||||||
|
* @package Kanboard\Core\ExternalTask
|
||||||
|
* @author Frederic Guillot
|
||||||
|
*/
|
||||||
|
class ProviderNotFoundException extends Exception
|
||||||
|
{
|
||||||
|
}
|
||||||
29
app/ServiceProvider/ExternalTaskProvider.php
Normal file
29
app/ServiceProvider/ExternalTaskProvider.php
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Kanboard\ServiceProvider;
|
||||||
|
|
||||||
|
use Kanboard\Core\ExternalTask\ExternalTaskManager;
|
||||||
|
use Pimple\Container;
|
||||||
|
use Pimple\ServiceProviderInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class ExternalTaskProvider
|
||||||
|
*
|
||||||
|
* @package Kanboard\ServiceProvider
|
||||||
|
* @author Frederic Guillot
|
||||||
|
*/
|
||||||
|
class ExternalTaskProvider implements ServiceProviderInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Register providers
|
||||||
|
*
|
||||||
|
* @access public
|
||||||
|
* @param \Pimple\Container $container
|
||||||
|
* @return \Pimple\Container
|
||||||
|
*/
|
||||||
|
public function register(Container $container)
|
||||||
|
{
|
||||||
|
$container['externalTaskManager'] = new ExternalTaskManager();
|
||||||
|
return $container;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -45,6 +45,7 @@ $container->register(new Kanboard\ServiceProvider\GroupProvider());
|
|||||||
$container->register(new Kanboard\ServiceProvider\RouteProvider());
|
$container->register(new Kanboard\ServiceProvider\RouteProvider());
|
||||||
$container->register(new Kanboard\ServiceProvider\ActionProvider());
|
$container->register(new Kanboard\ServiceProvider\ActionProvider());
|
||||||
$container->register(new Kanboard\ServiceProvider\ExternalLinkProvider());
|
$container->register(new Kanboard\ServiceProvider\ExternalLinkProvider());
|
||||||
|
$container->register(new Kanboard\ServiceProvider\ExternalTaskProvider());
|
||||||
$container->register(new Kanboard\ServiceProvider\AvatarProvider());
|
$container->register(new Kanboard\ServiceProvider\AvatarProvider());
|
||||||
$container->register(new Kanboard\ServiceProvider\FilterProvider());
|
$container->register(new Kanboard\ServiceProvider\FilterProvider());
|
||||||
$container->register(new Kanboard\ServiceProvider\JobProvider());
|
$container->register(new Kanboard\ServiceProvider\JobProvider());
|
||||||
|
|||||||
44
tests/units/Core/ExternalTask/ExternalTaskManagerTest.php
Normal file
44
tests/units/Core/ExternalTask/ExternalTaskManagerTest.php
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
use Kanboard\Core\ExternalTask\ExternalTaskManager;
|
||||||
|
|
||||||
|
require_once __DIR__.'/../../Base.php';
|
||||||
|
|
||||||
|
class ExternalTaskManagerTest extends Base
|
||||||
|
{
|
||||||
|
public function testProviderNotFound()
|
||||||
|
{
|
||||||
|
$this->setExpectedException('Kanboard\Core\ExternalTask\ProviderNotFoundException');
|
||||||
|
|
||||||
|
$manager = new ExternalTaskManager();
|
||||||
|
$manager->getProvider('foobar');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testRegister()
|
||||||
|
{
|
||||||
|
$provider = $this->getMock('Kanboard\Core\ExternalTask\ExternalTaskProviderInterface');
|
||||||
|
$provider->expects($this->any())->method('getName')->willReturn('MyProvider');
|
||||||
|
|
||||||
|
$manager = new ExternalTaskManager();
|
||||||
|
$manager->register($provider);
|
||||||
|
|
||||||
|
$this->assertInstanceOf('Kanboard\Core\ExternalTask\ExternalTaskProviderInterface', $manager->getProvider('MyProvider'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetList()
|
||||||
|
{
|
||||||
|
$provider1 = $this->getMock('Kanboard\Core\ExternalTask\ExternalTaskProviderInterface');
|
||||||
|
$provider1->expects($this->any())->method('getName')->willReturn('MyProvider1');
|
||||||
|
|
||||||
|
$provider2 = $this->getMock('Kanboard\Core\ExternalTask\ExternalTaskProviderInterface');
|
||||||
|
$provider2->expects($this->any())->method('getName')->willReturn('MyProvider2');
|
||||||
|
|
||||||
|
$manager = new ExternalTaskManager();
|
||||||
|
$manager->register($provider1);
|
||||||
|
$manager->register($provider2);
|
||||||
|
$providers = $manager->getProvidersList();
|
||||||
|
|
||||||
|
$expected = array('MyProvider1' => 'MyProvider1', 'MyProvider2' => 'MyProvider2');
|
||||||
|
$this->assertEquals($expected, $providers);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user