1 package com.indexdata.mkjsf.pazpar2.data;
\r
3 import java.io.IOException;
\r
4 import java.io.Serializable;
\r
5 import java.io.UnsupportedEncodingException;
\r
6 import java.util.List;
\r
7 import java.util.Map;
\r
8 import java.util.concurrent.ConcurrentHashMap;
\r
10 import javax.enterprise.context.SessionScoped;
\r
11 import javax.faces.context.ExternalContext;
\r
12 import javax.faces.context.FacesContext;
\r
13 import javax.inject.Named;
\r
15 import org.apache.log4j.Logger;
\r
17 import com.indexdata.mkjsf.errors.ErrorHelper;
\r
18 import com.indexdata.mkjsf.errors.ErrorInterface;
\r
19 import com.indexdata.mkjsf.pazpar2.data.sp.SpResponses;
\r
20 import com.indexdata.mkjsf.utils.Utils;
\r
22 @Named("pzresp") @SessionScoped
\r
23 public class Responses implements Serializable {
\r
25 private static final long serialVersionUID = -7543231258346154642L;
\r
26 protected Map<String,ResponseDataObject> dataObjects = new ConcurrentHashMap<String,ResponseDataObject>();
\r
27 private static Logger logger = Logger.getLogger(Responses.class);
\r
28 private ErrorHelper errorHelper = null;
\r
30 public Responses() {
\r
33 public void put(String name, ResponseDataObject responseData) {
\r
34 dataObjects.put(name, responseData);
\r
37 public void setErrorHelper(ErrorHelper helper) {
\r
38 this.errorHelper = helper;
\r
41 public boolean hasApplicationError () {
\r
42 if (getSearch().hasApplicationError()) {
\r
43 logger.info("Error detected in search");
\r
46 for (String name : dataObjects.keySet()) {
\r
47 if (dataObjects.get(name).hasApplicationError()) {
\r
48 logger.info("Error detected in " + name);
\r
56 * Returns a search command error, if any, otherwise the first
\r
57 * error found for an arbitrary command, if any, otherwise
\r
58 * an empty dummy error.
\r
60 public ErrorInterface getCommandError() {
\r
61 CommandError error = new CommandError();
\r
62 if (dataObjects.get("search").hasApplicationError()) {
\r
63 error = dataObjects.get("search").getApplicationError();
\r
64 error.setErrorHelper(errorHelper);
\r
66 for (String name : dataObjects.keySet()) {
\r
67 if (dataObjects.get(name).hasApplicationError()) {
\r
68 error = dataObjects.get(name).getApplicationError();
\r
69 error.setErrorHelper(errorHelper);
\r
77 public void resetSearchResponses() {
\r
78 logger.debug("Resetting show,stat,termlist,bytarget,record,search response objects.");
\r
79 dataObjects.put("show", new ShowResponse());
\r
80 dataObjects.put("stat", new StatResponse());
\r
81 dataObjects.put("termlist", new TermListsResponse());
\r
82 dataObjects.put("bytarget", new ByTarget());
\r
83 dataObjects.put("record", new RecordResponse());
\r
84 dataObjects.put("search", new SearchResponse());
\r
87 public void resetAllSessionData () {
\r
88 logger.debug("Resetting all response objects");
\r
89 dataObjects = new ConcurrentHashMap<String,ResponseDataObject>();
\r
90 resetSearchResponses();
\r
91 dataObjects.put("init", new InitResponse());
\r
94 public InitResponse getInit () {
\r
95 logger.info("Request to show init response from " + Utils.objectId(this));
\r
96 return ((InitResponse) dataObjects.get("init"));
\r
99 public ShowResponse getShow () {
\r
100 return ((ShowResponse) dataObjects.get("show"));
\r
103 public StatResponse getStat () {
\r
104 return ((StatResponse) dataObjects.get("stat"));
\r
107 public RecordResponse getRecord() {
\r
108 return ((RecordResponse) dataObjects.get("record"));
\r
111 public SearchResponse getSearch() {
\r
112 return ((SearchResponse) dataObjects.get("search"));
\r
115 public TermListsResponse getTermLists () {
\r
116 return ((TermListsResponse) dataObjects.get("termlist"));
\r
119 public List<TermResponse> getFacetTerms (String facet, int count) {
\r
120 return (getTermLists().getTermList(facet).getTerms(count));
\r
123 public List<TermResponse> getFacetTerms (String facet) {
\r
124 return (getTermLists().getTermList(facet).getTerms());
\r
127 public ByTarget getByTarget() {
\r
128 return ((ByTarget) dataObjects.get("bytarget"));
\r
131 public ResponseDataObject getResponseObject (String name) {
\r
132 return dataObjects.get(name);
\r
135 public boolean hasRecords () {
\r
136 return getStat().getRecords() > 0
\r
137 && getShow().getHits() != null
\r
138 && getShow().getHits().size()>0;
\r
141 public String getActiveClients() {
\r
142 if (getShow()!=null) {
\r
143 logger.debug("Active clients: "+getShow().getActiveClients());
\r
144 return getShow().getActiveClients();
\r
150 public SpResponses getSp() {
\r
155 public void download(String commandName) throws UnsupportedEncodingException, IOException {
\r
156 logger.info(Utils.objectId(this) + " got a download request for "
\r
158 FacesContext facesContext = FacesContext.getCurrentInstance();
\r
159 ExternalContext externalContext = facesContext.getExternalContext();
\r
160 externalContext.setResponseHeader("Content-Type","application/xml; charset=\"utf-8\"");
\r
161 externalContext.setResponseHeader("Content-Length",String.valueOf(dataObjects.get(commandName).getXml().getBytes("UTF-8").length));
\r
162 externalContext.setResponseHeader("Content-Disposition","attachment;filename=\"" + commandName + ".xml\"");
\r
163 externalContext.getResponseOutputStream().write(dataObjects.get(commandName).getXml().getBytes("UTF-8"));
\r
164 facesContext.responseComplete();
\r