/*
* 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.data.repository.datasource.tag;
import com.ushahidi.platform.mobile.app.data.api.TagApi;
import com.ushahidi.platform.mobile.app.data.database.TagDatabaseHelper;
import com.ushahidi.platform.mobile.app.data.entity.TagEntity;
import android.support.annotation.NonNull;
import java.util.ArrayList;
import java.util.List;
import rx.Observable;
/**
* Data source for manipulating {@link com.ushahidi.platform.mobile.app.data.entity.TagEntity} data to and from
* the API.
*
* @author Ushahidi Team <team@ushahidi.com>
*/
public class TagApiDataSource implements TagDataSource {
private final TagApi mTagApi;
private final TagDatabaseHelper mTagDatabaseHelper;
/**
* Default constructor that constructs {@link TagApiDataSource}
*
* @param tagApi The tag API
* @param tagDatabaseHelper The tag database helper
*/
public TagApiDataSource(@NonNull TagApi tagApi, TagDatabaseHelper tagDatabaseHelper) {
mTagApi = tagApi;
mTagDatabaseHelper = tagDatabaseHelper;
}
@Override
public Observable<List<TagEntity>> getTagList(Long deploymentId) {
return mTagApi.getTags()
.doOnNext(tag -> mTagDatabaseHelper.putTags(setDeploymentId(tag, deploymentId)));
}
@Override
public Observable<Long> putTag(List<TagEntity> tagList) {
// Do nothing. For now we're posting tags via the API
return null;
}
@Override
public Observable<Boolean> deleteTag(TagEntity tagEntity) {
// Do nothing. For now we're not deleting tags via the API
return null;
}
@Override
public Observable<Boolean> deleteTagList(Long deploymentId) {
// Do nothing. For now we're not deleting tags via the API
return null;
}
/**
* Set the deployment ID for the TagModel since it's not set by the
* API
*
* @param tagEntities The TagModel to set the deployment Id on
* @param deploymentId The ID of the deployment to set
* @return observable
*/
private List<TagEntity> setDeploymentId(List<TagEntity> tagEntities,
Long deploymentId) {
List<TagEntity> tagEntityList = new ArrayList<>(tagEntities.size());
for (TagEntity tagEntity : tagEntities) {
tagEntity.setDeploymentId(deploymentId);
tagEntityList.add(tagEntity);
}
return tagEntityList;
}
}