123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- /*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package org.apache.dolphinscheduler.api.security.impl.ldap;
- import org.apache.dolphinscheduler.common.enums.UserType;
- import java.util.Properties;
- import javax.naming.Context;
- import javax.naming.NamingEnumeration;
- import javax.naming.NamingException;
- import javax.naming.directory.Attribute;
- import javax.naming.directory.InitialDirContext;
- import javax.naming.directory.SearchControls;
- import javax.naming.directory.SearchResult;
- import javax.naming.ldap.InitialLdapContext;
- import javax.naming.ldap.LdapContext;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.context.annotation.Configuration;
- import org.springframework.stereotype.Component;
- @Component
- @Configuration
- public class LdapService {
- private static final Logger logger = LoggerFactory.getLogger(LdapService.class);
- @Value("${security.authentication.ldap.user.admin:null}")
- private String adminUserId;
- @Value("${ldap.urls:null}")
- private String ldapUrls;
- @Value("${ldap.base.dn:null}")
- private String ldapBaseDn;
- @Value("${ldap.username:null}")
- private String ldapSecurityPrincipal;
- @Value("${ldap.password:null}")
- private String ldapPrincipalPassword;
- @Value("${ldap.user.identity.attribute:null}")
- private String ldapUserIdentifyingAttribute;
- @Value("${ldap.user.email.attribute:null}")
- private String ldapEmailAttribute;
- /***
- * get user type by configured admin userId
- * @param userId login userId
- * @return user type
- */
- public UserType getUserType(String userId) {
- return adminUserId.equalsIgnoreCase(userId) ? UserType.ADMIN_USER : UserType.GENERAL_USER;
- }
- /**
- * login by userId and return user email
- *
- * @param userId user identity id
- * @param userPwd user login password
- * @return user email
- */
- public String ldapLogin(String userId, String userPwd) {
- Properties searchEnv = getManagerLdapEnv();
- try {
- //Connect to the LDAP server and Authenticate with a service user of whom we know the DN and credentials
- LdapContext ctx = new InitialLdapContext(searchEnv, null);
- SearchControls sc = new SearchControls();
- sc.setReturningAttributes(new String[]{ldapEmailAttribute});
- sc.setSearchScope(SearchControls.SUBTREE_SCOPE);
- String searchFilter = String.format("(%s=%s)", ldapUserIdentifyingAttribute, userId);
- //Search for the user you want to authenticate, search him with some attribute
- NamingEnumeration<SearchResult> results = ctx.search(ldapBaseDn, searchFilter, sc);
- if (results.hasMore()) {
- // get the users DN (distinguishedName) from the result
- SearchResult result = results.next();
- NamingEnumeration attrs = result.getAttributes().getAll();
- while (attrs.hasMore()) {
- //Open another connection to the LDAP server with the found DN and the password
- searchEnv.put(Context.SECURITY_PRINCIPAL, result.getNameInNamespace());
- searchEnv.put(Context.SECURITY_CREDENTIALS, userPwd);
- try {
- new InitialDirContext(searchEnv);
- } catch (Exception e) {
- logger.warn("invalid ldap credentials or ldap search error", e);
- return null;
- }
- Attribute attr = (Attribute) attrs.next();
- if (attr.getID().equals(ldapEmailAttribute)) {
- return (String) attr.get();
- }
- }
- }
- } catch (NamingException e) {
- logger.error("ldap search error", e);
- return null;
- }
- return null;
- }
- /***
- * get ldap env fot ldap server search
- * @return Properties
- */
- Properties getManagerLdapEnv() {
- Properties env = new Properties();
- env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");
- env.put(Context.SECURITY_AUTHENTICATION, "simple");
- env.put(Context.SECURITY_PRINCIPAL, ldapSecurityPrincipal);
- env.put(Context.SECURITY_CREDENTIALS, ldapPrincipalPassword);
- env.put(Context.PROVIDER_URL, ldapUrls);
- return env;
- }
- }
|