123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- /*
- * Copyright [2022] [MaxKey of copyright http://www.maxkey.top]
- *
- * Licensed 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.maxkey;
- import java.util.List;
- import org.maxkey.authn.AbstractAuthenticationProvider;
- import org.maxkey.authn.support.jwt.HttpJwtEntryPoint;
- import org.maxkey.authn.support.jwt.JwtLoginService;
- import org.maxkey.authn.web.CurrentUserMethodArgumentResolver;
- import org.maxkey.authn.web.interceptor.PermissionInterceptor;
- import org.maxkey.configuration.ApplicationConfig;
- import org.maxkey.web.interceptor.HistoryLogsAdapter;
- import org.maxkey.web.interceptor.RestApiPermissionAdapter;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.context.annotation.Bean;
- import org.springframework.context.annotation.Configuration;
- import org.springframework.web.servlet.config.annotation.EnableWebMvc;
- import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
- import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
- import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
- import org.springframework.web.method.support.HandlerMethodArgumentResolver;
- @Configuration
- @EnableWebMvc
- public class MaxKeyMgtMvcConfig implements WebMvcConfigurer {
- private static final Logger _logger = LoggerFactory.getLogger(MaxKeyMgtMvcConfig.class);
-
- @Autowired
- ApplicationConfig applicationConfig;
-
- @Autowired
- AbstractAuthenticationProvider authenticationProvider ;
-
- @Autowired
- JwtLoginService jwtLoginService;
-
- @Autowired
- PermissionInterceptor permissionInterceptor;
-
- @Autowired
- HistoryLogsAdapter historyLogsAdapter;
-
- @Autowired
- RestApiPermissionAdapter restApiPermissionAdapter;
-
- @Override
- public void addResourceHandlers(ResourceHandlerRegistry registry) {
- _logger.debug("addResourceHandlers");
-
- _logger.debug("add statics");
- registry.addResourceHandler("/static/**")
- .addResourceLocations("classpath:/static/");
- _logger.debug("add templates");
- registry.addResourceHandler("/templates/**")
- .addResourceLocations("classpath:/templates/");
-
- _logger.debug("add swagger");
- registry.addResourceHandler("swagger-ui.html")
- .addResourceLocations("classpath:/META-INF/resources/");
- registry.addResourceHandler("/webjars/**")
- .addResourceLocations("classpath:/META-INF/resources/webjars/");
-
- _logger.debug("add knife4j");
- registry.addResourceHandler("doc.html").addResourceLocations("classpath:/META-INF/resources/");
- registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
- _logger.debug("addResourceHandler finished .");
- }
- @Override
- public void addInterceptors(InterceptorRegistry registry) {
- //addPathPatterns 用于添加拦截规则 , 先把所有路径都加入拦截, 再一个个排除
- //excludePathPatterns 表示改路径不用拦截
- _logger.debug("add HttpJwtEntryPoint");
- registry.addInterceptor(new HttpJwtEntryPoint(
- authenticationProvider,jwtLoginService,applicationConfig,true))
- .addPathPatterns("/login");
-
- permissionInterceptor.setMgmt(true);
-
- registry.addInterceptor(permissionInterceptor)
- .addPathPatterns("/dashboard/**")
- .addPathPatterns("/orgs/**")
- .addPathPatterns("/users/**")
- .addPathPatterns("/apps/**")
- .addPathPatterns("/accounts/**")
-
-
- .addPathPatterns("/access/**")
- .addPathPatterns("/access/**/**")
-
- .addPathPatterns("/permissions/**")
- .addPathPatterns("/permissions/**/**")
-
- .addPathPatterns("/config/**")
- .addPathPatterns("/config/**/**")
-
- .addPathPatterns("/historys/**")
- .addPathPatterns("/historys/**/**")
-
- .addPathPatterns("/institutions/**")
- .addPathPatterns("/localization/**")
-
- .addPathPatterns("/file/upload/")
-
- ;
-
- _logger.debug("add PermissionAdapter");
-
- registry.addInterceptor(historyLogsAdapter)
- .addPathPatterns("/userinfo/**")
- .addPathPatterns("/enterprises/**")
- .addPathPatterns("/employees/**")
- .addPathPatterns("/authInfo/**")
- .addPathPatterns("/usercenter/**")
- .addPathPatterns("/retrievePassword/**")
- .addPathPatterns("/roles/**")
- .addPathPatterns("/apps/**")
- .addPathPatterns("/approles/**")
- ;
- _logger.debug("add HistoryLogsAdapter");
-
- /*
- * api
- * idm
- * scim
- * */
- registry.addInterceptor(restApiPermissionAdapter)
- .addPathPatterns("/api/**")
- .addPathPatterns("/api/idm/**")
- .addPathPatterns("/api/idm/scim/**")
- ;
-
- _logger.debug("add RestApiPermissionAdapter");
-
- }
-
- @Override
- public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) {
- argumentResolvers.add(currentUserMethodArgumentResolver());
- }
-
- @Bean
- public CurrentUserMethodArgumentResolver currentUserMethodArgumentResolver() {
- return new CurrentUserMethodArgumentResolver();
- }
- }
|