/*
* This file is part of gwap, an open platform for games with a purpose
*
* Copyright (C) 2013
* Project play4science
* Lehr- und Forschungseinheit für Programmier- und Modellierungssprachen
* Ludwig-Maximilians-Universität München
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package gwap.mit;
import gwap.model.Person;
import gwap.model.resource.Statement;
import java.io.Serializable;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.Query;
import org.jboss.seam.ScopeType;
import org.jboss.seam.annotations.In;
import org.jboss.seam.annotations.Logger;
import org.jboss.seam.annotations.Name;
import org.jboss.seam.annotations.Scope;
import org.jboss.seam.annotations.Unwrap;
import org.jboss.seam.log.Log;
/**
* @author Fabian Kneißl
*/
@Name("mitStatementList")
@Scope(ScopeType.PAGE)
public class StatementList implements Serializable {
private static final long serialVersionUID = 1L;
@Logger Log log;
@In EntityManager entityManager;
@In Person person;
private List<Statement> statementList;
@Unwrap
public List<Statement> getStatementList() {
if (statementList == null) {
long start = System.currentTimeMillis();
Query q = entityManager.createNamedQuery("statement.byCreator").setParameter("person", person);
statementList = q.getResultList();
for (Statement statement : statementList) {
statement.getStatementTokens().size();
}
log.info("Created statementList with #0 statements in #1ms", statementList.size(), System.currentTimeMillis()-start);
}
return statementList;
}
}