/[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 660 by torben, Fri Apr 23 12:39:31 2010 UTC revision 758 by torben, Thu May 27 08:57:57 2010 UTC
# Line 3  package dk.thoerup.marketstats; Line 3  package dk.thoerup.marketstats;
3  import java.io.IOException;  import java.io.IOException;
4  import java.io.PrintWriter;  import java.io.PrintWriter;
5  import java.net.InetSocketAddress;  import java.net.InetSocketAddress;
6    import java.util.ArrayList;
7    import java.util.Collections;
8  import java.util.Date;  import java.util.Date;
 import java.util.Formatter;  
 import java.util.List;  
9  import java.util.Locale;  import java.util.Locale;
10  import java.util.logging.Logger;  import java.util.logging.Logger;
11    
# Line 17  import javax.servlet.http.HttpServletRes Line 17  import javax.servlet.http.HttpServletRes
17  import net.spy.memcached.MemcachedClient;  import net.spy.memcached.MemcachedClient;
18    
19  import com.gc.android.market.api.MarketSession;  import com.gc.android.market.api.MarketSession;
 import com.gc.android.market.api.MarketSession.Callback;  
 import com.gc.android.market.api.model.Market.App;  
20  import com.gc.android.market.api.model.Market.AppsRequest;  import com.gc.android.market.api.model.Market.AppsRequest;
 import com.gc.android.market.api.model.Market.AppsResponse;  
 import com.gc.android.market.api.model.Market.Comment;  
21  import com.gc.android.market.api.model.Market.CommentsRequest;  import com.gc.android.market.api.model.Market.CommentsRequest;
22  import com.gc.android.market.api.model.Market.CommentsResponse;  
 import com.gc.android.market.api.model.Market.ResponseContext;  
23    
24    
25  public class ShowStats extends HttpServlet {  public class ShowStats extends HttpServlet {
26          private static final long serialVersionUID = 1L;          private static final long serialVersionUID = 1L;
27    
28          final int TIMEOUT = 15*60;          final int TIMEOUT = 30*60;
29          static final Logger log = Logger.getLogger(ShowStats.class.getName());          static final Logger log = Logger.getLogger(ShowStats.class.getName());
30    
31          String login;          String login;
32          String password;          String password;
33                    
34                    MemcachedClient memcache = null;
35    
36    
37          @Override          @Override
# Line 45  public class ShowStats extends HttpServl Line 40  public class ShowStats extends HttpServl
40    
41                  login = getServletContext().getInitParameter("login");                  login = getServletContext().getInitParameter("login");
42                  password = getServletContext().getInitParameter("password");                  password = getServletContext().getInitParameter("password");
43                    
44                    try {
45                            memcache = new MemcachedClient(new InetSocketAddress("localhost", 11211));
46                    } catch (IOException e) {
47                            throw new ServletException(e);
48                    }
49          }          }
50    
51          protected String doLookup(String appId) throws IOException {          protected String doLookup(String query) throws IOException {
                 MemcachedClient c = new MemcachedClient(new InetSocketAddress("localhost", 11211));  
52                                    
53    
54                  String key = "marketstats:" + appId;                  String key = "marketstats:" + query;
55                  String response = (String) c.get(key);                  String response = (String) memcache.get(key);
56    
57                  if (response == null) {                  if (response == null) {
58                          response = doLookupWorker(appId);                          response = doLookupWorker(query);
59                          c.set(key, TIMEOUT, response);                          memcache.set(key, TIMEOUT, response);
60                          response += "<!-- new lookup -->";                          response += "<!-- new lookup -->";
61                  } else {                  } else {
62                          response += "<!-- from memcached -->";                          response += "<!-- from memcached -->";
63                  }                  }
64                  return response;                  return response;
65          }          }
66            
67            private void loadComments(String appId, MarketSession session, ArrayList<CommentBean> commentBeans) {          
68                    CommentCallback commentsCb = new CommentCallback();
69                    commentsCb.setList( commentBeans );
70    
71                    session.setLocale( Locale.ROOT );
72                    
73                    
74                    
75                    int start = 0;
76                    do {
77                            int count = 10;
78                            if (start > 0)                          
79                                    count = Math.min(10, commentsCb.getEntryCount() );
80                            
81                            //log.warning("count=" + count + " start=" + start + " entryCount=" + commentsCb.getEntryCount() );
82                            CommentsRequest commentsRequest = CommentsRequest.newBuilder()
83                            .setAppId(appId)
84                            .setStartIndex(start)
85                            .setEntriesCount(count)
86                            .build();
87                            
88                            session.append(commentsRequest, commentsCb);
89                            session.flush();
90                            start +=10;
91                            
92                            if (start >= 200)
93                                    break; //emergency brake
94                            
95                    } while ( start < commentsCb.getEntryCount() );
96            }
97    
98          protected String doLookupWorker(String appId) {  
99            protected String doLookupWorker(String query) {
100                  final StringBuilder sb = new StringBuilder();                  final StringBuilder sb = new StringBuilder();
101    
102    
103                  MarketSession session = new MarketSession();                  MarketSession session = new MarketSession();
104                  session.login(login,password);                  session.login(login,password);
105                  session.setLocale( Locale.ENGLISH );  
106    
107                  AppsRequest appsRequest = AppsRequest.newBuilder()                  AppsRequest appsRequest = AppsRequest.newBuilder()
108                  .setAppId(appId)                  .setQuery(query)
109                  .setStartIndex(0).setEntriesCount(10)                  .setStartIndex(0).setEntriesCount(10)
110                  .setWithExtendedInfo(true)                  .setWithExtendedInfo(true)
111                  .build();                  .build();
112    
                 CommentsRequest commentsRequest = CommentsRequest.newBuilder()  
                 .setAppId(appId)  
                 .setStartIndex(0)  
                 .setEntriesCount(10)  
                 .build();  
                   
   
   
   
                 Callback<AppsResponse> appsCb = new Callback<AppsResponse>() {  
                         @Override  
                         public void onResult(ResponseContext context, AppsResponse response) {  
                                 //System.out.println("Response : " + response);  
                                 //sb.append("Response: " + response + "\n");  
   
                                 Formatter form = new Formatter(sb);  
                                 App app = response.getApp(0);  
                                 sb.append( "<h2>" + app.getTitle() + "</h2>");  
                                 sb.append("Ver: " + app.getVersion() + "(" + app.getVersionCode() + ")\n"  );  
                                 sb.append("Ratingcount: " + app.getRatingsCount() + "\n");  
   
                                 sb.append("Rating: "  );  
                                 double rating = Double.parseDouble( app.getRating() );  
                                 form.format("%.4f", rating);  
                                 sb.append("\n");  
   
                                 sb.append("Downloads: " + app.getExtendedInfo().getDownloadsCountText() + "(" + app.getExtendedInfo().getDownloadsCount() + ")\n" );  
113    
114                                  sb.append("\n");                  AppsCallback appsCb = new AppsCallback() ;
115                    appsCb.setStringBuffer(sb);
116    
117                          }                  ArrayList<CommentBean> commentBeans = new ArrayList<CommentBean>();
                 };  
118    
                 Callback<CommentsResponse> commentsCb = new Callback<CommentsResponse>() {  
   
                         @Override  
                         public void onResult(ResponseContext context, CommentsResponse response) {  
                                 //System.out.println("Response : " + response);  
                                 //sb.append("Response: " + response + "\n");  
                                 sb.append("--------------------------------------------------------------\n");  
                                 sb.append("Total comments: " + response.getEntriesCount() +"\n\n");  
   
   
                                 List<Comment> cl = response.getCommentsList();  
                                 for (Comment c : cl) {  
                                         sb.append("User: " + c.getAuthorName() + "\n");  
                                         sb.append("Rating: " + c.getRating() + "\n");  
                                         sb.append("Time: " + new Date(c.getCreationTime()).toString() + "\n");  
                                         sb.append( c.getText() + "\n");  
                                         sb.append("\n");  
                                         sb.append(c.getUnknownFields().toString() );  
                                           
                                 }  
                                 sb.append( response.getUnknownFields().toString() );  
119    
120    
121                    session.append(appsRequest, appsCb);
122                    session.flush();
123                    
124                    String appId = appsCb.getAppId();
125                    
126                    if (appId != null) {
127    
128                            loadComments(appId, session, commentBeans);
129            
130                            sb.append("-----------------------------------------------------------------\n");
131                            for (CommentBean c : commentBeans) {
132                                    sb.append("User: " + c.author + "\n");
133                                    sb.append("Rating: " + c.rating + "\n");
134                                    sb.append("Time: " + new Date(c.time).toString() + "\n");
135                                    sb.append( c.text + "\n");
136                                    sb.append("\n");
137            
138                          }                          }
139                            sb.append("Comments: " + commentBeans.size() + "\n");
140                    }
141                    sb.append("Cache.Timeout=" + TIMEOUT/60 + " minutes");          
142    
                 };  
                 session.append(appsRequest, appsCb);  
                 session.append(commentsRequest, commentsCb);  
                 session.flush();  
                 session.setLocale( new Locale("da") );  
                 session.append(commentsRequest, commentsCb);  
                 session.flush();  
143    
144                  return sb.toString();                  return sb.toString();
145          }          }
146    
147          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
148                  String appId = request.getParameter("appId");                  String query = request.getParameter("query");
149                    
150                  response.setContentType("text/html");                  response.setContentType("text/html");
151                  PrintWriter out = response.getWriter();                  PrintWriter out = response.getWriter();
152                  out.print( "<html><body><pre>" + doLookup(appId) + "</pre></body></html>" );                  out.print( "<html><body><pre>" + doLookup(query) + "</pre></body></html>" );
153          }          }
154    
155  }  }

Legend:
Removed from v.660  
changed lines
  Added in v.758

  ViewVC Help
Powered by ViewVC 1.1.20