From 6ec6bcc5c6ecb65b9d8b154f3058f5ad27aafdca Mon Sep 17 00:00:00 2001
From: Sonia Zorba <sonia.zorba@inaf.it>
Date: Mon, 24 Aug 2020 17:10:16 +0200
Subject: [PATCH] Added GroupStatusManager

---
 gms/pom.xml                                   |  5 +
 .../ia2/gms/manager/GroupStatusManager.java   | 96 +++++++++++++++++++
 .../ia2/gms/persistence/MembershipsDAO.java   | 25 +++++
 3 files changed, 126 insertions(+)
 create mode 100644 gms/src/main/java/it/inaf/ia2/gms/manager/GroupStatusManager.java

diff --git a/gms/pom.xml b/gms/pom.xml
index afe66f7..d3842da 100644
--- a/gms/pom.xml
+++ b/gms/pom.xml
@@ -41,6 +41,11 @@
             <artifactId>postgresql</artifactId>
             <scope>runtime</scope>
         </dependency>
+        <dependency>
+            <groupId>com.opencsv</groupId>
+            <artifactId>opencsv</artifactId>
+            <version>3.8</version>
+        </dependency>
         <dependency>
             <groupId>org.springframework.boot</groupId>
             <artifactId>spring-boot-devtools</artifactId>
diff --git a/gms/src/main/java/it/inaf/ia2/gms/manager/GroupStatusManager.java b/gms/src/main/java/it/inaf/ia2/gms/manager/GroupStatusManager.java
new file mode 100644
index 0000000..e6d2b38
--- /dev/null
+++ b/gms/src/main/java/it/inaf/ia2/gms/manager/GroupStatusManager.java
@@ -0,0 +1,96 @@
+package it.inaf.ia2.gms.manager;
+
+import it.inaf.ia2.gms.exception.UnauthorizedException;
+import it.inaf.ia2.gms.model.Permission;
+import it.inaf.ia2.gms.model.RapUser;
+import it.inaf.ia2.gms.persistence.GroupsDAO;
+import it.inaf.ia2.gms.persistence.MembershipsDAO;
+import it.inaf.ia2.gms.persistence.model.GroupEntity;
+import it.inaf.ia2.gms.persistence.model.MembershipEntity;
+import it.inaf.ia2.gms.rap.RapClient;
+import it.inaf.ia2.gms.service.GroupNameService;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+@Service
+public class GroupStatusManager extends UserAwareComponent {
+
+    private static final Logger LOG = LoggerFactory.getLogger(GroupStatusManager.class);
+
+    @Autowired
+    private PermissionsManager permissionsManager;
+
+    @Autowired
+    private GroupsDAO groupsDAO;
+
+    @Autowired
+    private MembershipsDAO membershipsDAO;
+
+    @Autowired
+    private GroupNameService groupNameService;
+
+    @Autowired
+    private RapClient rapClient;
+
+    public List<Object[]> generateStatus(GroupEntity parentGroup) {
+
+        Permission groupPermission = permissionsManager.getCurrentUserPermission(parentGroup);
+
+        if (groupPermission != Permission.ADMIN) {
+            throw new UnauthorizedException("ADMIN permission is needed for performing this action");
+        }
+
+        List<GroupEntity> groups = groupsDAO.getAllChildren(parentGroup.getPath());
+
+        List<String> names = groupNameService.getGroupsNames(groups);
+
+        List<MembershipEntity> memberships = membershipsDAO.findByGroups(groups.stream()
+                .map(g -> g.getId()).collect(Collectors.toList()));
+
+        Map<String, List<String>> membersMap = new HashMap<>();
+
+        for (MembershipEntity membership : memberships) {
+
+            List<String> users = membersMap.get(membership.getGroupId());
+            if (users == null) {
+                users = new ArrayList<>();
+                membersMap.put(membership.getGroupId(), users);
+            }
+            users.add(membership.getUserId());
+        }
+
+        Map<String, String> usersMap = new HashMap<>();
+        for (RapUser user : rapClient.getUsers(memberships.stream()
+                .map(u -> u.getUserId()).collect(Collectors.toSet()))) {
+            usersMap.put(user.getId(), user.getPrimaryEmail());
+        }
+
+        List<Object[]> rows = new ArrayList<>();
+
+        for (int i = 0; i < groups.size(); i++) {
+            GroupEntity group = groups.get(i);
+            String groupName = names.get(i);
+            List<String> users = membersMap.get(group.getId());
+            if (users != null) {
+                for (String userId : users) {
+                    String email = usersMap.get(userId);
+                    if (email == null) {
+                        LOG.warn("Unable to retrieve information about user " + userId);
+                        continue;
+                    }
+                    Object[] row = new Object[]{groupName, email};
+                    rows.add(row);
+                }
+            }
+        }
+
+        return rows;
+    }
+}
diff --git a/gms/src/main/java/it/inaf/ia2/gms/persistence/MembershipsDAO.java b/gms/src/main/java/it/inaf/ia2/gms/persistence/MembershipsDAO.java
index 6f0b4c6..22b0811 100644
--- a/gms/src/main/java/it/inaf/ia2/gms/persistence/MembershipsDAO.java
+++ b/gms/src/main/java/it/inaf/ia2/gms/persistence/MembershipsDAO.java
@@ -5,6 +5,7 @@ import it.inaf.ia2.gms.persistence.model.MembershipEntity;
 import java.sql.PreparedStatement;
 import java.sql.Types;
 import java.util.ArrayList;
+import java.util.Collections;
 import java.util.List;
 import java.util.stream.Collectors;
 import javax.sql.DataSource;
@@ -42,6 +43,30 @@ public class MembershipsDAO {
         });
     }
 
+    public List<MembershipEntity> findByGroups(List<String> groupIds) {
+
+        String sql = "SELECT user_id, group_id FROM gms_membership WHERE group_id IN ("
+                + String.join(",", Collections.nCopies(groupIds.size(), "?")) + ")";
+
+        return jdbcTemplate.query(conn -> {
+            PreparedStatement ps = conn.prepareStatement(sql);
+            int i = 0;
+            for (String groupId : groupIds) {
+                ps.setString(++i, groupId);
+            }
+            return ps;
+        }, resultSet -> {
+            List<MembershipEntity> members = new ArrayList<>();
+            while (resultSet.next()) {
+                MembershipEntity membership = new MembershipEntity();
+                membership.setGroupId(resultSet.getString("group_id"));
+                membership.setUserId(resultSet.getString("user_id"));
+                members.add(membership);
+            }
+            return members;
+        });
+    }
+
     public List<GroupEntity> getUserMemberships(String userId) {
         return getUserMemberships(userId, null);
     }
-- 
GitLab