|
11 | 11 | import javax.persistence.EntityManager; |
12 | 12 | import javax.persistence.PersistenceContext; |
13 | 13 | import javax.persistence.Query; |
| 14 | +import javax.persistence.Tuple; |
14 | 15 | import javax.transaction.Transactional; |
| 16 | + |
| 17 | +import java.util.HashMap; |
15 | 18 | import java.util.HashSet; |
| 19 | +import java.util.List; |
| 20 | +import java.util.Map; |
16 | 21 | import java.util.Optional; |
| 22 | +import java.util.stream.Collectors; |
17 | 23 |
|
18 | 24 | import static com.glaum.login.util.RoleEnum.ROLE_ADMIN; |
19 | 25 | import static com.glaum.login.util.RoleEnum.ROLE_USER; |
@@ -43,6 +49,23 @@ public int createUser(com.glaum.login.model.User user) { |
43 | 49 | public int creatAdmin(com.glaum.login.model.User user) { |
44 | 50 | return create(user, ROLE_ADMIN); |
45 | 51 | } |
| 52 | + |
| 53 | + public Map<String, Integer> findUserPermission(int userid) { |
| 54 | + Query query = entityManager.createNativeQuery("select p.bit,p.name \n" |
| 55 | + + " FROM user u LEFT JOIN permission p ON u.permissionid & p.bit\n" |
| 56 | + + " WHERE u.id =?"); |
| 57 | + query.setParameter(1,userid); |
| 58 | + List<Object[]> resultList = query.getResultList(); |
| 59 | + Map<String,Integer> mapofper= new HashMap<String, Integer>(); |
| 60 | + for (Object[] ob : resultList){ |
| 61 | + |
| 62 | + String key = (String)ob[1]; |
| 63 | + int value = (int) ob[0]; |
| 64 | + mapofper.put(key,value); |
| 65 | + } |
| 66 | + return mapofper; |
| 67 | + |
| 68 | + } |
46 | 69 |
|
47 | 70 |
|
48 | 71 | private int create(com.glaum.login.model.User user, RoleEnum roleEnum) { |
|
0 commit comments