/*
* Copyright (C) 2010-2016 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.user.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.user.domain.User;
/**
* Dao for User objects
*
* @author Christopher Fagiani
*/
public class UserDao extends BaseDAO<User> {
public UserDao() {
super(User.class);
}
/**
* finds a single user by email address.
*
* @param email
* @return
*/
public User findUserByEmail(String email) {
if (email == null || email.trim().isEmpty()) {
return null;
}
return findByProperty("emailAddress", email.trim().toLowerCase(), STRING_TYPE);
}
/**
* searches for users that match the non-null params
*
* @return
*/
@SuppressWarnings("unchecked")
public List<User> searchUser(String username, String emailAddress,
String orderByField, String orderByDir, String cursorString) {
PersistenceManager pm = PersistenceFilter.getManager();
javax.jdo.Query query = pm.newQuery(User.class);
StringBuilder filterString = new StringBuilder();
StringBuilder paramString = new StringBuilder();
Map<String, Object> paramMap = null;
paramMap = new HashMap<String, Object>();
appendNonNullParam("userName", filterString, paramString, "String",
username, paramMap);
appendNonNullParam("emailAddress", filterString, paramString, "String",
emailAddress, paramMap);
if (orderByField != null) {
String ordering = orderByDir;
if (ordering == null) {
ordering = "asc";
}
query.setOrdering(orderByField + " " + ordering);
}
if (filterString.length() > 0) {
query.setFilter(filterString.toString());
query.declareParameters(paramString.toString());
}
prepareCursor(cursorString, query);
List<User> results = (List<User>) query.executeWithMap(paramMap);
return results;
}
/**
* finds a single user by accessKey
*
* @param accessKey
* @return
*/
public User findByAccessKey(String accessKey) {
return findByProperty("accessKey", accessKey, STRING_TYPE);
}
}