/*
* (c) 2008- RANDI2 Core Development Team
*
* This file is part of RANDI2.
*
* RANDI2 is free software: you can redistribute it and/or modify it under the
* terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* RANDI2 is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
* A PARTICULAR PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with
* RANDI2. If not, see <http://www.gnu.org/licenses/>.
*/
package de.randi2.services;
import java.util.List;
import de.randi2.model.Login;
import de.randi2.model.Trial;
import de.randi2.model.TrialSite;
import de.randi2.model.TrialSubject;
import de.randi2.model.exceptions.TrialStateException;
/**
* All Trial-relevant services.
*
* @author Lukasz Plotnicki <lp@randi2.de>
*/
public interface TrialService extends AbstractService<Trial> {
/**
* Stores a new trial object in the system.
*
* @param newTrial
*/
public void create(Trial newTrial);
/**
* Updates the trial object and returns the its newest version.
*
* @param trial
* @return
* @throws TrialStateException, IllegalArgumentException
*/
public Trial update(Trial trial) throws TrialStateException, IllegalArgumentException;
/**
* Add a new trial subject to the given trial and randomize it. The
* refreshed Trial object will be returned.
*
* @param subject
* @return
*/
public Trial randomize(Trial trial, TrialSubject subject) throws IllegalArgumentException;
/**
* Method for the retrieval of all subjects randomized by a specific
* investigator within a specific trial.
*
* @param trial
* specific trial
* @param investigator
* Investigator which subjects should be returned.
* @return A list of all found subjects
*/
public List<TrialSubject> getSubjects(Trial trial, Login investigator);
/**
* Returns all trials of the specific trial site
* @param site specific trial site
* @return A list of all relevant trials
*/
public List<Trial> getAll(TrialSite site);
/**
* Add a new response to the given trial and to the given subject.
* @param trial specific trial
* @param subject specific subject
*/
public void addResponse(Trial trial, TrialSubject subject);
}