/** * Copyright (c) 2000-present Liferay, Inc. All rights reserved. * * This library is free software; you can redistribute it and/or modify it under * the terms of the GNU Lesser General Public License as published by the Free * Software Foundation; either version 2.1 of the License, or (at your option) * any later version. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more * details. */ package com.liferay.portal.security.auto.login.request.header; import com.liferay.portal.kernel.log.Log; import com.liferay.portal.kernel.log.LogFactoryUtil; import com.liferay.portal.kernel.model.User; import com.liferay.portal.kernel.module.configuration.ConfigurationException; import com.liferay.portal.kernel.module.configuration.ConfigurationProvider; import com.liferay.portal.kernel.security.access.control.AccessControlUtil; import com.liferay.portal.kernel.security.auto.login.AutoLogin; import com.liferay.portal.kernel.security.auto.login.BaseAutoLogin; import com.liferay.portal.kernel.service.UserLocalService; import com.liferay.portal.kernel.servlet.HttpHeaders; import com.liferay.portal.kernel.settings.CompanyServiceSettingsLocator; import com.liferay.portal.kernel.util.Portal; import com.liferay.portal.kernel.util.StringPool; import com.liferay.portal.kernel.util.StringUtil; import com.liferay.portal.kernel.util.Validator; import com.liferay.portal.security.auto.login.internal.request.header.constants.RequestHeaderAutoLoginConstants; import com.liferay.portal.security.auto.login.request.header.module.configuration.RequestHeaderAutoLoginConfiguration; import com.liferay.portal.security.exportimport.UserImporter; import java.util.HashSet; import java.util.Set; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.osgi.service.component.annotations.Component; import org.osgi.service.component.annotations.Reference; /** * @author Brian Wing Shun Chan * @author Wesley Gong */ @Component( configurationPid = "com.liferay.portal.security.auto.login.request.header.module.configuration.RequestHeaderAutoLoginConfiguration", immediate = true, service = AutoLogin.class ) public class RequestHeaderAutoLogin extends BaseAutoLogin { @Override protected String[] doLogin( HttpServletRequest request, HttpServletResponse response) throws Exception { long companyId = _portal.getCompanyId(request); if (!isEnabled(companyId)) { return null; } String remoteAddr = request.getRemoteAddr(); if (isAccessAllowed(companyId, request)) { if (_log.isDebugEnabled()) { _log.debug("Access allowed for " + remoteAddr); } } else { if (_log.isWarnEnabled()) { _log.warn("Access denied for " + remoteAddr); } return null; } String screenName = request.getHeader(HttpHeaders.LIFERAY_SCREEN_NAME); if (Validator.isNull(screenName)) { return null; } User user = null; if (isLDAPImportEnabled(companyId)) { try { user = _userImporter.importUser( companyId, StringPool.BLANK, screenName); } catch (Exception e) { } } if (user == null) { user = _userLocalService.getUserByScreenName(companyId, screenName); } String[] credentials = new String[3]; credentials[0] = String.valueOf(user.getUserId()); credentials[1] = user.getPassword(); credentials[2] = Boolean.TRUE.toString(); return credentials; } protected boolean isAccessAllowed( long companyId, HttpServletRequest request) { RequestHeaderAutoLoginConfiguration requestHeaderAutoLoginConfiguration = _getRequestHeaderAutoLoginConfiguration(companyId); if (requestHeaderAutoLoginConfiguration == null) { return false; } String[] hostsAllowedArray = StringUtil.split( requestHeaderAutoLoginConfiguration.authHostsAllowed()); Set<String> hostsAllowed = new HashSet<>(); for (int i = 0; i < hostsAllowedArray.length; i++) { hostsAllowed.add(hostsAllowedArray[i]); } return AccessControlUtil.isAccessAllowed(request, hostsAllowed); } protected boolean isEnabled(long companyId) { RequestHeaderAutoLoginConfiguration requestHeaderAutoLoginConfiguration = _getRequestHeaderAutoLoginConfiguration(companyId); if (requestHeaderAutoLoginConfiguration == null) { return false; } return requestHeaderAutoLoginConfiguration.enabled(); } protected boolean isLDAPImportEnabled(long companyId) { RequestHeaderAutoLoginConfiguration requestHeaderAutoLoginConfiguration = _getRequestHeaderAutoLoginConfiguration(companyId); if (requestHeaderAutoLoginConfiguration == null) { return false; } return requestHeaderAutoLoginConfiguration.importFromLDAP(); } @Reference(unbind = "-") protected void setConfigurationProvider( ConfigurationProvider configurationProvider) { _configurationProvider = configurationProvider; } @Reference(unbind = "-") protected void setUserImporter(UserImporter userImporter) { _userImporter = userImporter; } @Reference(unbind = "-") protected void setUserLocalService(UserLocalService userLocalService) { _userLocalService = userLocalService; } private RequestHeaderAutoLoginConfiguration _getRequestHeaderAutoLoginConfiguration(long companyId) { try { RequestHeaderAutoLoginConfiguration requestHeaderAutoLoginConfiguration = _configurationProvider.getConfiguration( RequestHeaderAutoLoginConfiguration.class, new CompanyServiceSettingsLocator( companyId, RequestHeaderAutoLoginConstants.SERVICE_NAME)); return requestHeaderAutoLoginConfiguration; } catch (ConfigurationException ce) { _log.error( "Unable to get request header auto login configuration", ce); } return null; } private static final Log _log = LogFactoryUtil.getLog( RequestHeaderAutoLogin.class); private ConfigurationProvider _configurationProvider; @Reference private Portal _portal; private UserImporter _userImporter; private UserLocalService _userLocalService; }