]> nmode's Git Repositories - signal-cli/blobdiff - src/main/java/org/asamk/signal/storage/groups/GroupInfo.java
Show pending and requesting members of v2 groups
[signal-cli] / src / main / java / org / asamk / signal / storage / groups / GroupInfo.java
index 96147fe3e76b529ca08bd0006c0c6ae40f81066c..d24a2694251ef85215559c24d544f85ab7d4ff13 100644 (file)
@@ -3,42 +3,63 @@ package org.asamk.signal.storage.groups;
 import com.fasterxml.jackson.annotation.JsonIgnore;
 import com.fasterxml.jackson.annotation.JsonProperty;
 
-import java.util.Collection;
+import org.whispersystems.signalservice.api.push.SignalServiceAddress;
+
 import java.util.HashSet;
 import java.util.Set;
 
-public class GroupInfo {
+public abstract class GroupInfo {
+
     @JsonProperty
     public final byte[] groupId;
 
-    @JsonProperty
-    public String name;
+    public GroupInfo(byte[] groupId) {
+        this.groupId = groupId;
+    }
 
-    @JsonProperty
-    public Set<String> members = new HashSet<>();
+    @JsonIgnore
+    public abstract String getTitle();
 
-    private long avatarId;
+    @JsonIgnore
+    public abstract Set<SignalServiceAddress> getMembers();
 
     @JsonIgnore
-    public long getAvatarId() {
-        return avatarId;
+    public Set<SignalServiceAddress> getPendingMembers() {
+        return Set.of();
     }
 
-    @JsonProperty
-    public boolean active;
+    @JsonIgnore
+    public Set<SignalServiceAddress> getRequestingMembers() {
+        return Set.of();
+    }
 
-    @JsonProperty
-    public String color;
+    @JsonIgnore
+    public abstract boolean isBlocked();
 
-    public GroupInfo(byte[] groupId) {
-        this.groupId = groupId;
+    @JsonIgnore
+    public abstract void setBlocked(boolean blocked);
+
+    @JsonIgnore
+    public abstract int getMessageExpirationTime();
+
+    @JsonIgnore
+    public Set<SignalServiceAddress> getMembersWithout(SignalServiceAddress address) {
+        Set<SignalServiceAddress> members = new HashSet<>();
+        for (SignalServiceAddress member : getMembers()) {
+            if (!member.matches(address)) {
+                members.add(member);
+            }
+        }
+        return members;
     }
 
-    public GroupInfo(@JsonProperty("groupId") byte[] groupId, @JsonProperty("name") String name, @JsonProperty("members") Collection<String> members, @JsonProperty("avatarId") long avatarId, @JsonProperty("color") String color) {
-        this.groupId = groupId;
-        this.name = name;
-        this.members.addAll(members);
-        this.avatarId = avatarId;
-        this.color = color;
+    @JsonIgnore
+    public boolean isMember(SignalServiceAddress address) {
+        for (SignalServiceAddress member : getMembers()) {
+            if (member.matches(address)) {
+                return true;
+            }
+        }
+        return false;
     }
 }