diff options
author | Frederic Guillot <fred@kanboard.net> | 2015-05-23 21:44:33 -0400 |
---|---|---|
committer | Frederic Guillot <fred@kanboard.net> | 2015-05-23 21:44:33 -0400 |
commit | e32f26d048249b84166542d6442efdf202ff44fd (patch) | |
tree | 1868c5e83cec5ea8b821ad8a2036543aa37e5adb /jsonrpc.php | |
parent | c9ba525bab06eff76b1d5fb8701848d0e3990122 (diff) |
API refactoring
Diffstat (limited to 'jsonrpc.php')
-rw-r--r-- | jsonrpc.php | 449 |
1 files changed, 14 insertions, 435 deletions
diff --git a/jsonrpc.php b/jsonrpc.php index e5c000c0..b6ec8291 100644 --- a/jsonrpc.php +++ b/jsonrpc.php @@ -2,441 +2,20 @@ require __DIR__.'/app/common.php'; -use Symfony\Component\EventDispatcher\Event; - -$container['dispatcher']->dispatch('api.bootstrap', new Event); - $server = new JsonRPC\Server; -$server->authentication(array('jsonrpc' => $container['config']->get('api_token'))); - -/** - * Project procedures - */ -$server->bind('getProjectById', $container['project'], 'getById'); -$server->bind('getProjectByName', $container['project'], 'getByName'); -$server->bind('getAllProjects', $container['project'], 'getAll'); -$server->bind('removeProject', $container['project'], 'remove'); -$server->bind('enableProject', $container['project'], 'enable'); -$server->bind('disableProject', $container['project'], 'disable'); -$server->bind('enableProjectPublicAccess', $container['project'], 'enablePublicAccess'); -$server->bind('disableProjectPublicAccess', $container['project'], 'disablePublicAccess'); -$server->bind('getProjectActivity', $container['projectActivity'], 'getProjects'); - -$server->register('createProject', function($name, $description = null) use ($container) { - $values = array( - 'name' => $name, - 'description' => $description - ); - list($valid,) = $container['project']->validateCreation($values); - return $valid ? $container['project']->create($values) : false; -}); - -$server->register('updateProject', function($id, $name, $is_active = null, $is_public = null, $token = null, $description = null) use ($container) { - - $values = array( - 'id' => $id, - 'name' => $name, - 'is_active' => $is_active, - 'is_public' => $is_public, - 'token' => $token, - 'description' => $description - ); - - foreach ($values as $key => $value) { - if (is_null($value)) { - unset($values[$key]); - } - } - - list($valid,) = $container['project']->validateModification($values); - return $valid && $container['project']->update($values); -}); - -/** - * Board procedures - */ -$server->bind('getBoard', $container['board'], 'getBoard'); -$server->bind('getColumns', $container['board'], 'getColumns'); -$server->bind('getColumn', $container['board'], 'getColumn'); -$server->bind('moveColumnUp', $container['board'], 'moveUp'); -$server->bind('moveColumnDown', $container['board'], 'moveDown'); -$server->bind('updateColumn', $container['board'], 'updateColumn'); -$server->bind('addColumn', $container['board'], 'addColumn'); -$server->bind('removeColumn', $container['board'], 'removeColumn'); - -/** - * Swimlane procedures - */ -$server->bind('getSwimlanes', $container['swimlane'], 'getSwimlanes'); -$server->bind('getAllSwimlanes', $container['swimlane'], 'getAll'); -$server->bind('getSwimlane', $container['swimlane'], 'getByName'); -$server->bind('addSwimlane', $container['swimlane'], 'create'); -$server->bind('updateSwimlane', $container['swimlane'], 'rename'); -$server->bind('removeSwimlane', $container['swimlane'], 'remove'); -$server->bind('disableSwimlane', $container['swimlane'], 'disable'); -$server->bind('enableSwimlane', $container['swimlane'], 'enable'); -$server->bind('moveSwimlaneUp', $container['swimlane'], 'moveUp'); -$server->bind('moveSwimlaneDown', $container['swimlane'], 'moveDown'); - -/** - * Actions procedures - */ -$server->bind('getAvailableActions', $container['action'], 'getAvailableActions'); -$server->bind('getAvailableEvents', $container['action'], 'getAvailableEvents'); -$server->bind('getCompatibleEvents', $container['action'], 'getCompatibleEvents'); -$server->bind('removeAction', $container['action'], 'remove'); - -$server->register('getActions', function($project_id) use ($container) { - $actions = $container['action']->getAllByProject($project_id); - - foreach ($actions as $index => $action) { - $params = array(); - - foreach($action['params'] as $param) { - $params[$param['name']] = $param['value']; - } - - $actions[$index]['params'] = $params; - } - - return $actions; -}); - -$server->register('createAction', function($project_id, $event_name, $action_name, $params) use ($container) { - - $values = array( - 'project_id' => $project_id, - 'event_name' => $event_name, - 'action_name' => $action_name, - 'params' => $params, - ); - - list($valid,) = $container['action']->validateCreation($values); - - if (! $valid) { - return false; - } - - // Check the action exists - $actions = $container['action']->getAvailableActions(); - - if (! isset($actions[$action_name])) { - return false; - } - - // Check the event - $action = $container['action']->load($action_name, $project_id, $event_name); - - if (! in_array($event_name, $action->getCompatibleEvents())) { - return false; - } - - $required_params = $action->getActionRequiredParameters(); - - // Check missing parameters - foreach($required_params as $param => $value) { - if (! isset($params[$param])) { - return false; - } - } - - // Check extra parameters - foreach($params as $param => $value) { - if (! isset($required_params[$param])) { - return false; - } - } - - return $container['action']->create($values); -}); - - -/** - * Project permissions procedures - */ -$server->bind('getMembers', $container['projectPermission'], 'getMembers'); -$server->bind('revokeUser', $container['projectPermission'], 'revokeMember'); -$server->bind('allowUser', $container['projectPermission'], 'addMember'); - -/** - * Task procedures - */ -$server->bind('getTask', $container['taskFinder'], 'getById'); -$server->bind('getAllTasks', $container['taskFinder'], 'getAll'); -$server->bind('getOverdueTasks', $container['taskFinder'], 'getOverdueTasks'); -$server->bind('openTask', $container['taskStatus'], 'open'); -$server->bind('closeTask', $container['taskStatus'], 'close'); -$server->bind('removeTask', $container['task'], 'remove'); -$server->bind('moveTaskPosition', $container['taskPosition'], 'movePosition'); - -$server->register('createTask', function($title, $project_id, $color_id = '', $column_id = 0, $owner_id = 0, $creator_id = 0, $date_due = '', $description = '', $category_id = 0, $score = 0, $swimlane_id = 0, $recurrence_status = 0, $recurrence_trigger = 0, $recurrence_factor = 0, $recurrence_timeframe = 0, $recurrence_basedate = 0) use ($container) { - - $values = array( - 'title' => $title, - 'project_id' => $project_id, - 'color_id' => $color_id, - 'column_id' => $column_id, - 'owner_id' => $owner_id, - 'creator_id' => $creator_id, - 'date_due' => $date_due, - 'description' => $description, - 'category_id' => $category_id, - 'score' => $score, - 'swimlane_id' => $swimlane_id, - 'recurrence_status' => $recurrence_status, - 'recurrence_trigger' => $recurrence_trigger, - 'recurrence_factor' => $recurrence_factor, - 'recurrence_timeframe' => $recurrence_timeframe, - 'recurrence_basedate' => $recurrence_basedate, - ); - - list($valid,) = $container['taskValidator']->validateCreation($values); - - if (! $valid) { - return false; - } - - return $container['taskCreation']->create($values); -}); - -$server->register('updateTask', function($id, $title = null, $project_id = null, $color_id = null, $column_id = null, $owner_id = null, $creator_id = null, $date_due = null, $description = null, $category_id = null, $score = null, $swimlane_id = null, $recurrence_status = null, $recurrence_trigger = null, $recurrence_factor = null, $recurrence_timeframe = null, $recurrence_basedate = null) use ($container) { - - $values = array( - 'id' => $id, - 'title' => $title, - 'project_id' => $project_id, - 'color_id' => $color_id, - 'column_id' => $column_id, - 'owner_id' => $owner_id, - 'creator_id' => $creator_id, - 'date_due' => $date_due, - 'description' => $description, - 'category_id' => $category_id, - 'score' => $score, - 'swimlane_id' => $swimlane_id, - 'recurrence_status' => $recurrence_status, - 'recurrence_trigger' => $recurrence_trigger, - 'recurrence_factor' => $recurrence_factor, - 'recurrence_timeframe' => $recurrence_timeframe, - 'recurrence_basedate' => $recurrence_basedate, - ); - - foreach ($values as $key => $value) { - if (is_null($value)) { - unset($values[$key]); - } - } - - list($valid) = $container['taskValidator']->validateApiModification($values); - return $valid && $container['taskModification']->update($values); -}); - - -/** - * User procedures - */ -$server->bind('getUser', $container['user'], 'getById'); -$server->bind('getAllUsers', $container['user'], 'getAll'); -$server->bind('removeUser', $container['user'], 'remove'); - -$server->register('createUser', function($username, $password, $name = '', $email = '', $is_admin = 0, $default_project_id = 0) use ($container) { - - $values = array( - 'username' => $username, - 'password' => $password, - 'confirmation' => $password, - 'name' => $name, - 'email' => $email, - 'is_admin' => $is_admin, - 'default_project_id' => $default_project_id, - ); - - list($valid,) = $container['user']->validateCreation($values); - - if (! $valid) { - return false; - } - - return $container['user']->create($values); -}); - -$server->register('createLdapUser', function($username = '', $email = '', $is_admin = 0, $default_project_id = 0) use ($container) { - - $ldap = new Auth\Ldap($container); - $user = $ldap->lookup($username, $email); - - if (! $user) { - return false; - } - - $values = array( - 'username' => $user['username'], - 'name' => $user['name'], - 'email' => $user['email'], - 'is_ldap_user' => 1, - 'is_admin' => $is_admin, - 'default_project_id' => $default_project_id, - ); - - return $container['user']->create($values); -}); - -$server->register('updateUser', function($id, $username = null, $name = null, $email = null, $is_admin = null, $default_project_id = null) use ($container) { - - $values = array( - 'id' => $id, - 'username' => $username, - 'name' => $name, - 'email' => $email, - 'is_admin' => $is_admin, - 'default_project_id' => $default_project_id, - ); - - foreach ($values as $key => $value) { - if (is_null($value)) { - unset($values[$key]); - } - } - - list($valid,) = $container['user']->validateApiModification($values); - return $valid && $container['user']->update($values); -}); - -/** - * Category procedures - */ -$server->bind('getCategory', $container['category'], 'getById'); -$server->bind('getAllCategories', $container['category'], 'getAll'); -$server->bind('removeCategory', $container['category'], 'remove'); - -$server->register('createCategory', function($project_id, $name) use ($container) { - - $values = array( - 'project_id' => $project_id, - 'name' => $name, - ); - - list($valid,) = $container['category']->validateCreation($values); - - if (! $valid) { - return false; - } - - return $container['category']->create($values); -}); - -$server->register('updateCategory', function($id, $name) use ($container) { - - $values = array( - 'id' => $id, - 'name' => $name, - ); - - list($valid,) = $container['category']->validateModification($values); - return $valid && $container['category']->update($values); -}); - -/** - * Comments procedures - */ -$server->bind('getComment', $container['comment'], 'getById'); -$server->bind('getAllComments', $container['comment'], 'getAll'); -$server->bind('removeComment', $container['comment'], 'remove'); - -$server->register('createComment', function($task_id, $user_id, $content) use ($container) { - - $values = array( - 'task_id' => $task_id, - 'user_id' => $user_id, - 'comment' => $content, - ); - - list($valid,) = $container['comment']->validateCreation($values); - - if (! $valid) { - return false; - } - - return $container['comment']->create($values); -}); - -$server->register('updateComment', function($id, $content) use ($container) { - - $values = array( - 'id' => $id, - 'comment' => $content, - ); - - list($valid,) = $container['comment']->validateModification($values); - return $valid && $container['comment']->update($values); -}); - -/** - * Subtask procedures - */ -$server->bind('getSubtask', $container['subtask'], 'getById'); -$server->bind('getAllSubtasks', $container['subtask'], 'getAll'); -$server->bind('removeSubtask', $container['subtask'], 'remove'); - -$server->register('createSubtask', function($task_id, $title, $user_id = 0, $time_estimated = 0, $time_spent = 0, $status = 0) use ($container) { - - $values = array( - 'title' => $title, - 'task_id' => $task_id, - 'user_id' => $user_id, - 'time_estimated' => $time_estimated, - 'time_spent' => $time_spent, - 'status' => $status, - ); - - foreach ($values as $key => $value) { - if (is_null($value)) { - unset($values[$key]); - } - } - list($valid,) = $container['subtask']->validateCreation($values); - - if (! $valid) { - return false; - } - - return $container['subtask']->create($values); -}); - -$server->register('updateSubtask', function($id, $task_id, $title = null, $user_id = null, $time_estimated = null, $time_spent = null, $status = null) use ($container) { - - $values = array( - 'id' => $id, - 'task_id' => $task_id, - 'title' => $title, - 'user_id' => $user_id, - 'time_estimated' => $time_estimated, - 'time_spent' => $time_spent, - 'status' => $status, - ); - - foreach ($values as $key => $value) { - if (is_null($value)) { - unset($values[$key]); - } - } - - list($valid,) = $container['subtask']->validateApiModification($values); - return $valid && $container['subtask']->update($values); -}); - -/** - * Application procedures - */ -$server->register('getTimezone', function() use ($container) { - return $container['config']->get('application_timezone'); -}); - -$server->register('getVersion', function() use ($container) { - return APP_VERSION; -}); +$server->before('authentication'); +$server->attach(new Api\Action($container)); +$server->attach(new Api\App($container)); +$server->attach(new Api\Board($container)); +$server->attach(new Api\Category($container)); +$server->attach(new Api\Comment($container)); +$server->attach(new Api\Link($container)); +$server->attach(new Api\Project($container)); +$server->attach(new Api\ProjectPermission($container)); +$server->attach(new Api\Subtask($container)); +$server->attach(new Api\Swimlane($container)); +$server->attach(new Api\Task($container)); +$server->attach(new Api\TaskLink($container)); +$server->attach(new Api\User($container)); -/** - * Parse incoming requests - */ echo $server->execute(); |