Implement 4.0 filters with hide action (#202)
* adding new "filtered" field for status * respect "hide" filter action on status * handling expire date for filter closes #161
This commit is contained in:
parent
6107698a76
commit
6220ce6780
|
@ -6,12 +6,14 @@ import com.google.gson.annotations.SerializedName;
|
|||
|
||||
import org.joinmastodon.android.api.ObjectValidationException;
|
||||
import org.joinmastodon.android.api.RequiredField;
|
||||
import org.parceler.Parcel;
|
||||
|
||||
import java.time.Instant;
|
||||
import java.util.EnumSet;
|
||||
import java.util.List;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
@Parcel
|
||||
public class Filter extends BaseModel{
|
||||
@RequiredField
|
||||
public String id;
|
||||
|
@ -21,6 +23,7 @@ public class Filter extends BaseModel{
|
|||
public Instant expiresAt;
|
||||
public boolean irreversible;
|
||||
public boolean wholeWord;
|
||||
public String filterAction;
|
||||
|
||||
@SerializedName("context")
|
||||
private List<FilterContext> _context;
|
||||
|
|
|
@ -0,0 +1,8 @@
|
|||
package org.joinmastodon.android.model;
|
||||
|
||||
import org.parceler.Parcel;
|
||||
|
||||
@Parcel
|
||||
public class FilterResult extends BaseModel {
|
||||
public Filter filter;
|
||||
}
|
|
@ -40,6 +40,7 @@ public class Status extends BaseModel implements DisplayItemsParent{
|
|||
public long favouritesCount;
|
||||
public long repliesCount;
|
||||
public Instant editedAt;
|
||||
public List<FilterResult> filtered;
|
||||
|
||||
public String url;
|
||||
public String inReplyToId;
|
||||
|
|
|
@ -2,8 +2,10 @@ package org.joinmastodon.android.utils;
|
|||
|
||||
import org.joinmastodon.android.api.session.AccountSessionManager;
|
||||
import org.joinmastodon.android.model.Filter;
|
||||
import org.joinmastodon.android.model.FilterResult;
|
||||
import org.joinmastodon.android.model.Status;
|
||||
|
||||
import java.time.Instant;
|
||||
import java.util.List;
|
||||
import java.util.function.Predicate;
|
||||
import java.util.stream.Collectors;
|
||||
|
@ -21,6 +23,12 @@ public class StatusFilterPredicate implements Predicate<Status>{
|
|||
|
||||
@Override
|
||||
public boolean test(Status status){
|
||||
for(FilterResult filterResult:status.filtered){
|
||||
if (filterResult.filter.expiresAt.isAfter(Instant.now()))
|
||||
continue;
|
||||
if (filterResult.filter.filterAction.equals("hide"))
|
||||
return false;
|
||||
}
|
||||
for(Filter filter:filters){
|
||||
if(filter.matches(status))
|
||||
return false;
|
||||
|
|
Loading…
Reference in New Issue