Update for more Logging Info
[aaf/authz.git] / auth / auth-core / src / main / java / org / onap / aaf / auth / env / AuthzTransImpl.java
1 /**
2  * ============LICENSE_START====================================================
3  * org.onap.aaf
4  * ===========================================================================
5  * Copyright (c) 2018 AT&T Intellectual Property. All rights reserved.
6  * ===========================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END====================================================
19  *
20  */
21
22 package org.onap.aaf.auth.env;
23
24 import java.util.Date;
25
26 import javax.servlet.http.HttpServletRequest;
27
28 import org.onap.aaf.auth.org.Organization;
29 import org.onap.aaf.auth.org.OrganizationFactory;
30 import org.onap.aaf.cadi.Lur;
31 import org.onap.aaf.cadi.Permission;
32 import org.onap.aaf.cadi.principal.TaggedPrincipal;
33 import org.onap.aaf.misc.env.LogTarget;
34 import org.onap.aaf.misc.env.impl.BasicTrans;
35
36 public class AuthzTransImpl extends BasicTrans implements AuthzTrans {
37         private static final String N_A = "n/a";
38         private static final String BLANK = "";
39         private HttpServletRequest hreq;
40     private TaggedPrincipal user;
41     private Lur lur;
42     private Organization org;
43     private int mask;
44     private Date now;
45     private String tag;
46     public AuthzTransImpl(AuthzEnv env) {
47         super(env);
48         org=null;
49         mask=0;
50         tag=null;
51     }
52
53     /**
54      * @see org.onap.aaf.auth.env.test.AuthTrans#set(javax.servlet.http.HttpServletRequest)
55      */
56     @Override
57     public AuthzTrans set(HttpServletRequest req) {
58         hreq = req;
59         user = (TaggedPrincipal)req.getUserPrincipal();
60         
61         for (REQD_TYPE rt : REQD_TYPE.values()) {
62             requested(rt,req);
63         }
64         // Handle alternate "request" for "future"
65         String request = req.getParameter("request");
66         if (request!=null) {
67             requested(REQD_TYPE.future,(request.length()==0 || "true".equalsIgnoreCase(request)));
68         }
69
70         org=null;
71         return this;
72     }
73     @Override
74     public HttpServletRequest hreq() {
75         return hreq;
76     }
77     
78     @Override
79     public void setUser(TaggedPrincipal p) {
80         user = p;
81     }
82
83     /**
84      * @see org.onap.aaf.auth.env.test.AuthTrans#user()
85      */
86     @Override
87     public String user() {
88         return user==null?N_A:user.getName();
89     }
90     
91     /**
92      * @see org.onap.aaf.auth.env.test.AuthTrans#getUserPrincipal()
93      */
94     @Override
95     public TaggedPrincipal getUserPrincipal() {
96         return user;
97     }
98
99     /**
100      * @see org.onap.aaf.auth.env.test.AuthTrans#ip()
101      */
102     @Override
103     public String ip() {
104         return hreq==null?N_A:hreq.getRemoteAddr();
105     }
106
107     /**
108      * @see org.onap.aaf.auth.env.test.AuthTrans#port()
109      */
110     @Override
111     public int port() {
112         return hreq==null?0:hreq.getRemotePort();
113     }
114
115
116     /* (non-Javadoc)
117      * @see org.onap.aaf.auth.env.test.AuthzTrans#meth()
118      */
119     @Override
120     public String meth() {
121         return hreq==null?"":hreq.getMethod();
122     }
123
124     /* (non-Javadoc)
125      * @see org.onap.aaf.auth.env.test.AuthzTrans#path()
126      */
127     @Override
128     public String path() {
129         return hreq==null?"":hreq.getPathInfo();
130     }
131
132     /**
133      * @see org.onap.aaf.auth.env.test.AuthTrans#agent()
134      */
135     @Override
136     public String agent() {
137         return hreq==null?BLANK:hreq.getHeader("User-Agent");
138     }
139
140     @Override
141     public AuthzEnv env() {
142         return (AuthzEnv)delegate;
143     }
144     
145     @Override
146     public boolean requested(REQD_TYPE requested) {
147         return (mask&requested.bit)==requested.bit;
148     }
149     
150     public void requested(REQD_TYPE requested, boolean b) {
151         if (b) {
152             mask|=requested.bit;
153         } else {
154             mask&=~requested.bit;
155         }
156     }
157     
158     private void requested(REQD_TYPE reqtype, HttpServletRequest req) {
159         String p = req.getParameter(reqtype.name());
160         if (p!=null) {
161             requested(reqtype,p.length()==0 || "true".equalsIgnoreCase(p));
162         }
163     }
164
165     @Override
166     public void setLur(Lur lur) {
167         this.lur = lur;
168     }
169     
170     @Override
171     public boolean fish(Permission ... pond) {
172         if (lur!=null) {
173             return lur.fish(user, pond);
174         }
175         return false;
176     }
177
178     /* (non-Javadoc)
179      * @see org.onap.aaf.auth.env.test.AuthzTrans#org()
180      */
181     @Override
182     public Organization org() {
183         if (org==null) {
184             try {
185                 if ((org = OrganizationFactory.obtain(env(), user()))==null) {
186                     org = Organization.NULL;
187                 }
188             } catch (Exception e) {
189                 
190                 org = Organization.NULL;
191             }
192         } 
193         return org;
194     }
195
196     /* (non-Javadoc)
197      * @see org.onap.aaf.auth.env.test.AuthzTrans#logAuditTrailOnly(com.att.inno.env.LogTarget)
198      */
199     @Override
200     public void logAuditTrail(LogTarget lt) {
201         if (lt.isLoggable()) {
202             StringBuilder sb = new StringBuilder();
203             auditTrail(1, sb);
204             lt.log(sb);
205         }
206     }
207
208     /* (non-Javadoc)
209      * @see org.onap.aaf.auth.env.test.AuthzTrans#now()
210      */
211     @Override
212     public Date now() {
213         if (now==null) {
214             now = new Date();
215         }
216         return now;
217     }
218     
219     /*
220      * (non-Javadoc)
221      * @see org.onap.aaf.auth.env.AuthzTrans#setTag(java.lang.String)
222      */
223     @Override
224     public void setTag(String tag) {
225         this.tag = tag;
226     }
227
228     @Override
229     public String getTag() {
230         return tag;
231     }
232 }