Initial commit
This commit is contained in:
@@ -0,0 +1,13 @@
|
||||
package be.naaturel.boardmateapi;
|
||||
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||
|
||||
@SpringBootApplication
|
||||
public class BoardmateApiApplication {
|
||||
|
||||
public static void main(String[] args) {
|
||||
SpringApplication.run(BoardmateApiApplication.class, args);
|
||||
}
|
||||
|
||||
}
|
||||
14
api/src/main/java/be/naaturel/boardmateapi/Interceptor.java
Normal file
14
api/src/main/java/be/naaturel/boardmateapi/Interceptor.java
Normal file
@@ -0,0 +1,14 @@
|
||||
package be.naaturel.boardmateapi;
|
||||
|
||||
import jakarta.servlet.http.HttpServletRequest;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import org.springframework.web.servlet.HandlerInterceptor;
|
||||
|
||||
public class Interceptor implements HandlerInterceptor {
|
||||
|
||||
@Override
|
||||
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
|
||||
System.out.println("Received : " + request.getRequestURI());
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,18 @@
|
||||
package be.naaturel.boardmateapi.configurations;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Value;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Component
|
||||
public class AppConfigurations {
|
||||
|
||||
@Value("${sec.cors.authorizedHots}")
|
||||
public String[] authorizedHosts;
|
||||
|
||||
@Value("${sec.cors.authorizedMethods}")
|
||||
public String[] authorizedMethods;
|
||||
|
||||
@Value("${sec.cors.authorizedHeader}")
|
||||
public String[] authorizedHeaders;
|
||||
|
||||
}
|
||||
@@ -0,0 +1,50 @@
|
||||
package be.naaturel.boardmateapi.configurations;
|
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.context.annotation.Bean;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
|
||||
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
|
||||
import org.springframework.security.config.annotation.web.configurers.AbstractHttpConfigurer;
|
||||
import org.springframework.security.config.annotation.web.configurers.LogoutConfigurer;
|
||||
import org.springframework.security.web.SecurityFilterChain;
|
||||
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||
import org.springframework.web.cors.CorsConfiguration;
|
||||
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
|
||||
import org.springframework.web.filter.CorsFilter;
|
||||
|
||||
import java.util.Arrays;
|
||||
|
||||
@Configuration
|
||||
@EnableWebSecurity
|
||||
@EnableTransactionManagement
|
||||
public class AppSecurity {
|
||||
|
||||
private final AppConfigurations conf;
|
||||
|
||||
@Autowired
|
||||
public AppSecurity(AppConfigurations appConf) {
|
||||
this.conf = appConf;
|
||||
}
|
||||
|
||||
@Bean
|
||||
public SecurityFilterChain filterChain(HttpSecurity http) {
|
||||
|
||||
return http
|
||||
.csrf(AbstractHttpConfigurer::disable)
|
||||
.build();
|
||||
}
|
||||
|
||||
@Bean
|
||||
public CorsFilter corsFilter() {
|
||||
|
||||
CorsConfiguration config = new CorsConfiguration();
|
||||
config.setAllowedOrigins(Arrays.asList(conf.authorizedHosts));
|
||||
config.setAllowedMethods(Arrays.asList(conf.authorizedMethods));
|
||||
config.setAllowedHeaders(Arrays.asList(conf.authorizedHeaders));
|
||||
|
||||
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
|
||||
source.registerCorsConfiguration("/**", config);
|
||||
return new CorsFilter(source);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,15 @@
|
||||
package be.naaturel.boardmateapi.configurations;
|
||||
|
||||
import be.naaturel.boardmateapi.Interceptor;
|
||||
import org.springframework.context.annotation.Configuration;
|
||||
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
|
||||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
|
||||
|
||||
@Configuration
|
||||
public class HttpRequests implements WebMvcConfigurer {
|
||||
|
||||
@Override
|
||||
public void addInterceptors(InterceptorRegistry registry) {
|
||||
registry.addInterceptor(new Interceptor());
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,20 @@
|
||||
package be.naaturel.boardmateapi.controllers;
|
||||
|
||||
import org.springframework.http.HttpStatus;
|
||||
import org.springframework.http.ResponseEntity;
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
@RestController
|
||||
public class SampleController {
|
||||
|
||||
public SampleController(){
|
||||
|
||||
}
|
||||
|
||||
@GetMapping({"/"})
|
||||
public ResponseEntity<String> example(){
|
||||
return new ResponseEntity<>("Hello World", HttpStatus.OK);
|
||||
}
|
||||
|
||||
}
|
||||
14
api/src/main/resources/application.properties
Normal file
14
api/src/main/resources/application.properties
Normal file
@@ -0,0 +1,14 @@
|
||||
#=============MAIN=============
|
||||
spring.application.name=boardmate-api
|
||||
|
||||
#=============SERVER=============
|
||||
server.port=8000
|
||||
|
||||
#=============SECURITY=============
|
||||
sec.cors.authorizedHots=*
|
||||
sec.cors.authorizedMethods=GET,POST,PUT,DELETE,OPTION
|
||||
sec.cors.authorizedHeader=Authorization,Content-type
|
||||
|
||||
#=============METRICS=============
|
||||
management.endpoints.web.exposure.include=*
|
||||
management.endpoint.prometheus.enabled=true
|
||||
@@ -0,0 +1,13 @@
|
||||
package be.naaturel.boardmateapi;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.boot.test.context.SpringBootTest;
|
||||
|
||||
@SpringBootTest
|
||||
class BoardmateApiApplicationTests {
|
||||
|
||||
@Test
|
||||
void contextLoads() {
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user