Initial commit

This commit is contained in:
Laurent
2025-12-08 13:47:02 +01:00
commit 390f290bbd
18 changed files with 664 additions and 0 deletions

View File

@@ -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);
}
}

View 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;
}
}

View File

@@ -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;
}

View File

@@ -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);
}
}

View File

@@ -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());
}
}

View File

@@ -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);
}
}

View 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

View File

@@ -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() {
}
}