Fix issue #99 - Add retry when media failed to load and if 3 retries fail the message is kept in drafts but not send

This commit is contained in:
Thomas 2022-06-08 11:43:38 +02:00
parent 8aad0fd264
commit 79c38746e2
2 changed files with 29 additions and 17 deletions

View file

@ -66,9 +66,7 @@ import androidx.navigation.ui.NavigationUI;
import androidx.preference.PreferenceManager;
import com.bumptech.glide.Glide;
import com.bumptech.glide.load.resource.bitmap.CenterCrop;
import com.bumptech.glide.load.resource.gif.GifDrawable;
import com.bumptech.glide.request.RequestOptions;
import com.bumptech.glide.request.target.CustomTarget;
import com.bumptech.glide.request.transition.Transition;
import com.google.android.material.snackbar.Snackbar;

View file

@ -170,21 +170,16 @@ public class PostMessageService extends IntentService {
} else {
fileMultipartBody = Helper.getMultipartBody("file", attachment);
}
Call<Attachment> attachmentCall = mastodonStatusesService.postMedia(dataPost.token, fileMultipartBody, null, attachment.description, null);
if (attachmentCall != null) {
try {
Response<Attachment> attachmentResponse = attachmentCall.execute();
if (attachmentResponse.isSuccessful()) {
Attachment attachmentReply = attachmentResponse.body();
if (attachmentReply != null) {
attachmentIds.add(attachmentReply.id);
}
}
} catch (IOException e) {
error = true;
e.printStackTrace();
}
String replyId = null;
int retry = 0;
while (replyId == null && retry < 3) {
replyId = postAttachment(mastodonStatusesService, dataPost, fileMultipartBody, attachment);
retry++;
}
if (replyId == null) {
error = true;
} else {
attachmentIds.add(replyId);
}
}
@ -296,6 +291,25 @@ public class PostMessageService extends IntentService {
}
}
private static String postAttachment(MastodonStatusesService mastodonStatusesService, DataPost dataPost, MultipartBody.Part fileMultipartBody, Attachment attachment) {
Call<Attachment> attachmentCall = mastodonStatusesService.postMedia(dataPost.token, fileMultipartBody, null, attachment.description, null);
if (attachmentCall != null) {
try {
Response<Attachment> attachmentResponse = attachmentCall.execute();
if (attachmentResponse.isSuccessful()) {
Attachment attachmentReply = attachmentResponse.body();
if (attachmentReply != null) {
return attachmentReply.id;
}
}
} catch (IOException e) {
e.printStackTrace();
}
}
return null;
}
@Override
public void onCreate() {
super.onCreate();