blob: 1cfc2e4eefd53a617e4a30f13af85b4d79da8f20 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2004, 2008 Tasktop Technologies and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Tasktop Technologies - initial API and implementation
*******************************************************************************/
package org.eclipse.mylyn.internal.tasks.core.sync;
import java.util.Set;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.OperationCanceledException;
import org.eclipse.core.runtime.Status;
import org.eclipse.mylyn.commons.core.StatusHandler;
import org.eclipse.mylyn.commons.net.Policy;
import org.eclipse.mylyn.internal.tasks.core.ITasksCoreConstants;
import org.eclipse.mylyn.internal.tasks.core.TaskTask;
import org.eclipse.mylyn.internal.tasks.core.ITasksCoreConstants.MutexSchedulingRule;
import org.eclipse.mylyn.internal.tasks.core.data.TaskDataManager;
import org.eclipse.mylyn.tasks.core.AbstractRepositoryConnector;
import org.eclipse.mylyn.tasks.core.ITask;
import org.eclipse.mylyn.tasks.core.RepositoryResponse;
import org.eclipse.mylyn.tasks.core.RepositoryStatus;
import org.eclipse.mylyn.tasks.core.TaskRepository;
import org.eclipse.mylyn.tasks.core.data.AbstractTaskDataHandler;
import org.eclipse.mylyn.tasks.core.data.TaskAttribute;
import org.eclipse.mylyn.tasks.core.data.TaskData;
import org.eclipse.mylyn.tasks.core.sync.SubmitJob;
/**
* @author Steffen Pingel
*/
public class SubmitTaskJob extends SubmitJob {
private final TaskRepository taskRepository;
private final TaskData taskData;
private final AbstractRepositoryConnector connector;
private IStatus errorStatus;
private ITask task;
private final Set<TaskAttribute> oldAttributes;
private final TaskDataManager taskDataManager;
private RepositoryResponse response;
public SubmitTaskJob(TaskDataManager taskDataManager, AbstractRepositoryConnector connector,
TaskRepository taskRepository, ITask task, TaskData taskData, Set<TaskAttribute> oldAttributes) {
super("Submitting Task"); //$NON-NLS-1$
this.taskDataManager = taskDataManager;
this.connector = connector;
this.taskRepository = taskRepository;
this.task = task;
this.taskData = taskData;
this.oldAttributes = oldAttributes;
setRule(new MutexSchedulingRule());
}
@Override
protected IStatus run(IProgressMonitor monitor) {
try {
monitor.beginTask(Messages.SubmitTaskJob_Submitting_task, 2 * (1 + getSubmitJobListeners().length) * 100);
// post task data
AbstractTaskDataHandler taskDataHandler = connector.getTaskDataHandler();
monitor.subTask(Messages.SubmitTaskJob_Sending_data);
response = taskDataHandler.postTaskData(taskRepository, taskData, oldAttributes, Policy.subMonitorFor(
monitor, 100));
if (response == null || response.getTaskId() == null) {
throw new CoreException(new RepositoryStatus(IStatus.ERROR, ITasksCoreConstants.ID_PLUGIN,
RepositoryStatus.ERROR_INTERNAL,
"Task could not be created. No additional information was provided by the connector.")); //$NON-NLS-1$
}
fireTaskSubmitted(monitor);
// update task in task list
String taskId = response.getTaskId();
monitor.subTask(Messages.SubmitTaskJob_Receiving_data);
TaskData updatedTaskData = connector.getTaskData(taskRepository, taskId, Policy.subMonitorFor(monitor, 100));
task = createTask(monitor, updatedTaskData);
taskDataManager.putSubmittedTaskData(task, updatedTaskData);
fireTaskSynchronized(monitor);
} catch (CoreException e) {
errorStatus = e.getStatus();
} catch (OperationCanceledException e) {
return Status.CANCEL_STATUS;
} catch (Exception e) {
StatusHandler.log(new Status(IStatus.ERROR, ITasksCoreConstants.ID_PLUGIN,
"Unexpected error during task submission", e)); //$NON-NLS-1$
errorStatus = new Status(IStatus.ERROR, ITasksCoreConstants.ID_PLUGIN, "Unexpected error: " //$NON-NLS-1$
+ e.getMessage(), e);
} finally {
monitor.done();
}
fireDone();
return Status.OK_STATUS;
}
private ITask createTask(IProgressMonitor monitor, TaskData updatedTaskData) throws CoreException {
if (taskData.isNew()) {
task = new TaskTask(connector.getConnectorKind(), taskRepository.getRepositoryUrl(),
updatedTaskData.getTaskId());
}
return task;
}
@Override
public IStatus getStatus() {
return errorStatus;
}
@Override
public ITask getTask() {
return task;
}
}