/[projects]/android/MarketStats/src/dk/thoerup/marketstats/ShowStats.java
ViewVC logotype

Diff of /android/MarketStats/src/dk/thoerup/marketstats/ShowStats.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 664 by torben, Fri Apr 23 15:25:52 2010 UTC revision 953 by torben, Mon Jul 5 08:44:09 2010 UTC
# Line 1  Line 1 
1  package dk.thoerup.marketstats;  package dk.thoerup.marketstats;
2    
3  import java.io.IOException;  import java.io.IOException;
 import java.io.PrintWriter;  
4  import java.net.InetSocketAddress;  import java.net.InetSocketAddress;
5  import java.util.ArrayList;  import java.util.ArrayList;
 import java.util.Collections;  
 import java.util.Date;  
6  import java.util.Locale;  import java.util.Locale;
7    import java.util.concurrent.TimeUnit;
8  import java.util.logging.Logger;  import java.util.logging.Logger;
9    
10  import javax.servlet.ServletException;  import javax.servlet.ServletException;
# Line 25  import com.gc.android.market.api.model.M Line 23  import com.gc.android.market.api.model.M
23  public class ShowStats extends HttpServlet {  public class ShowStats extends HttpServlet {
24          private static final long serialVersionUID = 1L;          private static final long serialVersionUID = 1L;
25    
26          final int TIMEOUT = 30*60;          static final int MAXCOMMENTS = 30;
27            static final int APP_TIMEOUT = 30*60;
28            static final int COMMENT_TIMEOUT = APP_TIMEOUT * 4;
29            
30          static final Logger log = Logger.getLogger(ShowStats.class.getName());          static final Logger log = Logger.getLogger(ShowStats.class.getName());
31    
32          String login;          String login;
33          String password;          String password;
34            
35            MemcachedClient memcache = null;
36    
37    
38          @Override          @Override
# Line 38  public class ShowStats extends HttpServl Line 41  public class ShowStats extends HttpServl
41    
42                  login = getServletContext().getInitParameter("login");                  login = getServletContext().getInitParameter("login");
43                  password = getServletContext().getInitParameter("password");                  password = getServletContext().getInitParameter("password");
44                    
45                    try {
46                            memcache = new MemcachedClient(new InetSocketAddress("localhost", 11211));
47                    } catch (IOException e) {
48                            throw new ServletException(e);
49                    }
50          }          }
51    
52          protected String doLookup(String appId) throws IOException {          @Override
53                  MemcachedClient c = new MemcachedClient(new InetSocketAddress("localhost", 11211));          public void destroy() {
54                    super.destroy();
55                    
56                    memcache.shutdown(3, TimeUnit.SECONDS);
57                    memcache = null;
58            }
59    
60            protected AppBean lookupApp(String query) throws IOException {
61                    
62    
63                  String key = "marketstats:" + appId;                  String key = "marketstats:" + query.replace(' ', '_');
64                  String response = (String) c.get(key);                  //String response = (String) memcache.get(key);
65                    AppBean response = (AppBean) memcache.get(key);
66    
67                  if (response == null) {                  if (response == null) {
68                          response = doLookupWorker(appId);                          response = lookupAppWorker(query);
69                          c.set(key, TIMEOUT, response);                          if (response != null) {
70                          response += "<!-- new lookup -->";                                  memcache.set(key, APP_TIMEOUT, response);
71                  } else {                          }
72                          response += "<!-- from memcached -->";                  }
                 }  
73                  return response;                  return response;
74          }          }
75    
76            protected AppBean lookupAppWorker(String query) {
77    
78                    MarketSession session = new MarketSession();
79                    session.login(login,password);
80    
81    
82                    AppsRequest appsRequest = AppsRequest.newBuilder()
83                    .setQuery(query)
84                    .setStartIndex(0)
85                    .setEntriesCount(1)
86                    .setWithExtendedInfo(true)
87                    .build();
88                    
89                    AppsCallback appsCb = new AppsCallback();
90                    session.append(appsRequest, appsCb);
91                    session.flush();
92                    
93                    return appsCb.getResult();
94            }      
95            
96            CommentsRequest buildCommentRequest(String appId, int start, int count) {
97                    CommentsRequest commentsRequest = CommentsRequest.newBuilder()
98                    .setAppId(appId)
99                    .setStartIndex(start)
100                    .setEntriesCount(count)
101                    .build();
102                    
103                    return commentsRequest;
104            }
105                    
106          private void loadComments(String appId, MarketSession session, String locale, ArrayList<CommentBean> commentBeans) {                      private ArrayList<CommentBean> loadComments(String appId) {
107                    
108                    ArrayList<CommentBean> commentBeans = new ArrayList<CommentBean>();
109                    MarketSession session = new MarketSession();
110                    session.login(login,password);
111                    
112                  CommentCallback commentsCb = new CommentCallback();                  CommentCallback commentsCb = new CommentCallback();
113                  commentsCb.setList( commentBeans );                  commentsCb.setList( commentBeans );
114    
115                  commentsCb.setLocale( locale );                  session.setLocale( Locale.ROOT );
116                  session.setLocale( new Locale(locale) );                  
117                                    
118                                    
119                  int start = 0;                  int start = 0;
# Line 71  public class ShowStats extends HttpServl Line 122  public class ShowStats extends HttpServl
122                          if (start > 0)                                                    if (start > 0)                          
123                                  count = Math.min(10, commentsCb.getEntryCount() );                                  count = Math.min(10, commentsCb.getEntryCount() );
124                                                    
125                          //log.warning("count=" + count + " start=" + start + " " + locale);                          //log.warning("count=" + count + " start=" + start + " entryCount=" + commentsCb.getEntryCount() );
126                          CommentsRequest commentsRequest = CommentsRequest.newBuilder()                          CommentsRequest commentsRequest = buildCommentRequest(appId,start,count);                      
                         .setAppId(appId)  
                         .setStartIndex(start)  
                         .setEntriesCount(count)  
                         .build();  
                           
127                          session.append(commentsRequest, commentsCb);                          session.append(commentsRequest, commentsCb);
128                            start +=10;
129                            
130                            CommentsRequest commentsRequest2 = buildCommentRequest(appId,start,count);                      
131                            session.append(commentsRequest2, commentsCb);
132                          session.flush();                          session.flush();
133                            
134                          start +=10;                          start +=10;
135                                                    
136                          if (start >= 30)                          if (start >= MAXCOMMENTS)
137                                  break; //emergency brake                                  break; //emergency brake
138                                                    
139                  } while ( start < commentsCb.getEntryCount() );                  } while ( start < commentsCb.getEntryCount() );
140                    
141                    return commentBeans;
142          }          }
143    
144            
145          protected String doLookupWorker(String appId) {          
146                  final StringBuilder sb = new StringBuilder();          @SuppressWarnings("unchecked")
147            public ArrayList<CommentBean> getComments(AppBean app) {                
148                    String key = "marketstats:comments:" + app.getId();
149                  MarketSession session = new MarketSession();                  ArrayList<CommentBean>  comments =  (ArrayList<CommentBean>) memcache.get(key);
150                  session.login(login,password);  
151                    if (comments == null) {
152                            comments = loadComments(app.getId());
153                  AppsRequest appsRequest = AppsRequest.newBuilder()                          memcache.set(key, COMMENT_TIMEOUT, comments);
154                  .setAppId(appId)                  }
155                  .setStartIndex(0).setEntriesCount(10)                  return comments;
                 .setWithExtendedInfo(true)  
                 .build();  
   
   
                 AppsCallback appsCb = new AppsCallback() ;  
                 appsCb.setStringBuffer(sb);  
   
                 ArrayList<CommentBean> commentBeans = new ArrayList<CommentBean>();  
   
   
   
                 session.append(appsRequest, appsCb);  
                 session.flush();  
   
                 loadComments(appId, session, "da", commentBeans);  
                 loadComments(appId, session, "en", commentBeans);  
   
                 Collections.sort(commentBeans);  
   
                 sb.append("-----------------------------------------------------------------\n");  
                 for (CommentBean c : commentBeans) {  
                         sb.append("User: " + c.author + " ("  + c.locale + ")\n");  
                         sb.append("Rating: " + c.rating + "\n");  
                         sb.append("Time: " + new Date(c.time).toString() + "\n");  
                         sb.append( c.text + "\n");  
                         sb.append("\n");  
   
                 }  
                 sb.append("Comments: " + commentBeans.size() );  
   
   
                 return sb.toString();  
156          }          }
157    
158          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
159                  String appId = request.getParameter("appId");                  String query = request.getParameter("query");
160                    
161                  response.setContentType("text/html");                  AppBean app = lookupApp(query);
162                  PrintWriter out = response.getWriter();                  if (app != null) {
163                  out.print( "<html><body><pre>" + doLookup(appId) + "</pre></body></html>" );                          request.setAttribute("app", app);
164                    
165                            ArrayList<CommentBean> comments = getComments(app);
166                            request.setAttribute("comments", comments);
167                    
168                            getServletContext().getRequestDispatcher("/statsview.jsp").forward(request, response);
169                    } else {
170                            response.getWriter().print("No app found with query=" + query);
171                    }
172          }          }
173    
174  }  }

Legend:
Removed from v.664  
changed lines
  Added in v.953

  ViewVC Help
Powered by ViewVC 1.1.20