/* * Copyright (c) 2015 Ushahidi Inc * * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU Affero General Public License as published by the Free * Software Foundation, either version 3 of the License, or (at your option) * any later version. * * This program 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program in the file LICENSE-AGPL. If not, see * https://www.gnu.org/licenses/agpl-3.0.html */ package com.ushahidi.platform.mobile.app.domain.usecase.tag; import com.addhen.android.raiburari.domain.executor.PostExecutionThread; import com.addhen.android.raiburari.domain.executor.ThreadExecutor; import com.addhen.android.raiburari.domain.usecase.Usecase; import com.ushahidi.platform.mobile.app.domain.entity.From; import com.ushahidi.platform.mobile.app.domain.repository.TagRepository; import javax.inject.Inject; import rx.Observable; /** * Use case for getting a list of tags either from online or * the local store. * * @author Ushahidi Team <team@ushahidi.com> */ public class ListTagUsecase extends Usecase { private final TagRepository mTagRepository; private Long mDeploymentId = null; private From mFrom; /** * The list of tag use case * * @param tagRepository The tag repository * @param threadExecutor The thread executor * @param postExecutionThread The post execution thread */ @Inject protected ListTagUsecase(TagRepository tagRepository, ThreadExecutor threadExecutor, PostExecutionThread postExecutionThread) { super(threadExecutor, postExecutionThread); mTagRepository = tagRepository; } /** * Sets the deployment ID to be used to fetch the {@link com.ushahidi.platform.mobile.app.domain.entity.Tag} * and where to fetch it from. * * @param deploymentId The deploymentId associated with the GeoJson * @param from Whether to fetch through the API or the local storage */ public void setListTag(Long deploymentId, From from) { mDeploymentId = deploymentId; mFrom = from; } @Override protected Observable buildUseCaseObservable() { if (mDeploymentId == null || mFrom == null) { throw new RuntimeException( "Deployment id and from cannot be null. You must call setListTag(...)"); } return mTagRepository.getTagList(mDeploymentId, mFrom); } }