/[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 659 by torben, Fri Apr 23 12:31:41 2010 UTC revision 663 by torben, Fri Apr 23 15:23:44 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;
9  import java.util.Formatter;  import java.util.Formatter;
 import java.util.List;  
10  import java.util.Locale;  import java.util.Locale;
11  import java.util.logging.Logger;  import java.util.logging.Logger;
12    
# Line 21  import com.gc.android.market.api.MarketS Line 22  import com.gc.android.market.api.MarketS
22  import com.gc.android.market.api.model.Market.App;  import com.gc.android.market.api.model.Market.App;
23  import com.gc.android.market.api.model.Market.AppsRequest;  import com.gc.android.market.api.model.Market.AppsRequest;
24  import com.gc.android.market.api.model.Market.AppsResponse;  import com.gc.android.market.api.model.Market.AppsResponse;
 import com.gc.android.market.api.model.Market.Comment;  
25  import com.gc.android.market.api.model.Market.CommentsRequest;  import com.gc.android.market.api.model.Market.CommentsRequest;
 import com.gc.android.market.api.model.Market.CommentsResponse;  
26  import com.gc.android.market.api.model.Market.ResponseContext;  import com.gc.android.market.api.model.Market.ResponseContext;
27    
28    
29  public class ShowStats extends HttpServlet {  public class ShowStats extends HttpServlet {
30          private static final long serialVersionUID = 1L;          private static final long serialVersionUID = 1L;
31    
32          final int TIMEOUT = 15*60;          final int TIMEOUT = 30*60;
33          static final Logger log = Logger.getLogger(ShowStats.class.getName());          static final Logger log = Logger.getLogger(ShowStats.class.getName());
34    
35          String login;          String login;
36          String password;          String password;
           
           
37    
38    
39          @Override          @Override
# Line 49  public class ShowStats extends HttpServl Line 46  public class ShowStats extends HttpServl
46    
47          protected String doLookup(String appId) throws IOException {          protected String doLookup(String appId) throws IOException {
48                  MemcachedClient c = new MemcachedClient(new InetSocketAddress("localhost", 11211));                  MemcachedClient c = new MemcachedClient(new InetSocketAddress("localhost", 11211));
49                  c.flush();  
                   
50    
51                  String key = "marketstats:" + appId;                  String key = "marketstats:" + appId;
52                  String response = (String) c.get(key);                  String response = (String) c.get(key);
# Line 64  public class ShowStats extends HttpServl Line 60  public class ShowStats extends HttpServl
60                  }                  }
61                  return response;                  return response;
62          }          }
63            
64            private void loadComments(String appId, MarketSession session, String locale, ArrayList<CommentBean> commentBeans) {            
65                    CommentCallback commentsCb = new CommentCallback();
66                    commentsCb.setList( commentBeans );
67    
68                    commentsCb.setLocale( locale );
69                    session.setLocale( new Locale(locale) );
70                    
71                    
72                    int start = 0;
73                    do {
74                            int count = 10;
75                            if (start > 0)                          
76                                    count = Math.min(10, commentsCb.getEntryCount() );
77                            
78                            log.warning("count=" + count + " start=" + start + " " + locale);
79                            CommentsRequest commentsRequest = CommentsRequest.newBuilder()
80                            .setAppId(appId)
81                            .setStartIndex(start)
82                            .setEntriesCount(count)
83                            .build();
84                            
85                            session.append(commentsRequest, commentsCb);
86                            session.flush();
87                            start +=10;
88                            
89                            if (start >= 30)
90                                    break; //emergency brake
91                            
92                    } while ( start < commentsCb.getEntryCount() );
93            }
94    
95    
96          protected String doLookupWorker(String appId) {          protected String doLookupWorker(String appId) {
# Line 72  public class ShowStats extends HttpServl Line 99  public class ShowStats extends HttpServl
99    
100                  MarketSession session = new MarketSession();                  MarketSession session = new MarketSession();
101                  session.login(login,password);                  session.login(login,password);
102                  session.setLocale( Locale.ENGLISH );  
103    
104                  AppsRequest appsRequest = AppsRequest.newBuilder()                  AppsRequest appsRequest = AppsRequest.newBuilder()
105                  .setAppId(appId)                  .setAppId(appId)
# Line 80  public class ShowStats extends HttpServl Line 107  public class ShowStats extends HttpServl
107                  .setWithExtendedInfo(true)                  .setWithExtendedInfo(true)
108                  .build();                  .build();
109    
                 CommentsRequest commentsRequest = CommentsRequest.newBuilder()  
                 .setAppId(appId)  
                 .setStartIndex(0)  
                 .setEntriesCount(10)  
                 .build();  
                   
   
110    
111                    AppsCallback appsCb = new AppsCallback() ;
112                    appsCb.setStringBuffer(sb);
113    
114                  Callback<AppsResponse> appsCb = new Callback<AppsResponse>() {                  ArrayList<CommentBean> commentBeans = new ArrayList<CommentBean>();
                         @Override  
                         public void onResult(ResponseContext context, AppsResponse response) {  
                                 //System.out.println("Response : " + response);  
                                 //sb.append("Response: " + response + "\n");  
115    
                                 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");  
116    
                                 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" );  
   
                                 sb.append("\n");  
   
                         }  
                 };  
   
                 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");  
117    
118                    session.append(appsRequest, appsCb);
119                    session.flush();
120    
121                                  List<Comment> cl = response.getCommentsList();                  loadComments(appId, session, "da", commentBeans);
122                                  for (Comment c : cl) {                  loadComments(appId, session, "en", commentBeans);
                                         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() );  
123    
124                    Collections.sort(commentBeans);
125    
126                    sb.append("-----------------------------------------------------------------\n");
127                    for (CommentBean c : commentBeans) {
128                            sb.append("User: " + c.author + " ("  + c.locale + ")\n");
129                            sb.append("Rating: " + c.rating + "\n");
130                            sb.append("Time: " + new Date(c.time).toString() + "\n");
131                            sb.append( c.text + "\n");
132                            sb.append("\n");
133    
134                          }                  }
135                    sb.append("Comments: " + commentBeans.size() );
136    
                 };  
                 session.append(appsRequest, appsCb);  
                 session.append(commentsRequest, commentsCb);  
                 session.flush();  
                 session.setLocale( new Locale("da") );  
                 session.append(commentsRequest, commentsCb);  
                 session.flush();  
137    
138                  return sb.toString();                  return sb.toString();
139          }          }
140    
141          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
142                  String appId = request.getParameter("appId");                  String appId = request.getParameter("appId");
                 PrintWriter out = response.getWriter();  
143    
144                  out.print( "<pre>" + doLookup(appId) + "</pre>" );                  response.setContentType("text/html");
145                    PrintWriter out = response.getWriter();
146                    out.print( "<html><body><pre>" + doLookup(appId) + "</pre></body></html>" );
147          }          }
148    
149  }  }

Legend:
Removed from v.659  
changed lines
  Added in v.663

  ViewVC Help
Powered by ViewVC 1.1.20