summaryrefslogtreecommitdiffstats
path: root/authz-gui/src/main/java/com/att/authz/gui/pages/RolesShow.java
blob: 8b264dfed8d74e068293456566d2d1aa39d607f9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*******************************************************************************
 * Copyright (c) 2016 AT&T Intellectual Property. All rights reserved.
 *******************************************************************************/
package com.att.authz.gui.pages;

import java.io.IOException;
import java.net.ConnectException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;

import com.att.authz.env.AuthzTrans;
import com.att.authz.gui.AuthGUI;
import com.att.authz.gui.BreadCrumbs;
import com.att.authz.gui.Page;
import com.att.authz.gui.Table;
import com.att.authz.gui.Table.Cells;
import com.att.authz.gui.table.AbsCell;
import com.att.authz.gui.table.RefCell;
import com.att.authz.gui.table.TextCell;
import org.onap.aaf.cadi.CadiException;
import org.onap.aaf.cadi.client.Future;
import org.onap.aaf.cadi.client.Rcli;
import org.onap.aaf.cadi.client.Retryable;
import org.onap.aaf.inno.env.APIException;
import org.onap.aaf.inno.env.Env;
import org.onap.aaf.inno.env.TimeTaken;
import org.onap.aaf.inno.env.util.Chrono;

import aaf.v2_0.UserRole;
import aaf.v2_0.UserRoles;


/**
 * Page content for My Roles
 * 
 *
 */
public class RolesShow extends Page {
	public static final String HREF = "/gui/myroles";
	private static final String DATE_TIME_FORMAT = "yyyy-MM-dd";
	private static SimpleDateFormat expiresDF;
	
	static {
		expiresDF = new SimpleDateFormat(DATE_TIME_FORMAT);
	}
	
	public RolesShow(final AuthGUI gui, final Page ... breadcrumbs) throws APIException, IOException {
		super(gui.env, "MyRoles",HREF, NO_FIELDS,
			new BreadCrumbs(breadcrumbs), 
			new Table<AuthGUI,AuthzTrans>("Roles",gui.env.newTransNoAvg(),new Model(), "class=std"));
	}

	/**
	 * Implement the Table Content for Permissions by User
	 * 
	 *
	 */
	private static class Model implements Table.Data<AuthGUI,AuthzTrans> {
		private static final String[] headers = new String[] {"Role","Expires","Remediation","Actions"};

		@Override
		public String[] headers() {
			return headers;
		}
		
		@Override
		public Cells get(final AuthGUI gui, final AuthzTrans trans) {
			Cells rv = Cells.EMPTY;

			try {
				rv = gui.clientAsUser(trans.getUserPrincipal(), new Retryable<Cells>() {
					@Override
					public Cells code(Rcli<?> client) throws CadiException, ConnectException, APIException {
						ArrayList<AbsCell[]> rv = new ArrayList<AbsCell[]>();
						TimeTaken tt = trans.start("AAF Roles by User",Env.REMOTE);
						try {
							Future<UserRoles> fur = client.read("/authz/userRoles/user/"+trans.user(),gui.userrolesDF);
							if (fur.get(5000)) {
								if(fur.value != null) for (UserRole u : fur.value.getUserRole()) {
									if(u.getExpires().compare(Chrono.timeStamp()) < 0) {
										AbsCell[] sa = new AbsCell[] {
												new TextCell(u.getRole() + "*", "class=expired"),
												new TextCell(expiresDF.format(u.getExpires().toGregorianCalendar().getTime()),"class=expired"),
												new RefCell("Extend",
														UserRoleExtend.HREF + "?user="+trans.user()+"&role="+u.getRole(), 
														new String[]{"class=expired"}),
												new RefCell("Remove",
													UserRoleRemove.HREF + "?user="+trans.user()+"&role="+u.getRole(), 
													new String[]{"class=expired"})
														
											};
											rv.add(sa);
									} else {
										AbsCell[] sa = new AbsCell[] {
												new RefCell(u.getRole(),
														RoleDetail.HREF+"?role="+u.getRole()),
												new TextCell(expiresDF.format(u.getExpires().toGregorianCalendar().getTime())),
												AbsCell.Null,
												new RefCell("Remove",
														UserRoleRemove.HREF + "?user="+trans.user()+"&role="+u.getRole())
											};
											rv.add(sa);
									}
								}
							}
							
						} finally {
							tt.done();
						}
						return new Cells(rv,null);
					}
				});
			} catch (Exception e) {
				trans.error().log(e);
			}
			return rv;
		}
	}
}