/*
* 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.auth.dao;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.jdo.PersistenceManager;
import com.gallatinsystems.auth.domain.WebActivityAuthorization;
import com.gallatinsystems.framework.dao.BaseDAO;
import com.gallatinsystems.framework.servlet.PersistenceFilter;
/**
* persists and finds WebActivityAuthorization objects.
*
* @author Christopher Fagiani
*/
public class WebActivityAuthorizationDao extends
BaseDAO<WebActivityAuthorization> {
public WebActivityAuthorizationDao() {
super(WebActivityAuthorization.class);
}
/**
* lists all webActivityAuthorizations associated with the token and, optionally, activityName
* passed in. If the validOnly flag is true, this list is filtered to only include "valid" items
* (unexpired tokens with a useCount < maxUses).
*
* @param token
* @param activity
* @param cursorString
* @param validOnly
* @return
*/
@SuppressWarnings("unchecked")
public List<WebActivityAuthorization> listByToken(String token,
String activityName, String cursorString, boolean validOnly) {
PersistenceManager pm = PersistenceFilter.getManager();
javax.jdo.Query query = pm.newQuery(WebActivityAuthorization.class);
Map<String, Object> paramMap = null;
StringBuilder filterString = new StringBuilder();
StringBuilder paramString = new StringBuilder();
paramMap = new HashMap<String, Object>();
appendNonNullParam("token", filterString, paramString, "String", token,
paramMap);
appendNonNullParam("webActivityName", filterString, paramString,
"String", activityName, paramMap);
query.setFilter(filterString.toString());
query.declareParameters(paramString.toString());
prepareCursor(cursorString, query);
List<WebActivityAuthorization> authList = (List<WebActivityAuthorization>) query
.executeWithMap(paramMap);
if (authList != null && validOnly) {
List<WebActivityAuthorization> filteredList = new ArrayList<WebActivityAuthorization>();
for (WebActivityAuthorization auth : authList) {
if (auth.isValidForAuth()) {
filteredList.add(auth);
}
}
authList = filteredList;
}
return authList;
}
/**
* returns all VALID authorization objects for a given user/activity combination
*
* @param userId
* @param activityName
* @return
*/
@SuppressWarnings("unchecked")
public List<WebActivityAuthorization> listByUser(Long userId,
String activityName) {
PersistenceManager pm = PersistenceFilter.getManager();
javax.jdo.Query query = pm.newQuery(WebActivityAuthorization.class);
Map<String, Object> paramMap = null;
StringBuilder filterString = new StringBuilder();
StringBuilder paramString = new StringBuilder();
paramMap = new HashMap<String, Object>();
appendNonNullParam("userId", filterString, paramString, "Long", userId,
paramMap);
appendNonNullParam("webActivityName", filterString, paramString,
"String", activityName, paramMap);
query.setFilter(filterString.toString());
query.declareParameters(paramString.toString());
List<WebActivityAuthorization> authList = (List<WebActivityAuthorization>) query
.executeWithMap(paramMap);
if (authList != null) {
List<WebActivityAuthorization> filteredList = new ArrayList<WebActivityAuthorization>();
for (WebActivityAuthorization auth : authList) {
if (auth.isValidForAuth()) {
filteredList.add(auth);
}
}
authList = filteredList;
}
return authList;
}
}