1
22
23 package com.liferay.portal.servlet;
24
25 import com.liferay.portal.kernel.util.GetterUtil;
26 import com.liferay.portal.model.User;
27 import com.liferay.portal.security.auth.PrincipalThreadLocal;
28 import com.liferay.portal.security.permission.PermissionCheckerFactory;
29 import com.liferay.portal.security.permission.PermissionCheckerImpl;
30 import com.liferay.portal.security.permission.PermissionThreadLocal;
31 import com.liferay.portal.service.UserLocalServiceUtil;
32
33 import java.io.IOException;
34
35 import javax.servlet.ServletException;
36 import javax.servlet.http.HttpServletRequest;
37 import javax.servlet.http.HttpServletResponse;
38
39 import org.apache.commons.logging.Log;
40 import org.apache.commons.logging.LogFactory;
41
42
48 public class AxisServlet extends org.apache.axis.transport.http.AxisServlet {
49
50 public void service(HttpServletRequest req, HttpServletResponse res)
51 throws IOException, ServletException {
52
53 PermissionCheckerImpl permissionChecker = null;
54
55 try {
56 String remoteUser = req.getRemoteUser();
57
58 if (_log.isDebugEnabled()) {
59 _log.debug("Remote user " + remoteUser);
60 }
61
62 if (remoteUser != null) {
63 PrincipalThreadLocal.setName(remoteUser);
64
65 long userId = GetterUtil.getLong(remoteUser);
66
67 User user = UserLocalServiceUtil.getUserById(userId);
68
69 permissionChecker = PermissionCheckerFactory.create(user, true);
70
71 PermissionThreadLocal.setPermissionChecker(permissionChecker);
72 }
73
74 super.service(req, res);
75 }
76 catch (Exception e) {
77 _log.error(e, e);
78 }
79 finally {
80 try {
81 PermissionCheckerFactory.recycle(permissionChecker);
82 }
83 catch (Exception e) {
84 }
85 }
86 }
87
88 private static Log _log = LogFactory.getLog(AxisServlet.class);
89
90 }