Catches init doc upload errors
[mkjsf-moved-to-github.git] / src / main / java / com / indexdata / mkjsf / pazpar2 / data / Responses.java
1 package com.indexdata.mkjsf.pazpar2.data;\r
2 \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
9 \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
14 \r
15 import org.apache.log4j.Logger;\r
16 \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
21 \r
22 @Named("pzresp") @SessionScoped\r
23 public class Responses implements Serializable {\r
24     \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
29 \r
30   public Responses() {    \r
31   }\r
32   \r
33   public void put(String name, ResponseDataObject responseData) {\r
34     dataObjects.put(name, responseData);\r
35   }\r
36   \r
37   public void setErrorHelper(ErrorHelper helper) {    \r
38     this.errorHelper = helper;\r
39   }\r
40   \r
41   public boolean hasApplicationError () {\r
42     if (getSearch().hasApplicationError()) {\r
43       logger.info("Error detected in search");\r
44       return true;\r
45     }\r
46     for (String name : dataObjects.keySet()) {\r
47       if (dataObjects.get(name).hasApplicationError()) {\r
48         logger.info("Error detected in " + name);\r
49         return true;\r
50       }\r
51     }    \r
52     return false;\r
53   }\r
54   \r
55   /**\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
59    */    \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
65     } else {\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
70           break;\r
71         } \r
72       }\r
73     }\r
74     return error;         \r
75   }\r
76   \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
85   }\r
86   \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
92   }\r
93   \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
97   }\r
98 \r
99   public ShowResponse getShow () {\r
100     return ((ShowResponse) dataObjects.get("show"));\r
101   }\r
102   \r
103   public StatResponse getStat () {\r
104     return ((StatResponse) dataObjects.get("stat"));\r
105   }\r
106   \r
107   public RecordResponse getRecord() {\r
108     return ((RecordResponse) dataObjects.get("record"));\r
109   }\r
110   \r
111   public SearchResponse getSearch() {\r
112     return ((SearchResponse) dataObjects.get("search"));\r
113   }\r
114   \r
115   public TermListsResponse getTermLists () {\r
116     return ((TermListsResponse) dataObjects.get("termlist"));\r
117   }\r
118   \r
119   public List<TermResponse> getFacetTerms (String facet, int count) {\r
120     return (getTermLists().getTermList(facet).getTerms(count));\r
121   }\r
122     \r
123   public List<TermResponse> getFacetTerms (String facet) {\r
124     return (getTermLists().getTermList(facet).getTerms());\r
125   }\r
126   \r
127   public ByTarget getByTarget() {\r
128     return ((ByTarget) dataObjects.get("bytarget"));\r
129   }\r
130 \r
131   public ResponseDataObject getResponseObject (String name) {\r
132     return dataObjects.get(name);\r
133   }\r
134   \r
135   public boolean hasRecords () {\r
136     return getStat().getRecords() > 0            \r
137            && getShow().getHits() != null \r
138            && getShow().getHits().size()>0;\r
139   }\r
140   \r
141   public String getActiveClients() {    \r
142     if (getShow()!=null) {\r
143       logger.debug("Active clients: "+getShow().getActiveClients());\r
144       return getShow().getActiveClients();\r
145     } else {\r
146       return "";\r
147     }\r
148   }\r
149 \r
150   public SpResponses getSp() {\r
151     // TODO:\r
152     return null;\r
153   }\r
154 \r
155   public void download(String commandName) throws UnsupportedEncodingException, IOException {\r
156     logger.info(Utils.objectId(this) + " got a download request for "\r
157         + commandName);\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
165   }\r
166 }