MaxKeyConfig.java 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. package org.maxkey;
  2. import org.apache.catalina.Context;
  3. import org.apache.catalina.connector.Connector;
  4. import org.apache.tomcat.util.descriptor.web.SecurityCollection;
  5. import org.apache.tomcat.util.descriptor.web.SecurityConstraint;
  6. import org.maxkey.authz.oauth2.provider.endpoint.TokenEndpointAuthenticationFilter;
  7. import org.maxkey.crypto.password.opt.algorithm.KeyUriFormat;
  8. import org.mybatis.spring.annotation.MapperScan;
  9. import org.slf4j.Logger;
  10. import org.slf4j.LoggerFactory;
  11. import org.springframework.beans.factory.annotation.Value;
  12. import org.springframework.boot.web.embedded.tomcat.TomcatServletWebServerFactory;
  13. import org.springframework.boot.web.servlet.FilterRegistrationBean;
  14. import org.springframework.context.annotation.Bean;
  15. import org.springframework.context.annotation.Configuration;
  16. import org.springframework.context.annotation.ImportResource;
  17. import org.springframework.context.annotation.PropertySource;
  18. @Configuration
  19. @ImportResource(locations = { "classpath:spring/maxkey.xml" })
  20. @PropertySource("classpath:/application.properties")
  21. @PropertySource("classpath:/config/applicationConfig.properties")
  22. @MapperScan("org.maxkey.dao.persistence,")
  23. public class MaxKeyConfig {
  24. private static final Logger _logger = LoggerFactory.getLogger(MaxKeyConfig.class);
  25. @Value("${server.port:8080}")
  26. private int port;
  27. public int getPort() {
  28. return port;
  29. }
  30. @Bean
  31. public FilterRegistrationBean<TokenEndpointAuthenticationFilter> TokenEndpointAuthenticationFilter() {
  32. _logger.debug("TokenEndpointAuthenticationFilter init ");
  33. FilterRegistrationBean<TokenEndpointAuthenticationFilter> registration = new FilterRegistrationBean<TokenEndpointAuthenticationFilter>();
  34. registration.setFilter(new TokenEndpointAuthenticationFilter());
  35. registration.addUrlPatterns("/oauth/v20/token/*");
  36. registration.setName("TokenEndpointAuthenticationFilter");
  37. registration.setOrder(1);
  38. return registration;
  39. }
  40. @Bean
  41. public Connector connector() {
  42. Connector connector = new Connector("org.apache.coyote.http11.Http11NioProtocol");
  43. connector.setScheme("http");
  44. connector.setPort(80);
  45. connector.setSecure(false);
  46. connector.setRedirectPort(443);
  47. return connector;
  48. }
  49. @Bean
  50. public TomcatServletWebServerFactory tomcatServletWebServerFactory(Connector connector) {
  51. TomcatServletWebServerFactory tomcat = new TomcatServletWebServerFactory() {
  52. @Override
  53. protected void postProcessContext(Context context) {
  54. SecurityConstraint securityConstraint = new SecurityConstraint();
  55. securityConstraint.setUserConstraint("CONFIDENTIAL");
  56. SecurityCollection collection = new SecurityCollection();
  57. collection.addPattern("/*");
  58. securityConstraint.addCollection(collection);
  59. context.addConstraint(securityConstraint);
  60. }
  61. };
  62. tomcat.addAdditionalTomcatConnectors(connector);
  63. return tomcat;
  64. }
  65. @Bean(name = "keyUriFormat")
  66. public KeyUriFormat keyUriFormat(
  67. @Value("${config.otp.keyuri.format.type:totp}")
  68. String keyuriFormatType,
  69. @Value("${config.otp.keyuri.format.domain:MaxKey.top}")
  70. String keyuriFormatDomain,
  71. @Value("${config.otp.keyuri.format.issuer:MaxKey}")
  72. String keyuriFormatIssuer,
  73. @Value("${config.otp.keyuri.format.digits:6}")
  74. int keyuriFormatDigits,
  75. @Value("${config.otp.keyuri.format.period:30}")
  76. int keyuriFormatPeriod) {
  77. KeyUriFormat keyUriFormat=new KeyUriFormat();
  78. keyUriFormat.setType(keyuriFormatType);
  79. keyUriFormat.setDomain(keyuriFormatDomain);
  80. keyUriFormat.setIssuer(keyuriFormatIssuer);
  81. keyUriFormat.setDigits(keyuriFormatDigits);
  82. keyUriFormat.setPeriod(keyuriFormatPeriod);
  83. _logger.debug("KeyUri Format " + keyUriFormat);
  84. return keyUriFormat;
  85. }
  86. }