LdapAuthenticator.java 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. package org.apache.dolphinscheduler.api.security.impl.ldap;
  18. import org.apache.dolphinscheduler.api.security.impl.AbstractAuthenticator;
  19. import org.apache.dolphinscheduler.api.service.UsersService;
  20. import org.apache.dolphinscheduler.dao.entity.User;
  21. import org.springframework.beans.factory.annotation.Autowired;
  22. public class LdapAuthenticator extends AbstractAuthenticator {
  23. @Autowired
  24. private UsersService usersService;
  25. @Autowired
  26. LdapService ldapService;
  27. @Override
  28. public User login(String userId, String password, String extra) {
  29. User user = null;
  30. String ldapEmail = ldapService.ldapLogin(userId, password);
  31. if (ldapEmail != null) {
  32. //check if user exist
  33. user = usersService.getUserByUserName(userId);
  34. if (user == null) {
  35. user = usersService.createUser(ldapService.getUserType(userId), userId, ldapEmail);
  36. }
  37. }
  38. return user;
  39. }
  40. }