Custom Authentication

Overview

The Apache Shiro framework is used in the inlong manager to realize the functions of authentication and authorization. The manager has integrated the default implementation logic. If you want to realize the custom Shiro based authentication and authorization function in the inlong manager, you can carry out the plug-in development of relevant functions according to the following instructions.

Dependency

  • Add Maven Dependency

    1. <dependency>
    2. <groupId>org.apache.inlong</groupId>
    3. <artifactId>manager-common</artifactId>
    4. <version>1.12.0</version>
    5. </dependency>

Code

  • Implement the following interfaces
  1. org.apache.inlong.manager.common.auth.InlongShiro
  2. public interface InlongShiro {
  3. WebSecurityManager getWebSecurityManager();
  4. AuthorizingRealm getShiroRealm();
  5. WebSessionManager getWebSessionManager();
  6. CredentialsMatcher getCredentialsMatcher();
  7. ShiroFilterFactoryBean getShiroFilter(SecurityManager securityManager);
  8. AuthorizationAttributeSourceAdvisor getAuthorizationAttributeSourceAdvisor(SecurityManager securityManager);
  9. }
  • Implement InlongShiro interface and specify the configuration in “@ conditionalonproperty”
  1. @ConditionalOnProperty(name = "type", prefix = "inlong.auth", havingValue = "Custom")
  2. @Component
  3. public class InlongShiroImpl implements InlongShiro {
  4. //todo
  5. }
  • Modify the application.properties under the manager web module
  1. inlong.auth.type=Custom