mirror of
https://github.com/commons-app/apps-android-commons.git
synced 2025-10-29 05:43:55 +01:00
* Fix #2215 Added BetaCheckerUtil class and made necessary changes * Fix #2215 Fixed formatting error in LogSender class * Fix #2215 Renamed BetaCheckerUtil to ConfigUtils * Fix #2215 Fixed formatting in CommonsApplicationModule
This commit is contained in:
parent
cd322d2f57
commit
b05b302e65
9 changed files with 39 additions and 24 deletions
|
|
@ -3,11 +3,11 @@ package fr.free.nrw.commons.logging;
|
|||
import android.content.Context;
|
||||
|
||||
import javax.inject.Inject;
|
||||
import javax.inject.Named;
|
||||
import javax.inject.Singleton;
|
||||
|
||||
import fr.free.nrw.commons.BuildConfig;
|
||||
import fr.free.nrw.commons.auth.SessionManager;
|
||||
import fr.free.nrw.commons.utils.ConfigUtils;
|
||||
import fr.free.nrw.commons.utils.DeviceInfoUtil;
|
||||
|
||||
/**
|
||||
|
|
@ -24,12 +24,12 @@ public class CommonsLogSender extends LogsSender {
|
|||
|
||||
@Inject
|
||||
public CommonsLogSender(SessionManager sessionManager,
|
||||
Context context,
|
||||
@Named("isBeta") boolean isBeta) {
|
||||
super(sessionManager, isBeta);
|
||||
Context context) {
|
||||
super(sessionManager);
|
||||
|
||||
this.sessionManager = sessionManager;
|
||||
this.context = context;
|
||||
boolean isBeta = ConfigUtils.isBetaFlavour();
|
||||
this.logFileName = isBeta ? "CommonsBetaAppLogs.zip" : "CommonsAppLogs.zip";
|
||||
String emailSubjectFormat = isBeta ? BETA_LOGS_PRIVATE_EMAIL_SUBJECT : LOGS_PRIVATE_EMAIL_SUBJECT;
|
||||
this.emailSubject = String.format(emailSubjectFormat, sessionManager.getUserName());
|
||||
|
|
|
|||
|
|
@ -20,6 +20,7 @@ import java.util.zip.ZipEntry;
|
|||
import java.util.zip.ZipOutputStream;
|
||||
|
||||
import fr.free.nrw.commons.auth.SessionManager;
|
||||
import fr.free.nrw.commons.utils.ConfigUtils;
|
||||
import timber.log.Timber;
|
||||
|
||||
/**
|
||||
|
|
@ -33,16 +34,14 @@ public abstract class LogsSender implements ReportSender {
|
|||
String emailBody;
|
||||
|
||||
private final SessionManager sessionManager;
|
||||
private final boolean isBeta;
|
||||
|
||||
LogsSender(SessionManager sessionManager,
|
||||
boolean isBeta) {
|
||||
LogsSender(SessionManager sessionManager) {
|
||||
this.sessionManager = sessionManager;
|
||||
this.isBeta = isBeta;
|
||||
}
|
||||
|
||||
/**
|
||||
* Overrides send method of ACRA's ReportSender to send logs
|
||||
*
|
||||
* @param context
|
||||
* @param report
|
||||
*/
|
||||
|
|
@ -53,6 +52,7 @@ public abstract class LogsSender implements ReportSender {
|
|||
|
||||
/**
|
||||
* Gets zipped log files and sends it via email. Can be modified to change the send log mechanism
|
||||
*
|
||||
* @param context
|
||||
* @param report
|
||||
*/
|
||||
|
|
@ -73,6 +73,7 @@ public abstract class LogsSender implements ReportSender {
|
|||
|
||||
/**
|
||||
* Fires an intent to send email with logs
|
||||
*
|
||||
* @param context
|
||||
* @param logFileUri
|
||||
*/
|
||||
|
|
@ -91,6 +92,7 @@ public abstract class LogsSender implements ReportSender {
|
|||
|
||||
/**
|
||||
* Returns the URI for the zipped log file
|
||||
*
|
||||
* @param context
|
||||
* @param report
|
||||
* @return
|
||||
|
|
@ -115,6 +117,7 @@ public abstract class LogsSender implements ReportSender {
|
|||
|
||||
/**
|
||||
* Checks if there are any pending crash reports and attaches them to the logs
|
||||
*
|
||||
* @param report
|
||||
* @param builder
|
||||
*/
|
||||
|
|
@ -127,6 +130,7 @@ public abstract class LogsSender implements ReportSender {
|
|||
|
||||
/**
|
||||
* Attaches username to the the meta_data file
|
||||
*
|
||||
* @param builder
|
||||
*/
|
||||
private void attachUserInfo(StringBuilder builder) {
|
||||
|
|
@ -135,6 +139,7 @@ public abstract class LogsSender implements ReportSender {
|
|||
|
||||
/**
|
||||
* Gets any extra meta information to be attached with the log files
|
||||
*
|
||||
* @param builder
|
||||
*/
|
||||
private void attachExtraInfo(StringBuilder builder) {
|
||||
|
|
@ -145,6 +150,7 @@ public abstract class LogsSender implements ReportSender {
|
|||
|
||||
/**
|
||||
* Zips the logs and meta information
|
||||
*
|
||||
* @param metaData
|
||||
* @param zipFile
|
||||
* @throws IOException
|
||||
|
|
@ -153,12 +159,13 @@ public abstract class LogsSender implements ReportSender {
|
|||
FileOutputStream fos = new FileOutputStream(zipFile);
|
||||
BufferedOutputStream bos = new BufferedOutputStream(fos);
|
||||
ZipOutputStream zos = new ZipOutputStream(bos);
|
||||
boolean isBeta = ConfigUtils.isBetaFlavour();
|
||||
File logDir = new File(LogUtils.getLogDirectory(isBeta));
|
||||
|
||||
if (!logDir.exists() || logDir.listFiles().length == 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
byte[] buffer = new byte[1024];
|
||||
for (File file : logDir.listFiles()) {
|
||||
FileInputStream fis = new FileInputStream(file);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue