/* * 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 com.gallatinsystems.gis.geography.dao; import java.util.HashMap; import java.util.List; import java.util.Map; import javax.jdo.PersistenceManager; import com.gallatinsystems.framework.dao.BaseDAO; import com.gallatinsystems.framework.servlet.PersistenceFilter; import com.gallatinsystems.gis.geography.domain.SubCountry; /** * data access object to save/find SubCountry objects. * * @author Christopher Fagiani */ public class SubCountryDao extends BaseDAO<SubCountry> { public SubCountryDao() { super(SubCountry.class); } /** * lists all sub country records with the given parent * * @param parentId * @return */ public List<SubCountry> listSubCountryByParent(Long parentId) { return listByProperty("parentKey", parentId, "Long"); } /** * finds a single SubCountry record given the country, level and name passed in * * @param countryCode * @param name * @param level * @return */ public SubCountry findSubCountry(String countryCode, String name, Integer level) { List<SubCountry> results = listSubCountryByLevel(countryCode, level, name); if (results != null && results.size() > 0) { return results.get(0); } else { return null; } } /** * lists all sub country records for a single country that belong to the level passed in. Level * 0 is assumed to be the country level. * * @param countryCode * @param level * @param name -optional name * @return */ @SuppressWarnings("unchecked") public List<SubCountry> listSubCountryByLevel(String countryCode, Integer level, String name) { PersistenceManager pm = PersistenceFilter.getManager(); javax.jdo.Query query = pm.newQuery(SubCountry.class); Map<String, Object> paramMap = null; StringBuilder filterString = new StringBuilder(); StringBuilder paramString = new StringBuilder(); paramMap = new HashMap<String, Object>(); appendNonNullParam("countryCode", filterString, paramString, "String", countryCode, paramMap); appendNonNullParam("level", filterString, paramString, "Integer", level, paramMap); appendNonNullParam("name", filterString, paramString, "String", name, paramMap); query.setFilter(filterString.toString()); query.declareParameters(paramString.toString()); return (List<SubCountry>) query.executeWithMap(paramMap); } }