made bug report works again

This commit is contained in:
Mariotaku Lee 2015-03-29 19:06:55 +08:00
parent 593027bad0
commit 9e991346e1
8 changed files with 322 additions and 291 deletions

View File

@ -35,11 +35,16 @@ Twidere is a powerful twitter client for Android 4.0+, which gives you a full Ma
## Credits ##
### Material re-design ###
* [@Uucky_Lee](https://twitter.com/Uucky_Lee)
### Icon designers ###
* [@lordfriend](https://twitter.com/#!/lordfriend)
* [@ilovinheart](https://twitter.com/#!/ilovinheart) (0.0.7 version)
* [@Rieya](https://twitter.com/#!/Rieya) (0.0.6 version)
* [@Linkzero](https://twitter.com/Linkzero)
* [@lordfriend](https://twitter.com//lordfriend)
* [@ilovinheart](https://twitter.com/ilovinheart) (0.0.7 version)
* [@Rieya](https://twitter.com/Rieya) (0.0.6 version)
Thanks to their excellent design!
@ -91,7 +96,7 @@ Bitcoin: 1FHAVAzge7cj1LfCTMfnLL49DgA3mVUCuW
[@TwidereProject/donators](https://twitter.com/TwidereProject/lists/donators), if you haven't find your name, please contact @TwidereProject :)
Buy me a bread or anything you want :)
Buy me a ~~bread~~ [game](http://steamcommunity.com/id/mariotaku/wishlist) or anything you want :)
---

2
twidere/.gitignore vendored
View File

@ -1 +1,3 @@
/build
res-localized/

View File

@ -44,6 +44,11 @@ android {
versionNameSuffix String.format(" (dev %s)", format.format(new Date()))
}
}
sourceSets {
main {
res.srcDirs = [project.file("src/$name/res"), project.file("src/$name/res-localized")]
}
}
}
repositories {

View File

@ -590,8 +590,8 @@
android:windowSoftInputMode="stateAlwaysHidden"/>
<activity
android:name=".activity.support.UsageStatisticsActivity"
android:label="@string/title_activity_usage_statistics" >
</activity>
android:theme="@android:style/Theme.NoDisplay"
android:label="@string/usage_statistics"/>
<service
android:name=".service.RefreshService"

View File

@ -54,6 +54,7 @@ import org.mariotaku.twidere.view.holder.GapViewHolder;
import org.mariotaku.twidere.view.holder.StatusViewHolder;
import edu.tsinghua.spice.Utilies.SpiceProfilingUtil;
import edu.tsinghua.spice.Utilies.TypeMappingUtil;
import static org.mariotaku.twidere.util.Utils.setMenuForStatus;
@ -354,17 +355,21 @@ public abstract class AbsStatusesFragment<Data> extends BaseSupportFragment impl
twitter.destroyFavoriteAsync(status.account_id, status.id);
//spice
SpiceProfilingUtil.profile(activity, status.account_id, status.id + ",Unfavor,"
+ status.account_id + "," + status.user_id + "," + status.reply_count + "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
+ status.account_id + "," + status.user_id + "," + status.reply_count
+ "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
SpiceProfilingUtil.log(activity, status.id + ",Unfavor,"
+ status.account_id + "," + status.user_id + "," + status.reply_count + "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
+ status.account_id + "," + status.user_id + "," + status.reply_count
+ "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
//end
} else {
twitter.createFavoriteAsync(status.account_id, status.id);
//spice
SpiceProfilingUtil.profile(activity, status.account_id, status.id + ",Favor,"
+ status.account_id + "," + status.user_id + "," + status.reply_count + "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
+ status.account_id + "," + status.user_id + "," + status.reply_count
+ "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
SpiceProfilingUtil.log(activity, status.id + ",Favor,"
+ status.account_id + "," + status.user_id + "," + status.reply_count + "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
+ status.account_id + "," + status.user_id + "," + status.reply_count
+ "," + status.retweet_count + "," + status.favorite_count + "," + status.timestamp);
//end
}
break;
@ -452,6 +457,16 @@ public abstract class AbsStatusesFragment<Data> extends BaseSupportFragment impl
final ParcelableStatus status = mAdapter.getStatus(position);
if (status == null) return;
Utils.openMedia(getActivity(), status, media);
//spice
SpiceProfilingUtil.log(getActivity(),
status.id + ",Clicked," + status.account_id + "," + status.user_id + ","
+ status.text_plain.length() + "," + media.media_url + ","
+ TypeMappingUtil.getMediaType(media.type) + "," + status.timestamp);
SpiceProfilingUtil.profile(getActivity(), status.account_id,
status.id + ",Clicked," + status.account_id + "," + status.user_id + ","
+ status.text_plain.length() + "," + media.media_url + ","
+ TypeMappingUtil.getMediaType(media.type) + "," + status.timestamp);
//end
}
private void updateRefreshProgressOffset() {

View File

@ -391,7 +391,7 @@ public class StatusFragment extends BaseSupportFragment
+ "," + status.text_plain.length() + "," + status.timestamp);
} else {
for (final ParcelableMedia spiceMedia : status.media) {
if (TypeMappingUtil.getMediaType(spiceMedia.type).equals("image")) {
if (spiceMedia.type == ParcelableMedia.TYPE_IMAGE) {
SpiceProfilingUtil.profile(getActivity(), status.account_id,
status.id + ",PreviewM," + status.account_id + "," + status.user_id
+ "," + status.reply_count + "," + status.retweet_count + "," + status.favorite_count

View File

@ -24,28 +24,24 @@ import android.os.Build;
import android.os.Build.VERSION;
import android.text.TextUtils;
import android.util.JsonReader;
import android.util.JsonWriter;
import android.util.Log;
import com.squareup.okhttp.MediaType;
import com.squareup.okhttp.OkHttpClient;
import com.squareup.okhttp.Request;
import com.squareup.okhttp.Request.Builder;
import com.squareup.okhttp.RequestBody;
import com.squareup.okhttp.Response;
import org.acra.ACRA;
import org.acra.ErrorReporter;
import org.acra.ReportField;
import org.acra.collector.CrashReportData;
import org.acra.sender.ReportSender;
import org.acra.sender.ReportSenderException;
import org.json.JSONException;
import org.json.JSONObject;
import org.mariotaku.twidere.BuildConfig;
import org.mariotaku.twidere.Constants;
import org.mariotaku.twidere.app.TwidereApplication;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.Charset;
import java.util.Locale;
import java.util.Scanner;
@ -63,7 +59,7 @@ public class BugReporter implements Constants {
public static class GitHubIssueReportSender implements ReportSender {
private static final String AUTH_TOKEN = "208aacee0f51338a85ba5e9e3da54859981456ca";
private static final String AUTH_TOKEN = "be96f826b8d1947e3a988cace182b57bf8b2cd00";
private static final String USER_REPO = "mariotaku-bugreport/Twidere-Android.bugreport.test";
@Override
@ -83,23 +79,19 @@ public class BugReporter implements Constants {
titleBuilder.append(checksum);
titleBuilder.append(" ");
titleBuilder.append(titleContent);
final JSONObject json = new JSONObject();
try {
json.put("title", titleBuilder.toString());
json.put("body", bodyBuilder.toString());
} catch (JSONException e) {
throw new ReportSenderException("Error processing report json", e);
}
final OkHttpClient client = new OkHttpClient();
final Request.Builder searchIssueBuilder = new Request.Builder();
final String query = String.format(Locale.ROOT, "%s repo:%s", checksum, USER_REPO);
final Uri.Builder searchIssueUrlBuilder = Uri.parse("https://api.github.com/search/issues").buildUpon();
searchIssueUrlBuilder.appendQueryParameter("q", query);
searchIssueBuilder.url(searchIssueUrlBuilder.build().toString());
authorizeRequest(searchIssueBuilder);
HttpURLConnection searchIssueConnection = null;
int searchIssueConnectionStatus = -1;
try {
final Response response = client.newCall(searchIssueBuilder.build()).execute();
final JsonReader jsonReader = new JsonReader(response.body().charStream());
searchIssueConnection = (HttpURLConnection) new URL(searchIssueUrlBuilder.build().toString()).openConnection();
searchIssueConnection.setRequestMethod("GET");
authorizeRequest(searchIssueConnection);
searchIssueConnection.setDoInput(true);
searchIssueConnectionStatus = searchIssueConnection.getResponseCode();
final InputStreamReader reader = new InputStreamReader(searchIssueConnection.getInputStream());
final JsonReader jsonReader = new JsonReader(reader);
boolean isDuplicate = false;
jsonReader.beginObject();
while (jsonReader.hasNext()) {
@ -115,18 +107,34 @@ public class BugReporter implements Constants {
return;
}
} catch (IOException e) {
final String msg = "Network error when searching issues";
final String msg = "Network error when searching issues, code " + searchIssueConnectionStatus;
Log.w(LOGTAG, msg, e);
throw new ReportSenderException(msg, e);
} finally {
if (searchIssueConnection != null) {
searchIssueConnection.disconnect();
}
final RequestBody issueBody = RequestBody.create(MediaType.parse("application/json"), json.toString());
final Request.Builder createIssueBuilder = new Request.Builder();
createIssueBuilder.url(String.format(Locale.ROOT, "https://api.github.com/repos/%s/issues", USER_REPO));
createIssueBuilder.post(issueBody);
authorizeRequest(createIssueBuilder);
}
createIssue(bodyBuilder.toString(), titleBuilder.toString());
}
private void createIssue(String body, String title) throws ReportSenderException {
HttpURLConnection createIssueConnection;
try {
final Response response = client.newCall(createIssueBuilder.build()).execute();
final String location = response.header("Location");
createIssueConnection = (HttpURLConnection) new URL(String.format(Locale.ROOT, "https://api.github.com/repos/%s/issues", USER_REPO)).openConnection();
createIssueConnection.setRequestMethod("POST");
authorizeRequest(createIssueConnection);
createIssueConnection.setRequestProperty("Content-Type", "application/json");
createIssueConnection.setDoOutput(true);
final JsonWriter writer = new JsonWriter(new OutputStreamWriter(createIssueConnection.getOutputStream()));
writer.beginObject();
writer.name("title").value(title);
writer.name("body").value(body);
writer.endObject();
writer.flush();
createIssueConnection.connect();
final String location = createIssueConnection.getHeaderField("Location");
if (!TextUtils.isEmpty(location)) {
Log.d(LOGTAG, "Issue created at " + location);
}
@ -166,10 +174,10 @@ public class BugReporter implements Constants {
bodyBuilder.append("\n````");
}
private void authorizeRequest(Builder builder) {
builder.header("Authorization", "token " + AUTH_TOKEN);
builder.header("Accept", "application/vnd.github.v3+json");
builder.header("User-Agent", "Twidere (" + BuildConfig.VERSION_NAME + ")");
private void authorizeRequest(HttpURLConnection builder) {
builder.setRequestProperty("Authorization", String.format(Locale.ROOT, "token %s", AUTH_TOKEN));
builder.setRequestProperty("Accept", "application/vnd.github.v3+json");
builder.setRequestProperty("User-Agent", "Twidere (" + BuildConfig.VERSION_NAME + ")");
}
}
}

View File

@ -729,10 +729,6 @@
<string name="permission_description_shorten_status">Application can shorten tweet for Twidere, so it can access your tweet to send.</string>
<string name="permission_description_upload_media">Application can upload media for Twidere, so it can access media in your tweet to send.</string>
<string name="permission_description_sync_timeline">Application can sync read position for Twidere, so it can access your read position.</string>
<string name="title_activity_usage_statistics">UsageStatisticsActivity</string>
<string name="hello_world">Hello world!</string>
<string name="action_settings">Settings</string>
<string name="usage_statistics_notification_summary">Help us improve Twidere!</string>
<string name="from_name">From <xliff:g id="name">%1$s</xliff:g></string>
<string name="from_name_and_name">From <xliff:g id="name">%1$s</xliff:g> and <xliff:g id="name">%2$s</xliff:g></string>