/*
*
* Copyright 2013 Entando S.r.l. (http://www.entando.com) All rights reserved.
*
* This file is part of Entando software.
* Entando is a free software;
* You can redistribute it and/or modify it
* under the terms of the GNU General Public License (GPL) as published by the Free Software Foundation; version 2.
*
* See the file License for the specific language governing permissions
* and limitations under the License
*
*
*
* Copyright 2013 Entando S.r.l. (http://www.entando.com) All rights reserved.
*
*/
package com.agiletec.plugins.jpsurvey.aps.system.services.collect;
import java.sql.Connection;
import java.util.Date;
import java.util.List;
import com.agiletec.aps.system.common.FieldSearchFilter;
import com.agiletec.plugins.jpsurvey.aps.system.services.collect.model.Voter;
public interface IVoterDAO {
public List<Integer> searchVotersId(FieldSearchFilter[] filters);
public Voter getVoter(String username, String ipAddress, int surveyId);
/**
* Get a voter given its ID
* @param id the unique identifier of the voter
* @return the obeject which describes the voter
*/
public Voter getVoterById(int id);
/**
* Get a voter given its ID.<br />The connection is not closed after an exception
* @param conn a previously opened connetion to the database
* @param id the unique identifier of the voter
* @return the obeject which describes the voter
*/
public Voter getVoterById(Connection conn, int id);
/**
* Save the given voter to the database.
* @param voter
*/
public void saveVoter(Voter voter);
/**
* Save the given voter to the database
* @param conn a previously opened connetion to the database
* @param voter to 'voter' object to save
*/
public void saveVoter(Connection conn, Voter voter);
/**
* Delete a voter identified by the given ID
* @param id
*/
public void deleteVoterById(int id);
/**
* Delete all the voters which answered the given survey
* @param surveyId
*/
public void deleteVoterBySurveyId(int surveyId);
/**
* Delete all the voters which answered the given survey
* @param surveyId
*/
public void deleteVoterBySurveyId(Connection conn, int surveyId);
/**
* Search the users matching the given criteria
* @param id
* @param age
* @param country
* @param sex
* @param date
* @param surveyId
* @param ipAddress
* @return a list containing the ID of the users found
*/
public List<Integer> searchVotersByIds(Integer id, Integer age, String country, Character sex, Date date, Integer surveyId, String ipAddress);
}