/* * Copyright (C) 2010-2012 Stichting Akvo (Akvo Foundation) * * This file is part of Akvo FLOW. * * Akvo FLOW is free software: you can redistribute it and modify it under the terms of * the GNU Affero General Public License (AGPL) as published by the Free Software Foundation, * either version 3 of the License or any later version. * * Akvo FLOW 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 Affero General Public License included below for more details. * * The full license text can also be seen at <http://www.gnu.org/licenses/agpl.html>. */ package org.waterforpeople.mapping.dao; import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import javax.jdo.PersistenceManager; import org.waterforpeople.mapping.domain.Status; import com.gallatinsystems.device.domain.DeviceFiles; import com.gallatinsystems.framework.dao.BaseDAO; import com.gallatinsystems.framework.servlet.PersistenceFilter; public class DeviceFilesDao extends BaseDAO<DeviceFiles> { public DeviceFilesDao() { super(DeviceFiles.class); } @SuppressWarnings("unchecked") public List<DeviceFiles> listDeviceFilesByDate(Date startDate, String cursorString) { PersistenceManager pm = PersistenceFilter.getManager(); javax.jdo.Query query = pm.newQuery(DeviceFiles.class); Map<String, Object> paramMap = null; StringBuilder filterString = new StringBuilder(); StringBuilder paramString = new StringBuilder(); paramMap = new HashMap<String, Object>(); /* * appendNonNullParam("createdDateTime", filterString, paramString, "Date", startDate, * paramMap, GTE_OP); if (startDate != null) { * query.declareImports("import java.util.Date"); } */ DateFormat dateFormat = new SimpleDateFormat("yyyy_MM_dd"); String dateTime = dateFormat.format(startDate); appendNonNullParam("processDate", filterString, paramString, "String", dateTime, paramMap, GTE_OP); // query.setOrdering("createdDateTime desc"); query.setFilter(filterString.toString()); query.declareParameters(paramString.toString()); prepareCursor(cursorString, query); List<DeviceFiles> results = (List<DeviceFiles>) query .executeWithMap(paramMap); return results; } public DeviceFiles findByInstance(Long instanceId) { return findByProperty("surveyInstanceId", instanceId, "Long"); } public DeviceFiles findByUri(String uri) { List<DeviceFiles> dfList = (List<DeviceFiles>) listByProperty("URI", uri, "String"); if (dfList.size() > 0) return dfList.get(0); else return null; } public List<DeviceFiles> listByUri(String uri) { List<DeviceFiles> dfList = (List<DeviceFiles>) listByProperty("URI", uri, "String"); if (dfList.size() > 0) return dfList; else return null; } @SuppressWarnings("unchecked") public List<DeviceFiles> listDeviceFilesByStatus(Status.StatusCode status, String cursorString) { PersistenceManager pm = PersistenceFilter.getManager(); javax.jdo.Query query = pm.newQuery(DeviceFiles.class); Map<String, Object> paramMap = null; StringBuilder filterString = new StringBuilder(); StringBuilder paramString = new StringBuilder(); paramMap = new HashMap<String, Object>(); appendNonNullParam("processedStatus", filterString, paramString, "String", status, paramMap, EQ_OP); query.setOrdering("createdDateTime desc URI asc"); query.setFilter(filterString.toString()); query.declareParameters(paramString.toString()); prepareCursor(cursorString, query); List<DeviceFiles> results = (List<DeviceFiles>) query .executeWithMap(paramMap); return results; } }