package app.fedilab.android.viewmodel.mastodon; /* Copyright 2021 Thomas Schneider * * This file is a part of Fedilab * * This program is free software; you can redistribute it and/or modify it under the terms of the * GNU General Public License as published by the Free Software Foundation; either version 3 of the * License, or (at your option) any later version. * * Fedilab is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even * the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General * Public License for more details. * * You should have received a copy of the GNU General Public License along with Fedilab; if not, * see . */ import android.app.Application; import android.os.Handler; import android.os.Looper; import androidx.annotation.NonNull; import androidx.lifecycle.AndroidViewModel; import androidx.lifecycle.LiveData; import androidx.lifecycle.MutableLiveData; import java.io.IOException; import java.util.List; import java.util.concurrent.TimeUnit; import app.fedilab.android.client.mastodon.MastodonAnnouncementsService; import app.fedilab.android.client.mastodon.entities.Announcement; import app.fedilab.android.helper.Helper; import okhttp3.OkHttpClient; import retrofit2.Call; import retrofit2.Response; import retrofit2.Retrofit; import retrofit2.converter.gson.GsonConverterFactory; public class AnnouncementsVM extends AndroidViewModel { final OkHttpClient okHttpClient = new OkHttpClient.Builder() .readTimeout(60, TimeUnit.SECONDS) .connectTimeout(60, TimeUnit.SECONDS) .callTimeout(60, TimeUnit.SECONDS) .proxy(Helper.getProxy(getApplication().getApplicationContext())) .build(); private MutableLiveData announcementMutableLiveData; private MutableLiveData> announcementListMutableLiveData; public AnnouncementsVM(@NonNull Application application) { super(application); } private MastodonAnnouncementsService init(@NonNull String instance) { Retrofit retrofit = new Retrofit.Builder() .baseUrl("https://" + instance + "/api/v1/") .addConverterFactory(GsonConverterFactory.create()) .client(okHttpClient) .build(); return retrofit.create(MastodonAnnouncementsService.class); } /** * See all currently active announcements set by admins. * * @param instance Instance domain of the active account * @param token Access token of the active account * @param withDismissed If true, response will include announcements dismissed by the user. Defaults to false. * @return {@link LiveData} containing a {@link List} of {@link Announcement}s */ public LiveData> getAnnouncements(@NonNull String instance, String token, boolean withDismissed) { MastodonAnnouncementsService mastodonAnnouncementsService = init(instance); announcementListMutableLiveData = new MutableLiveData<>(); new Thread(() -> { List announcementList = null; Call> getAnnouncementsCall = mastodonAnnouncementsService.getAnnouncements(token, withDismissed); if (getAnnouncementsCall != null) { try { Response> getAnnouncementsResponse = getAnnouncementsCall.execute(); if (getAnnouncementsResponse.isSuccessful()) { announcementList = getAnnouncementsResponse.body(); } } catch (IOException e) { e.printStackTrace(); } } Handler mainHandler = new Handler(Looper.getMainLooper()); List finalAnnouncementList = announcementList; Runnable myRunnable = () -> announcementListMutableLiveData.setValue(finalAnnouncementList); mainHandler.post(myRunnable); }).start(); return announcementListMutableLiveData; } /** * Allows a user to mark the announcement as read. * * @param instance Instance domain of the active account * @param token Access token of the active account * @param id Local ID of an announcement */ public void dismiss(@NonNull String instance, String token, @NonNull String id) { MastodonAnnouncementsService mastodonAnnouncementsService = init(instance); new Thread(() -> { Call dismissCall = mastodonAnnouncementsService.dismiss(token, id); if (dismissCall != null) { try { dismissCall.execute(); } catch (IOException e) { e.printStackTrace(); } } }).start(); } /** * React to an announcement with an emoji. * * @param instance Instance domain of the active account * @param token Access token of the active account * @param id Local ID of an announcement * @param name Unicode emoji, or shortcode of custom emoji */ public void addReaction(@NonNull String instance, String token, @NonNull String id, @NonNull String name) { MastodonAnnouncementsService mastodonAnnouncementsService = init(instance); new Thread(() -> { Call addReactionCall = mastodonAnnouncementsService.addReaction(token, id, name); if (addReactionCall != null) { try { addReactionCall.execute(); } catch (IOException e) { e.printStackTrace(); } } }).start(); } /** * Undo a react emoji to an announcement. * * @param instance Instance domain of the active account * @param token Access token of the active account * @param id Local ID of an announcement * @param name Unicode emoji, or shortcode of custom emoji */ public void removeReaction(@NonNull String instance, String token, @NonNull String id, @NonNull String name) { MastodonAnnouncementsService mastodonAnnouncementsService = init(instance); new Thread(() -> { Call removeReactionCall = mastodonAnnouncementsService.removeReaction(token, id, name); if (removeReactionCall != null) { try { removeReactionCall.execute(); } catch (IOException e) { e.printStackTrace(); } } }).start(); } }