Compare commits
	
		
			58 Commits
		
	
	
		
			back-postg
			...
			84b70f8f38
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					84b70f8f38 | ||
| 
						 | 
					834d68949c | ||
| 
						 | 
					fea8687664 | ||
| 
						 | 
					c94d3654ce | ||
| 
						 | 
					d5c89bf8f4 | ||
| 
						 | 
					78c72bdd72 | ||
| 
						 | 
					307c7e700b | ||
| 
						 | 
					8d486dce89 | ||
| 
						 | 
					653f923693 | ||
| 
						 | 
					64da3c9ab0 | ||
| 
						 | 
					419ceec1bc | ||
| 
						 | 
					e011a5534e | ||
| 
						 | 
					ef964c4d35 | ||
| 
						 | 
					5608b12f84 | ||
| 
						 | 
					467babab79 | ||
| 
						 | 
					a2e2395cc2 | ||
| 
						 | 
					e3393c8834 | ||
| 
						 | 
					5f8fe4a374 | ||
| 
						 | 
					c5e7736a16 | ||
| 
						 | 
					04589392cb | ||
| 
						 | 
					1106cf8478 | ||
| 
						 | 
					215d80ad70 | ||
| 
						 | 
					dded62c25a | ||
| 
						 | 
					3de7ebe2b1 | ||
| 
						 | 
					8153496a0f | ||
| 
						 | 
					861e7495a7 | ||
| 
						 | 
					d78e43f7e0 | ||
| 
						 | 
					3ca97cf378 | ||
| 
						 | 
					e6a8d98d63 | ||
| 
						 | 
					8894fea6d4 | ||
| 
						 | 
					236bb0d167 | ||
| 
						 | 
					d4dcc95d9b | ||
| 
						 | 
					dc843299eb | ||
| 
						 | 
					f3eaf8fe34 | ||
| 
						 | 
					628c61fb8b | ||
| 
						 | 
					4880f3829c | ||
| 
						 | 
					80b2d087e4 | ||
| 
						 | 
					b5c03798fc | ||
| 
						 | 
					1d970ce5f5 | ||
| 
						 | 
					f9de5ed6bf | ||
| 
						 | 
					e75a5c9d2c | ||
| 
						 | 
					5c3b2b138d | ||
| 
						 | 
					8d4dc7916d | ||
| 
						 | 
					1a6db7c953 | ||
| 
						 | 
					3890aed158 | ||
| 
						 | 
					dd5ca2cbd7 | ||
| 
						 | 
					024deeba41 | ||
| 
						 | 
					1cebebf1a5 | ||
| 
						 | 
					d8bc7cc9b6 | ||
| 
						 | 
					e66fa33577 | ||
| 
						 | 
					27e70ee109 | ||
| 
						 | 
					153501c8d4 | ||
| 
						 | 
					40afde89b7 | ||
| 
						 | 
					4698aa549f | ||
| 
						 | 
					04a73073c1 | ||
| 
						 | 
					11ab5e1dc4 | ||
| 
						 | 
					3cb12dab4f | ||
| 
						 | 
					0a9d83655f | 
@@ -15,4 +15,4 @@ jobs:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      - uses: axel-op/googlejavaformat-action@v3
 | 
					      - uses: axel-op/googlejavaformat-action@v3
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          args: "--set-exit-if-changed --skip-sorting-imports --aosp -n"
 | 
					          args: "--set-exit-if-changed --skip-sorting-imports --skip-reflowing-long-strings --aosp -n"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										33
									
								
								.gitea/workflows/build-back.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								.gitea/workflows/build-back.yaml
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,33 @@
 | 
				
			|||||||
 | 
					name: Build
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					on:
 | 
				
			||||||
 | 
					  push:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					jobs:
 | 
				
			||||||
 | 
					  build:
 | 
				
			||||||
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
 | 
					    steps:
 | 
				
			||||||
 | 
					    - name: Checkout sources
 | 
				
			||||||
 | 
					      uses: actions/checkout@v4
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    - name: Load .env file
 | 
				
			||||||
 | 
					      uses: xom9ikk/dotenv@v2.3.0
 | 
				
			||||||
 | 
					      with:
 | 
				
			||||||
 | 
					        path: ./config/
 | 
				
			||||||
 | 
					        mode: dev
 | 
				
			||||||
 | 
					        load-mode: strict
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    - name: Setup Java
 | 
				
			||||||
 | 
					      uses: actions/setup-java@v4
 | 
				
			||||||
 | 
					      with:
 | 
				
			||||||
 | 
					        distribution: 'temurin'
 | 
				
			||||||
 | 
					        java-version: 21
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    - name: Setup Gradle
 | 
				
			||||||
 | 
					      uses: gradle/actions/setup-gradle@v4
 | 
				
			||||||
 | 
					      with:
 | 
				
			||||||
 | 
					        cache-disabled: true # Once the code has been pushed once in main, this should be reenabled. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    - name: init gradle
 | 
				
			||||||
 | 
					      working-directory: ./MyINPulse-back/
 | 
				
			||||||
 | 
					      run: ./gradlew build # todo: run test, currently fail because no database is present 
 | 
				
			||||||
@@ -1,33 +1,59 @@
 | 
				
			|||||||
plugins {
 | 
					plugins {
 | 
				
			||||||
	id 'java'
 | 
					    id 'java'
 | 
				
			||||||
	id 'org.springframework.boot' version '3.4.2'
 | 
					    id 'org.springframework.boot' version '3.4.2'
 | 
				
			||||||
	id 'io.spring.dependency-management' version '1.1.7'
 | 
					    id 'io.spring.dependency-management' version '1.1.7'
 | 
				
			||||||
 | 
					    id 'jacoco'
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
group = 'enseirb'
 | 
					group = 'enseirb'
 | 
				
			||||||
version = '0.0.1-SNAPSHOT'
 | 
					version = '0.0.1-SNAPSHOT'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
java {
 | 
					java {
 | 
				
			||||||
	toolchain {
 | 
					    toolchain {
 | 
				
			||||||
		languageVersion = JavaLanguageVersion.of(21)
 | 
					        languageVersion = JavaLanguageVersion.of(21)
 | 
				
			||||||
	}
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
repositories {
 | 
					repositories {
 | 
				
			||||||
	mavenCentral()
 | 
					    mavenCentral()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
dependencies {
 | 
					dependencies {
 | 
				
			||||||
	implementation 'org.springframework.boot:spring-boot-starter-oauth2-resource-server'
 | 
					    implementation 'org.springframework.boot:spring-boot-starter-oauth2-resource-server'
 | 
				
			||||||
	implementation 'org.springframework.boot:spring-boot-starter-web'
 | 
					    implementation 'org.springframework.boot:spring-boot-starter-web'
 | 
				
			||||||
	implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
 | 
					    implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
 | 
				
			||||||
	implementation 'org.springframework.boot:spring-boot-starter-validation'
 | 
					    implementation 'org.springframework.boot:spring-boot-starter-validation'
 | 
				
			||||||
	implementation 'org.springframework.boot:spring-boot-starter-data-rest'
 | 
					    implementation 'org.springframework.boot:spring-boot-starter-data-rest'
 | 
				
			||||||
	implementation 'org.postgresql:postgresql'
 | 
					    implementation group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.+'
 | 
				
			||||||
	testImplementation 'org.springframework.boot:spring-boot-starter-test'
 | 
					    implementation group: 'org.apache.logging.log4j', name: 'log4j-core', version: '2.+'
 | 
				
			||||||
	testRuntimeOnly 'org.junit.platform:junit-platform-launcher'
 | 
					    implementation 'org.postgresql:postgresql'
 | 
				
			||||||
 | 
					    implementation group: 'com.itextpdf', name: 'itextpdf', version: '5.5.13.3'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    testImplementation 'org.springframework.boot:spring-boot-starter-test'
 | 
				
			||||||
 | 
					    testImplementation 'com.h2database:h2'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    testRuntimeOnly 'org.junit.platform:junit-platform-launcher'
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
tasks.named('test') {
 | 
					tasks.named('test') {
 | 
				
			||||||
	useJUnitPlatform()
 | 
					    useJUnitPlatform()
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					test {
 | 
				
			||||||
 | 
					    finalizedBy jacocoTestReport // report is always generated after tests run
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					jacocoTestReport {
 | 
				
			||||||
 | 
					    dependsOn test // tests are required to run before generating the report
 | 
				
			||||||
 | 
					    reports {
 | 
				
			||||||
 | 
					        xml.required = false
 | 
				
			||||||
 | 
					        csv.required = false
 | 
				
			||||||
 | 
					        html.outputLocation = layout.buildDirectory.dir('jacocoHtml')
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					jacoco {
 | 
				
			||||||
 | 
					    toolVersion = "0.8.12"
 | 
				
			||||||
 | 
					    reportsDirectory = layout.buildDirectory.dir('customJacocoReportDir')
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,40 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.api;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.boot.autoconfigure.SpringBootApplication;
 | 
					 | 
				
			||||||
import org.springframework.security.core.context.SecurityContextHolder;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.GetMapping;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.RestController;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.security.Principal;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import javax.management.relation.RoleNotFoundException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@SpringBootApplication
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class GetUserInfo {
 | 
					 | 
				
			||||||
    // TODO: understand how to get data
 | 
					 | 
				
			||||||
    @GetMapping("/getUserInfo")
 | 
					 | 
				
			||||||
    public Object user(Principal principal) {
 | 
					 | 
				
			||||||
        System.out.println("GetUserInfo + " + principal);
 | 
					 | 
				
			||||||
        System.out.println(SecurityContextHolder.getContext().getAuthentication());
 | 
					 | 
				
			||||||
        return SecurityContextHolder.getContext().getAuthentication().getPrincipal();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @CrossOrigin(methods = {RequestMethod.GET, RequestMethod.OPTIONS})
 | 
					 | 
				
			||||||
    @GetMapping("/unauth/random")
 | 
					 | 
				
			||||||
    public boolean rand(@RequestHeader("Authorization") String token) throws RoleNotFoundException {
 | 
					 | 
				
			||||||
        System.err.println(token);
 | 
					 | 
				
			||||||
        return Math.random() > 0.5;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/admin/random")
 | 
					 | 
				
			||||||
    public boolean rand2() {
 | 
					 | 
				
			||||||
        return Math.random() > 0.5;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/entrepreneur/random")
 | 
					 | 
				
			||||||
    public boolean rand3() {
 | 
					 | 
				
			||||||
        return Math.random() > 0.5;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -2,7 +2,7 @@
 | 
				
			|||||||
 * Source: https://github.com/ChristianHuff-DEV/secure-spring-rest-api-using-keycloak/blob/main/src/main/java/io/betweendata/RestApi/security/oauth2/KeycloakJwtRolesConverter.java
 | 
					 * Source: https://github.com/ChristianHuff-DEV/secure-spring-rest-api-using-keycloak/blob/main/src/main/java/io/betweendata/RestApi/security/oauth2/KeycloakJwtRolesConverter.java
 | 
				
			||||||
 * edited by Pierre Tellier
 | 
					 * edited by Pierre Tellier
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
package enseirb.myinpulse.security;
 | 
					package enseirb.myinpulse.config;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import static java.util.stream.Collectors.toSet;
 | 
					import static java.util.stream.Collectors.toSet;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -2,8 +2,6 @@ package enseirb.myinpulse.config;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import static org.springframework.security.authorization.AuthorityAuthorizationManager.hasRole;
 | 
					import static org.springframework.security.authorization.AuthorityAuthorizationManager.hasRole;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import enseirb.myinpulse.security.KeycloakJwtRolesConverter;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Value;
 | 
					import org.springframework.beans.factory.annotation.Value;
 | 
				
			||||||
import org.springframework.context.annotation.Bean;
 | 
					import org.springframework.context.annotation.Bean;
 | 
				
			||||||
import org.springframework.context.annotation.Configuration;
 | 
					import org.springframework.context.annotation.Configuration;
 | 
				
			||||||
@@ -58,9 +56,9 @@ public class WebSecurityCustomConfiguration {
 | 
				
			|||||||
        http.authorizeHttpRequests(
 | 
					        http.authorizeHttpRequests(
 | 
				
			||||||
                        authorize ->
 | 
					                        authorize ->
 | 
				
			||||||
                                authorize
 | 
					                                authorize
 | 
				
			||||||
                                        .requestMatchers("/entrepreneur/**")
 | 
					                                        .requestMatchers("/entrepreneur/**", "/shared/**")
 | 
				
			||||||
                                        .access(hasRole("REALM_MyINPulse-entrepreneur"))
 | 
					                                        .access(hasRole("REALM_MyINPulse-entrepreneur"))
 | 
				
			||||||
                                        .requestMatchers("/admin/**")
 | 
					                                        .requestMatchers("/admin/**", "/shared/**")
 | 
				
			||||||
                                        .access(hasRole("REALM_MyINPulse-admin"))
 | 
					                                        .access(hasRole("REALM_MyINPulse-admin"))
 | 
				
			||||||
                                        .requestMatchers("/unauth/**")
 | 
					                                        .requestMatchers("/unauth/**")
 | 
				
			||||||
                                        .permitAll()
 | 
					                                        .permitAll()
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,102 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.controller;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.*;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.AdminApiService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.boot.autoconfigure.SpringBootApplication;
 | 
				
			||||||
 | 
					import org.springframework.security.core.annotation.AuthenticationPrincipal;
 | 
				
			||||||
 | 
					import org.springframework.security.oauth2.jwt.Jwt;
 | 
				
			||||||
 | 
					import org.springframework.web.bind.annotation.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@SpringBootApplication
 | 
				
			||||||
 | 
					@RestController
 | 
				
			||||||
 | 
					public class AdminApi {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final AdminApiService adminApiService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    AdminApi(AdminApiService adminApiService) {
 | 
				
			||||||
 | 
					        this.adminApiService = adminApiService;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: description
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return a list of all project managed by the current admin user
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/admin/projects")
 | 
				
			||||||
 | 
					    public Iterable<Project> getProjects(@AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        return adminApiService.getProjectsOfAdmin(principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: Why in admin instead of shared ? + desc
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return a list of upcoming appointments for the current user
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/admin/appointments/upcoming")
 | 
				
			||||||
 | 
					    public Iterable<Appointment> getUpcomingAppointments(@AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        return adminApiService.getUpcomingAppointments(principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: description
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return a list of current unvalidated projects, waiting to be accepted
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/admin/projects/pending")
 | 
				
			||||||
 | 
					    public Iterable<Project> getPendingProjects() {
 | 
				
			||||||
 | 
					        return adminApiService.getPendingProjects();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Endpoint used to make a decision about a project.
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * <p>The decision must contain the administrator
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return the status code of the request
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @PostMapping("/admin/projects/decision")
 | 
				
			||||||
 | 
					    public void validateProject(@RequestBody ProjectDecision decision) {
 | 
				
			||||||
 | 
					        adminApiService.validateProject(decision);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Endpoint used to manually add a project by an admin
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return the status code of the request
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @PostMapping("/admin/project/add")
 | 
				
			||||||
 | 
					    public void addNewProject(@RequestBody Project project) {
 | 
				
			||||||
 | 
					        adminApiService.addNewProject(project);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: shouldn't it be an PUT request ? / What is the rerun type
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * <p>Endpoint used to add a new report to an appointment
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return the status code of the request
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @PostMapping("/admin/appoitements/report/{appointmentId}")
 | 
				
			||||||
 | 
					    public void createAppointmentReport(
 | 
				
			||||||
 | 
					            @PathVariable long appointmentId,
 | 
				
			||||||
 | 
					            @RequestBody Report report,
 | 
				
			||||||
 | 
					            @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        adminApiService.createAppointmentReport(
 | 
				
			||||||
 | 
					                appointmentId, report, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: Shouldn't a project be kept in history ? 2 different endpoints ?
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * <p>Endpoint used to completely remove a project.
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return the status code of the request
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @DeleteMapping("/admin/projects/remove/{projectId}")
 | 
				
			||||||
 | 
					    public void deleteProject(@PathVariable long projectId) {
 | 
				
			||||||
 | 
					        adminApiService.deleteProject(projectId);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,78 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.controller;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.SectionCell;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.EntrepreneurApiService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.boot.autoconfigure.SpringBootApplication;
 | 
				
			||||||
 | 
					import org.springframework.security.core.annotation.AuthenticationPrincipal;
 | 
				
			||||||
 | 
					import org.springframework.security.oauth2.jwt.Jwt;
 | 
				
			||||||
 | 
					import org.springframework.web.bind.annotation.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@SpringBootApplication
 | 
				
			||||||
 | 
					@RestController
 | 
				
			||||||
 | 
					public class EntrepreneurApi {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final EntrepreneurApiService entrepreneurApiService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    EntrepreneurApi(EntrepreneurApiService entrepreneurApiService) {
 | 
				
			||||||
 | 
					        this.entrepreneurApiService = entrepreneurApiService;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: check return type
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * <p>Endpoint used to update a LC section.
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return status code
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @PutMapping("/entrepreneur/lcsection/modify/{sectionId}")
 | 
				
			||||||
 | 
					    public void editSectionCell(
 | 
				
			||||||
 | 
					            @PathVariable Long sectionId,
 | 
				
			||||||
 | 
					            @RequestBody SectionCell sectionCell,
 | 
				
			||||||
 | 
					            @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        entrepreneurApiService.editSectionCell(
 | 
				
			||||||
 | 
					                sectionId, sectionCell, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: checkReturn Type
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * <p>Endpoint used to delete a LC section
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return status code
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @DeleteMapping("/entrepreneur/lcsection/remove/{sectionId}")
 | 
				
			||||||
 | 
					    public void removeSectionCell(
 | 
				
			||||||
 | 
					            @PathVariable Long sectionId, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        entrepreneurApiService.removeSectionCell(sectionId, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: check return type
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * <p>Endpoint used to create a new LC section
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return status code
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @PostMapping("/entrepreneur/lcsection/add") // remove id from doc aswell
 | 
				
			||||||
 | 
					    public void addLCSection(
 | 
				
			||||||
 | 
					            @RequestBody SectionCell sectionCell, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        entrepreneurApiService.addSectionCell(sectionCell, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * TODO: check return type
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * <p>Endpoint used to request the creation of a new project
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return status code
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @PostMapping("/entrepreneur/project/request")
 | 
				
			||||||
 | 
					    public void requestNewProject(
 | 
				
			||||||
 | 
					            @RequestBody Project project, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        entrepreneurApiService.requestNewProject(project, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,101 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.controller;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.itextpdf.text.DocumentException;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.*;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.SharedApiService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.boot.autoconfigure.SpringBootApplication;
 | 
				
			||||||
 | 
					import org.springframework.security.core.annotation.AuthenticationPrincipal;
 | 
				
			||||||
 | 
					import org.springframework.security.oauth2.jwt.Jwt;
 | 
				
			||||||
 | 
					import org.springframework.web.bind.annotation.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.io.FileNotFoundException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@SpringBootApplication
 | 
				
			||||||
 | 
					@RestController
 | 
				
			||||||
 | 
					public class SharedApi {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final SharedApiService sharedApiService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    SharedApi(SharedApiService sharedApiService) {
 | 
				
			||||||
 | 
					        this.sharedApiService = sharedApiService;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Endpoint used to get the data inside the lean canvas
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return a list of lean canvas sections
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/shared/project/lcsection/{projectId}/{sectionId}/{date}")
 | 
				
			||||||
 | 
					    public Iterable<SectionCell> getLCSection(
 | 
				
			||||||
 | 
					            @PathVariable("projectId") Long projectId,
 | 
				
			||||||
 | 
					            @PathVariable("sectionId") Long sectionId,
 | 
				
			||||||
 | 
					            @PathVariable("date") String date,
 | 
				
			||||||
 | 
					            @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        return sharedApiService.getSectionCells(
 | 
				
			||||||
 | 
					                projectId, sectionId, date, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Endpoint used to get entrepreneurs details
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return a list of all entrepreneurs in a project
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/shared/entrepreneurs/{projectId}")
 | 
				
			||||||
 | 
					    public Iterable<Entrepreneur> getEntrepreneursByProjectId(
 | 
				
			||||||
 | 
					            @PathVariable int projectId, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        return sharedApiService.getEntrepreneursByProjectId(
 | 
				
			||||||
 | 
					                projectId, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Endpoint used to get the administrator of a project.
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return the admin of a project
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/shared/projects/admin/{projectId}")
 | 
				
			||||||
 | 
					    public Administrator getAdminByProjectId(
 | 
				
			||||||
 | 
					            @PathVariable int projectId, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        return sharedApiService.getAdminByProjectId(projectId, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Endpoint used to get all appointments of a single project.
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return a list of all appointments.
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/shared/projects/appointments/{projectId}")
 | 
				
			||||||
 | 
					    public Iterable<Appointment> getAppointmentsByProjectId(
 | 
				
			||||||
 | 
					            @PathVariable int projectId, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        return sharedApiService.getAppointmentsByProjectId(
 | 
				
			||||||
 | 
					                projectId, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * Endpoint used to generate a PDF report
 | 
				
			||||||
 | 
					     *
 | 
				
			||||||
 | 
					     * @return a PDF file? TODO: how does that works ?
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @GetMapping("/shared/projects/appointments/report/{appointmentId}")
 | 
				
			||||||
 | 
					    public void getPDFReport(
 | 
				
			||||||
 | 
					            @PathVariable int appointmentId, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        try {
 | 
				
			||||||
 | 
					            sharedApiService.getPDFReport(appointmentId, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					        } catch (FileNotFoundException e) {
 | 
				
			||||||
 | 
					            System.out.println(e + "File not found");
 | 
				
			||||||
 | 
					        } catch (DocumentException e) {
 | 
				
			||||||
 | 
					            System.out.println(e + "Document exception");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * @return TODO
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    @PostMapping("/shared/appointment/request")
 | 
				
			||||||
 | 
					    public void createAppointmentRequest(
 | 
				
			||||||
 | 
					            @RequestBody Appointment appointment, @AuthenticationPrincipal Jwt principal) {
 | 
				
			||||||
 | 
					        sharedApiService.createAppointmentRequest(appointment, principal.getClaimAsString("email"));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
package enseirb.myinpulse.exceptions;
 | 
					package enseirb.myinpulse.exception;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class RoleNotFoudException extends RuntimeException {
 | 
					public class RoleNotFoudException extends RuntimeException {
 | 
				
			||||||
    public RoleNotFoudException(String message) {
 | 
					    public RoleNotFoudException(String message) {
 | 
				
			||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
package enseirb.myinpulse.exceptions;
 | 
					package enseirb.myinpulse.exception;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class UserNotFoundException extends RuntimeException {
 | 
					public class UserNotFoundException extends RuntimeException {
 | 
				
			||||||
    public UserNotFoundException(String message) {
 | 
					    public UserNotFoundException(String message) {
 | 
				
			||||||
@@ -0,0 +1,66 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					import jakarta.persistence.PrimaryKeyJoinColumn;
 | 
				
			||||||
 | 
					import jakarta.persistence.Table;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "administrator")
 | 
				
			||||||
 | 
					@PrimaryKeyJoinColumn(name = "idAdministrator", referencedColumnName = "idUser")
 | 
				
			||||||
 | 
					public class Administrator extends User {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToMany(mappedBy = "projectAdministrator", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private final List<Project> listProject = new ArrayList<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /*@OneToMany(mappedBy = "administratorSectionCell", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private List<SectionCell> listSectionCell = new ArrayList<>();*/
 | 
				
			||||||
 | 
					    // should now be useless
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToMany(mappedBy = "administratorAnnotation", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private final List<Annotation> listAnnotation = new ArrayList<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /*@OneToMany(mappedBy = "administratorAppointment", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private final List<Appointment> listAppointment = new ArrayList<>();*/
 | 
				
			||||||
 | 
					    // should now be useless
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToOne(mappedBy = "administratorAppointment", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private MakeAppointment makeAppointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Administrator() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Administrator(
 | 
				
			||||||
 | 
					            String userSurname,
 | 
				
			||||||
 | 
					            String username,
 | 
				
			||||||
 | 
					            String primaryMail,
 | 
				
			||||||
 | 
					            String secondaryMail,
 | 
				
			||||||
 | 
					            String phoneNumber) {
 | 
				
			||||||
 | 
					        super(null, userSurname, username, primaryMail, secondaryMail, phoneNumber);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<Project> getListProject() {
 | 
				
			||||||
 | 
					        return listProject;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void updateListProject(Project project) {
 | 
				
			||||||
 | 
					        listProject.add(project);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<Annotation> getListAnnotation() {
 | 
				
			||||||
 | 
					        return listAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void updateListAnnotation(Annotation annotation) {
 | 
				
			||||||
 | 
					        listAnnotation.add(annotation);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public MakeAppointment getMakeAppointment() {
 | 
				
			||||||
 | 
					        return makeAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setMakeAppointment(MakeAppointment makeAppointment) {
 | 
				
			||||||
 | 
					        this.makeAppointment = makeAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,61 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "annotation")
 | 
				
			||||||
 | 
					public class Annotation {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
				
			||||||
 | 
					    private Long idAnnotation;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private String comment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idSectionCell")
 | 
				
			||||||
 | 
					    private SectionCell sectionCellAnnotation;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idAdministrator")
 | 
				
			||||||
 | 
					    private Administrator administratorAnnotation;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Annotation() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Annotation(Long idAnnotation, String commentary) {
 | 
				
			||||||
 | 
					        this.idAnnotation = idAnnotation;
 | 
				
			||||||
 | 
					        this.comment = comment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getComment() {
 | 
				
			||||||
 | 
					        return comment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setComment(String comment) {
 | 
				
			||||||
 | 
					        this.comment = comment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getIdAnnotation() {
 | 
				
			||||||
 | 
					        return idAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setIdAnnotation(Long idAnnotation) {
 | 
				
			||||||
 | 
					        this.idAnnotation = idAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public SectionCell getSectionCellAnnotation() {
 | 
				
			||||||
 | 
					        return sectionCellAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSectionCellAnnotation(SectionCell sectionCellAnnotation) {
 | 
				
			||||||
 | 
					        this.sectionCellAnnotation = sectionCellAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Administrator getAdministratorAnnotation() {
 | 
				
			||||||
 | 
					        return administratorAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAdministratorAnnotation(Administrator administratorAnnotation) {
 | 
				
			||||||
 | 
					        this.administratorAnnotation = administratorAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,126 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDate;
 | 
				
			||||||
 | 
					import java.time.LocalTime;
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "appointment")
 | 
				
			||||||
 | 
					public class Appointment {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /*@OneToMany(mappedBy = "appointmentEntrepreneurs", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private final List<Entrepreneur> listEntrepreneur =
 | 
				
			||||||
 | 
					            new ArrayList<>(); */
 | 
				
			||||||
 | 
					    // should now be useless
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToMany(
 | 
				
			||||||
 | 
					            fetch = FetchType.LAZY,
 | 
				
			||||||
 | 
					            cascade = {CascadeType.ALL})
 | 
				
			||||||
 | 
					    @JoinTable(
 | 
				
			||||||
 | 
					            name = "concern",
 | 
				
			||||||
 | 
					            joinColumns = @JoinColumn(name = "idAppointment"),
 | 
				
			||||||
 | 
					            inverseJoinColumns = @JoinColumn(name = "idSectionCell"))
 | 
				
			||||||
 | 
					    List<SectionCell> listSectionCell = new ArrayList<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToOne(mappedBy = "appointmentReport", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private Report report;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
				
			||||||
 | 
					    private Long idAppointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private LocalDate appointmentDate;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private LocalTime appointmentTime;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private LocalTime appointmentDuration;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String appointmentPlace;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private String appointmentSubject;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Appointment() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Appointment(
 | 
				
			||||||
 | 
					            Long idAppointment,
 | 
				
			||||||
 | 
					            LocalDate appointmentDate,
 | 
				
			||||||
 | 
					            LocalTime appointmentTime,
 | 
				
			||||||
 | 
					            LocalTime appointmentDuration,
 | 
				
			||||||
 | 
					            String appointmentPlace,
 | 
				
			||||||
 | 
					            String appointmentSubject) {
 | 
				
			||||||
 | 
					        this.idAppointment = idAppointment;
 | 
				
			||||||
 | 
					        this.appointmentDate = appointmentDate;
 | 
				
			||||||
 | 
					        this.appointmentTime = appointmentTime;
 | 
				
			||||||
 | 
					        this.appointmentDuration = appointmentDuration;
 | 
				
			||||||
 | 
					        this.appointmentPlace = appointmentPlace;
 | 
				
			||||||
 | 
					        this.appointmentSubject = appointmentSubject;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getIdAppointment() {
 | 
				
			||||||
 | 
					        return idAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setIdAppointment(Long idAppointment) {
 | 
				
			||||||
 | 
					        this.idAppointment = idAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public LocalDate getAppointmentDate() {
 | 
				
			||||||
 | 
					        return appointmentDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAppointmentDate(LocalDate appointmentDate) {
 | 
				
			||||||
 | 
					        this.appointmentDate = appointmentDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public LocalTime getAppointmentTime() {
 | 
				
			||||||
 | 
					        return appointmentTime;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAppointmentTime(LocalTime appointmentTime) {
 | 
				
			||||||
 | 
					        this.appointmentTime = appointmentTime;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public LocalTime getAppointmentDuration() {
 | 
				
			||||||
 | 
					        return appointmentDuration;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAppointmentDuration(LocalTime appointmentDuration) {
 | 
				
			||||||
 | 
					        this.appointmentDuration = appointmentDuration;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getAppointmentPlace() {
 | 
				
			||||||
 | 
					        return appointmentPlace;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAppointmentPlace(String appointmentPlace) {
 | 
				
			||||||
 | 
					        this.appointmentPlace = appointmentPlace;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getAppointmentSubject() {
 | 
				
			||||||
 | 
					        return appointmentSubject;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAppointmentSubject(String appointmentSubject) {
 | 
				
			||||||
 | 
					        this.appointmentSubject = appointmentSubject;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<SectionCell> getAppointmentListSectionCell() {
 | 
				
			||||||
 | 
					        return listSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void updateListSectionCell(SectionCell sectionCell) {
 | 
				
			||||||
 | 
					        listSectionCell.add(sectionCell);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Report getAppointmentReport() {
 | 
				
			||||||
 | 
					        return report;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAppointmentReport(Report report) {
 | 
				
			||||||
 | 
					        this.report = report;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,124 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					import jakarta.persistence.Entity;
 | 
				
			||||||
 | 
					import jakarta.persistence.Table;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "entrepreneur")
 | 
				
			||||||
 | 
					@PrimaryKeyJoinColumn(name = "idEntrepreneur", referencedColumnName = "idUser")
 | 
				
			||||||
 | 
					public class Entrepreneur extends User {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String school;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String course;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private boolean sneeStatus;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idProjectParticipation", referencedColumnName = "idProject")
 | 
				
			||||||
 | 
					    private Project projectParticipation;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // @Column(insertable=false, updatable=false)
 | 
				
			||||||
 | 
					    @OneToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idProjectProposed", referencedColumnName = "idProject")
 | 
				
			||||||
 | 
					    private Project projectProposed;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /*@ManyToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idAppointment")
 | 
				
			||||||
 | 
					    private Appointment appointmentEntrepreneur;*/
 | 
				
			||||||
 | 
					    // should now be useless
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToOne(mappedBy = "entrepreneurAppointment", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private MakeAppointment makeAppointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Entrepreneur() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Entrepreneur(
 | 
				
			||||||
 | 
					            Long idUser,
 | 
				
			||||||
 | 
					            String userSurname,
 | 
				
			||||||
 | 
					            String username,
 | 
				
			||||||
 | 
					            String primaryMail,
 | 
				
			||||||
 | 
					            String secondaryMail,
 | 
				
			||||||
 | 
					            String phoneNumber,
 | 
				
			||||||
 | 
					            String school,
 | 
				
			||||||
 | 
					            String course,
 | 
				
			||||||
 | 
					            boolean sneeStatus) {
 | 
				
			||||||
 | 
					        super(idUser, userSurname, username, primaryMail, secondaryMail, phoneNumber);
 | 
				
			||||||
 | 
					        this.school = school;
 | 
				
			||||||
 | 
					        this.course = course;
 | 
				
			||||||
 | 
					        this.sneeStatus = sneeStatus;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Entrepreneur(
 | 
				
			||||||
 | 
					            Long idUser,
 | 
				
			||||||
 | 
					            String userSurname,
 | 
				
			||||||
 | 
					            String userName,
 | 
				
			||||||
 | 
					            String primaryMail,
 | 
				
			||||||
 | 
					            String secondaryMail,
 | 
				
			||||||
 | 
					            String phoneNumber,
 | 
				
			||||||
 | 
					            String school,
 | 
				
			||||||
 | 
					            String course,
 | 
				
			||||||
 | 
					            boolean sneeStatus,
 | 
				
			||||||
 | 
					            Project projectParticipation,
 | 
				
			||||||
 | 
					            Project projectProposed,
 | 
				
			||||||
 | 
					            MakeAppointment makeAppointment) {
 | 
				
			||||||
 | 
					        super(idUser, userSurname, userName, primaryMail, secondaryMail, phoneNumber);
 | 
				
			||||||
 | 
					        this.school = school;
 | 
				
			||||||
 | 
					        this.course = course;
 | 
				
			||||||
 | 
					        this.sneeStatus = sneeStatus;
 | 
				
			||||||
 | 
					        this.projectParticipation = projectParticipation;
 | 
				
			||||||
 | 
					        this.projectProposed = projectProposed;
 | 
				
			||||||
 | 
					        this.makeAppointment = makeAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getSchool() {
 | 
				
			||||||
 | 
					        return school;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSchool(String school) {
 | 
				
			||||||
 | 
					        this.school = school;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getCourse() {
 | 
				
			||||||
 | 
					        return course;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setCourse(String course) {
 | 
				
			||||||
 | 
					        this.course = course;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public boolean isSneeStatus() {
 | 
				
			||||||
 | 
					        return sneeStatus;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSneeStatus(boolean statusSnee) {
 | 
				
			||||||
 | 
					        this.sneeStatus = sneeStatus;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project getProjectParticipation() {
 | 
				
			||||||
 | 
					        return projectParticipation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setProjectParticipation(Project projectParticipation) {
 | 
				
			||||||
 | 
					        this.projectParticipation = projectParticipation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project getProjectProposed() {
 | 
				
			||||||
 | 
					        return projectProposed;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setProjectProposed(Project projectProposed) {
 | 
				
			||||||
 | 
					        this.projectProposed = projectProposed;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public MakeAppointment getMakeAppointment() {
 | 
				
			||||||
 | 
					        return makeAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setMakeAppointment(MakeAppointment makeAppointment) {
 | 
				
			||||||
 | 
					        this.makeAppointment = makeAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,26 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "make_appointment")
 | 
				
			||||||
 | 
					public class MakeAppointment {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
				
			||||||
 | 
					    private Long idMakeAppointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idAdministrator")
 | 
				
			||||||
 | 
					    private Administrator administratorAppointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idEntrepreneur")
 | 
				
			||||||
 | 
					    private Entrepreneur entrepreneurAppointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public MakeAppointment() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public MakeAppointment(Long idMakeAppointment) {
 | 
				
			||||||
 | 
					        this.idMakeAppointment = idMakeAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,140 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDate;
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "project")
 | 
				
			||||||
 | 
					public class Project {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToMany(mappedBy = "projectParticipation", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private final List<Entrepreneur> listEntrepreneurParticipation = new ArrayList<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToMany(mappedBy = "projectSectionCell", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private final List<SectionCell> listSectionCell = new ArrayList<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
				
			||||||
 | 
					    private Long idProject;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String projectName;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private byte[] logo;
 | 
				
			||||||
 | 
					    private LocalDate creationDate;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column private ProjectDecisionValue projectStatus;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idAdministrator")
 | 
				
			||||||
 | 
					    private Administrator projectAdministrator;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToOne(mappedBy = "projectProposed", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private Entrepreneur entrepreneurProposed;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project(
 | 
				
			||||||
 | 
					            String projectName,
 | 
				
			||||||
 | 
					            byte[] logo,
 | 
				
			||||||
 | 
					            LocalDate creationDate,
 | 
				
			||||||
 | 
					            ProjectDecisionValue projectStatus,
 | 
				
			||||||
 | 
					            Administrator projectAdministrator) {
 | 
				
			||||||
 | 
					        this.projectName = projectName;
 | 
				
			||||||
 | 
					        this.logo = logo;
 | 
				
			||||||
 | 
					        this.creationDate = creationDate;
 | 
				
			||||||
 | 
					        // this.projectStatus = (long) projectStatus.ordinal();
 | 
				
			||||||
 | 
					        this.projectStatus = projectStatus;
 | 
				
			||||||
 | 
					        this.projectAdministrator = projectAdministrator;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project(
 | 
				
			||||||
 | 
					            String projectName,
 | 
				
			||||||
 | 
					            byte[] logo,
 | 
				
			||||||
 | 
					            LocalDate creationDate,
 | 
				
			||||||
 | 
					            ProjectDecisionValue projectStatus,
 | 
				
			||||||
 | 
					            Administrator projectAdministrator,
 | 
				
			||||||
 | 
					            Entrepreneur entrepreneurProposed) {
 | 
				
			||||||
 | 
					        this.projectName = projectName;
 | 
				
			||||||
 | 
					        this.logo = logo;
 | 
				
			||||||
 | 
					        this.creationDate = creationDate;
 | 
				
			||||||
 | 
					        this.projectStatus = projectStatus;
 | 
				
			||||||
 | 
					        this.projectAdministrator = projectAdministrator;
 | 
				
			||||||
 | 
					        this.entrepreneurProposed = entrepreneurProposed;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getIdProject() {
 | 
				
			||||||
 | 
					        return idProject;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setIdProject(Long idProject) {
 | 
				
			||||||
 | 
					        this.idProject = idProject;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getProjectName() {
 | 
				
			||||||
 | 
					        return projectName;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setProjectName(String projectName) {
 | 
				
			||||||
 | 
					        this.projectName = projectName;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public byte[] getLogo() {
 | 
				
			||||||
 | 
					        return logo;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setLogo(byte[] logo) {
 | 
				
			||||||
 | 
					        this.logo = logo;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public LocalDate getCreationDate() {
 | 
				
			||||||
 | 
					        return creationDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setCreationDate(LocalDate creationDate) {
 | 
				
			||||||
 | 
					        this.creationDate = creationDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ProjectDecisionValue getProjectStatus() {
 | 
				
			||||||
 | 
					        return projectStatus;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setProjectStatus(ProjectDecisionValue projectStatus) {
 | 
				
			||||||
 | 
					        this.projectStatus = projectStatus;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<Entrepreneur> getListEntrepreneurParticipation() {
 | 
				
			||||||
 | 
					        return listEntrepreneurParticipation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void updateListEntrepreneurParticipation(Entrepreneur projectParticipant) {
 | 
				
			||||||
 | 
					        listEntrepreneurParticipation.add(projectParticipant);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<SectionCell> getListSectionCell() {
 | 
				
			||||||
 | 
					        return listSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void updateListSectionCell(SectionCell projectSectionCell) {
 | 
				
			||||||
 | 
					        listSectionCell.add(projectSectionCell);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Administrator getProjectAdministrator() {
 | 
				
			||||||
 | 
					        return projectAdministrator;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setProjectAdministrator(Administrator projectAdministrator) {
 | 
				
			||||||
 | 
					        this.projectAdministrator = projectAdministrator;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Entrepreneur getEntrepreneurProposed() {
 | 
				
			||||||
 | 
					        return entrepreneurProposed;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setEntrepreneurProposed(Entrepreneur entrepreneurProposed) {
 | 
				
			||||||
 | 
					        this.entrepreneurProposed = entrepreneurProposed;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,25 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public class ProjectDecision {
 | 
				
			||||||
 | 
					    public long projectId;
 | 
				
			||||||
 | 
					    public long adminId;
 | 
				
			||||||
 | 
					    public long isAccepted;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public ProjectDecision(long projectId, long adminId, long isAccepted) {
 | 
				
			||||||
 | 
					        this.projectId = projectId;
 | 
				
			||||||
 | 
					        this.adminId = adminId;
 | 
				
			||||||
 | 
					        this.isAccepted = isAccepted;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Override
 | 
				
			||||||
 | 
					    public String toString() {
 | 
				
			||||||
 | 
					        return "ProjectDecision{"
 | 
				
			||||||
 | 
					                + "projectId="
 | 
				
			||||||
 | 
					                + projectId
 | 
				
			||||||
 | 
					                + ", adminId="
 | 
				
			||||||
 | 
					                + adminId
 | 
				
			||||||
 | 
					                + ", isAccepted="
 | 
				
			||||||
 | 
					                + isAccepted
 | 
				
			||||||
 | 
					                + '}';
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public enum ProjectDecisionValue {
 | 
				
			||||||
 | 
					    PENDING,
 | 
				
			||||||
 | 
					    ACTIVE,
 | 
				
			||||||
 | 
					    ENDED,
 | 
				
			||||||
 | 
					    ABORTED,
 | 
				
			||||||
 | 
					    REJECTED,
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,48 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					import jakarta.persistence.Entity;
 | 
				
			||||||
 | 
					import jakarta.persistence.Id;
 | 
				
			||||||
 | 
					import jakarta.persistence.Table;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "report")
 | 
				
			||||||
 | 
					public class Report {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
				
			||||||
 | 
					    private Long idReport;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private String reportContent;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idAppointment")
 | 
				
			||||||
 | 
					    private Appointment appointmentReport;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Report() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Report(Long idReport, String reportContent) {
 | 
				
			||||||
 | 
					        this.idReport = idReport;
 | 
				
			||||||
 | 
					        this.reportContent = reportContent;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getIdReport() {
 | 
				
			||||||
 | 
					        return idReport;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getReportContent() {
 | 
				
			||||||
 | 
					        return reportContent;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setReportContent(String reportContent) {
 | 
				
			||||||
 | 
					        this.reportContent = reportContent;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Appointment getAppointmentReport() {
 | 
				
			||||||
 | 
					        return appointmentReport;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setAppointmentReport(Appointment appointmentReport) {
 | 
				
			||||||
 | 
					        this.appointmentReport = appointmentReport;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
package enseirb.myinpulse.utils.keycloak.datatypes;
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class RoleRepresentation {
 | 
					public class RoleRepresentation {
 | 
				
			||||||
    public String id;
 | 
					    public String id;
 | 
				
			||||||
@@ -0,0 +1,110 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDateTime;
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "section_cell")
 | 
				
			||||||
 | 
					public class SectionCell {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToMany(mappedBy = "listSectionCell")
 | 
				
			||||||
 | 
					    private final List<Appointment> listAppointment = new ArrayList<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @OneToMany(mappedBy = "sectionCellAnnotation", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
				
			||||||
 | 
					    private final List<Annotation> listAnnotation = new ArrayList<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
				
			||||||
 | 
					    private Long idSectionCell;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column() private long sectionId;
 | 
				
			||||||
 | 
					    private String contentSectionCell;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /*@ManyToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idAdministrator")
 | 
				
			||||||
 | 
					    private Administrator administratorSectionCell;*/
 | 
				
			||||||
 | 
					    // should now be useless
 | 
				
			||||||
 | 
					    private LocalDateTime modificationDate;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @ManyToOne(fetch = FetchType.LAZY)
 | 
				
			||||||
 | 
					    @JoinColumn(name = "idProject")
 | 
				
			||||||
 | 
					    private Project projectSectionCell;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public SectionCell() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public SectionCell(
 | 
				
			||||||
 | 
					            Long idSectionCell,
 | 
				
			||||||
 | 
					            Long sectionId,
 | 
				
			||||||
 | 
					            String contentSectionCell,
 | 
				
			||||||
 | 
					            LocalDateTime modificationDate,
 | 
				
			||||||
 | 
					            Project projectSectionCell) {
 | 
				
			||||||
 | 
					        this.idSectionCell = idSectionCell;
 | 
				
			||||||
 | 
					        this.sectionId = sectionId;
 | 
				
			||||||
 | 
					        this.contentSectionCell = contentSectionCell;
 | 
				
			||||||
 | 
					        this.modificationDate = modificationDate;
 | 
				
			||||||
 | 
					        this.projectSectionCell = projectSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getIdSectionCell() {
 | 
				
			||||||
 | 
					        return idSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setIdSectionCell(Long idSectionCell) {
 | 
				
			||||||
 | 
					        this.idSectionCell = idSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getSectionId() {
 | 
				
			||||||
 | 
					        return sectionId;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSectionId(Long sectionId) {
 | 
				
			||||||
 | 
					        this.sectionId = sectionId;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getContentSectionCell() {
 | 
				
			||||||
 | 
					        return contentSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setContentSectionCell(String contentSectionCell) {
 | 
				
			||||||
 | 
					        this.contentSectionCell = contentSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public LocalDateTime getModificationDate() {
 | 
				
			||||||
 | 
					        return modificationDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setModificationDate(LocalDateTime modificationDate) {
 | 
				
			||||||
 | 
					        this.modificationDate = modificationDate;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project getProjectSectionCell() {
 | 
				
			||||||
 | 
					        return projectSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<Appointment> getAppointmentSectionCell() {
 | 
				
			||||||
 | 
					        return listAppointment;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void updateAppointmentSectionCell(Appointment appointment) {
 | 
				
			||||||
 | 
					        listAppointment.add(appointment);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<Annotation> getListAnnotation() {
 | 
				
			||||||
 | 
					        return listAnnotation;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void updateListAnnotation(Annotation annotation) {
 | 
				
			||||||
 | 
					        listAnnotation.add(annotation);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSectionId(long sectionId) {
 | 
				
			||||||
 | 
					        this.sectionId = sectionId;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setProjectSectionCell(Project projectSectionCell) {
 | 
				
			||||||
 | 
					        this.projectSectionCell = projectSectionCell;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,93 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import jakarta.persistence.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Entity
 | 
				
			||||||
 | 
					@Table(name = "user_inpulse")
 | 
				
			||||||
 | 
					@Inheritance(strategy = InheritanceType.JOINED)
 | 
				
			||||||
 | 
					public class User {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Id
 | 
				
			||||||
 | 
					    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
				
			||||||
 | 
					    private Long idUser;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String userSurname;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String userName;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String primaryMail;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 255)
 | 
				
			||||||
 | 
					    private String secondaryMail;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Column(length = 20)
 | 
				
			||||||
 | 
					    private String phoneNumber;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public User() {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public User(
 | 
				
			||||||
 | 
					            Long idUser,
 | 
				
			||||||
 | 
					            String userSurname,
 | 
				
			||||||
 | 
					            String userName,
 | 
				
			||||||
 | 
					            String primaryMail,
 | 
				
			||||||
 | 
					            String secondaryMail,
 | 
				
			||||||
 | 
					            String phoneNumber) {
 | 
				
			||||||
 | 
					        this.idUser = idUser;
 | 
				
			||||||
 | 
					        this.userSurname = userSurname;
 | 
				
			||||||
 | 
					        this.userName = userName;
 | 
				
			||||||
 | 
					        this.primaryMail = primaryMail;
 | 
				
			||||||
 | 
					        this.secondaryMail = secondaryMail;
 | 
				
			||||||
 | 
					        this.phoneNumber = phoneNumber;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getIdUser() {
 | 
				
			||||||
 | 
					        return idUser;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setIdUser(Long idUser) {
 | 
				
			||||||
 | 
					        this.idUser = idUser;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getUserSurname() {
 | 
				
			||||||
 | 
					        return userSurname;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setUserSurname(String userSurname) {
 | 
				
			||||||
 | 
					        userSurname = userSurname;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getUserName() {
 | 
				
			||||||
 | 
					        return userName;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setUserName(String userName) {
 | 
				
			||||||
 | 
					        userName = userName;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getPrimaryMail() {
 | 
				
			||||||
 | 
					        return primaryMail;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setPrimaryMail(String primaryMail) {
 | 
				
			||||||
 | 
					        this.primaryMail = primaryMail;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getSecondaryMail() {
 | 
				
			||||||
 | 
					        return secondaryMail;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setSecondaryMail(String secondaryMail) {
 | 
				
			||||||
 | 
					        this.secondaryMail = secondaryMail;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public String getPhoneNumber() {
 | 
				
			||||||
 | 
					        return phoneNumber;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void setPhoneNumber(String phoneNumber) {
 | 
				
			||||||
 | 
					        phoneNumber = phoneNumber;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
package enseirb.myinpulse.utils.keycloak.datatypes;
 | 
					package enseirb.myinpulse.model;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class UserRepresentation {
 | 
					public class UserRepresentation {
 | 
				
			||||||
    public String id;
 | 
					    public String id;
 | 
				
			||||||
@@ -1,38 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Administrateurs;
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.repository.AdministrateursRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Autowired;
 | 
					 | 
				
			||||||
import org.springframework.http.HttpStatus;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.server.ResponseStatusException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.util.Optional;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class AdministrateursController {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Autowired AdministrateursRepository administrateursRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Administrateurs")
 | 
					 | 
				
			||||||
    @ResponseBody
 | 
					 | 
				
			||||||
    public Iterable<Administrateurs> allAdministrateurs() {
 | 
					 | 
				
			||||||
        return this.administrateursRepository.findAll();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Administrateurs/{id}")
 | 
					 | 
				
			||||||
    public Administrateurs getAdministrateursById(@PathVariable Long id) {
 | 
					 | 
				
			||||||
        Optional<Administrateurs> administrateur = this.administrateursRepository.findById(id);
 | 
					 | 
				
			||||||
        if (administrateur.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(
 | 
					 | 
				
			||||||
                    HttpStatus.NOT_FOUND, "Cet administrateur n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return administrateur.get();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Administrateurs")
 | 
					 | 
				
			||||||
    public Administrateurs addAdministrateurs(@RequestBody Administrateurs administrateurs) {
 | 
					 | 
				
			||||||
        return this.administrateursRepository.save(administrateurs);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,49 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.ComptesRendus;
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.repository.ComptesRendusRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Autowired;
 | 
					 | 
				
			||||||
import org.springframework.http.HttpStatus;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.server.ResponseStatusException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.util.Optional;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class ComptesRendusController {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Autowired ComptesRendusRepository comptesRendusRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/ComptesRendus")
 | 
					 | 
				
			||||||
    @ResponseBody
 | 
					 | 
				
			||||||
    public Iterable<ComptesRendus> allComptesRendus() {
 | 
					 | 
				
			||||||
        return this.comptesRendusRepository.findAll();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/ComptesRendus/{id}")
 | 
					 | 
				
			||||||
    public ComptesRendus getComptesRendusById(@PathVariable Long id) {
 | 
					 | 
				
			||||||
        Optional<ComptesRendus> compteRendu = this.comptesRendusRepository.findById(id);
 | 
					 | 
				
			||||||
        if (compteRendu.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce compte rendu n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return compteRendu.get();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/ComptesRendus")
 | 
					 | 
				
			||||||
    public ComptesRendus addComptesRendus(@RequestBody ComptesRendus comptesRendus) {
 | 
					 | 
				
			||||||
        return this.comptesRendusRepository.save(comptesRendus);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/ComptesRendus/{id}")
 | 
					 | 
				
			||||||
    public ComptesRendus updateProjets(@PathVariable Long id, String contenu_compte_rendu) {
 | 
					 | 
				
			||||||
        Optional<ComptesRendus> compteRendu = this.comptesRendusRepository.findById(id);
 | 
					 | 
				
			||||||
        if (compteRendu.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce compte rendu n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (contenu_compte_rendu != null) {
 | 
					 | 
				
			||||||
            compteRendu.get().setContenu_compte_rendu(contenu_compte_rendu);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return this.comptesRendusRepository.save(compteRendu.get());
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,58 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Entrepreneurs;
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.repository.EntrepreneursRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Autowired;
 | 
					 | 
				
			||||||
import org.springframework.http.HttpStatus;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.server.ResponseStatusException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.util.Optional;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class EntrepreneursController {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Autowired EntrepreneursRepository entrepreneursRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Entrepreneurs")
 | 
					 | 
				
			||||||
    @ResponseBody
 | 
					 | 
				
			||||||
    public Iterable<Entrepreneurs> allEntrepreneurs() {
 | 
					 | 
				
			||||||
        return this.entrepreneursRepository.findAll();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Entrepreneurs/{id}")
 | 
					 | 
				
			||||||
    public Entrepreneurs getEntrepreneursById(@PathVariable Long id) {
 | 
					 | 
				
			||||||
        Optional<Entrepreneurs> entrepreneur = entrepreneursRepository.findById(id);
 | 
					 | 
				
			||||||
        if (entrepreneur.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(
 | 
					 | 
				
			||||||
                    HttpStatus.NOT_FOUND, "Cet entrepreneur n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return entrepreneur.get();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Entrepreneurs")
 | 
					 | 
				
			||||||
    public Entrepreneurs addEntrepreneurs(@RequestBody Entrepreneurs entrepreneurs) {
 | 
					 | 
				
			||||||
        return this.entrepreneursRepository.save(entrepreneurs);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Entrepreneurs/{id}")
 | 
					 | 
				
			||||||
    public Entrepreneurs updateEntrepreneurs(
 | 
					 | 
				
			||||||
            @PathVariable Long id, String ecole, String filiere, Boolean status_snee) {
 | 
					 | 
				
			||||||
        Optional<Entrepreneurs> entrepreneur = entrepreneursRepository.findById(id);
 | 
					 | 
				
			||||||
        if (entrepreneur.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(
 | 
					 | 
				
			||||||
                    HttpStatus.NOT_FOUND, "Cet entrepreneur n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (ecole != null) {
 | 
					 | 
				
			||||||
            entrepreneur.get().setEcole(ecole);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (filiere != null) {
 | 
					 | 
				
			||||||
            entrepreneur.get().setFiliere(filiere);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (status_snee != null) {
 | 
					 | 
				
			||||||
            entrepreneur.get().setStatus_snee(status_snee);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return this.entrepreneursRepository.save(entrepreneur.get());
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,64 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Projets;
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.repository.ProjetsRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Autowired;
 | 
					 | 
				
			||||||
import org.springframework.http.HttpStatus;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.server.ResponseStatusException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.time.LocalDate;
 | 
					 | 
				
			||||||
import java.util.Optional;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class ProjetsController {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Autowired ProjetsRepository projetsRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Projets")
 | 
					 | 
				
			||||||
    @ResponseBody
 | 
					 | 
				
			||||||
    public Iterable<Projets> allProjets() {
 | 
					 | 
				
			||||||
        return this.projetsRepository.findAll();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Projets/{id}")
 | 
					 | 
				
			||||||
    public Projets getProjetsById(@PathVariable Long id) {
 | 
					 | 
				
			||||||
        Optional<Projets> projet = this.projetsRepository.findById(id);
 | 
					 | 
				
			||||||
        if (projet.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce projet n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return projet.get();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Projets")
 | 
					 | 
				
			||||||
    public Projets addProjets(@RequestBody Projets projet) {
 | 
					 | 
				
			||||||
        return this.projetsRepository.save(projet);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Projets/{id}")
 | 
					 | 
				
			||||||
    public Projets updateProjets(
 | 
					 | 
				
			||||||
            @PathVariable Long id,
 | 
					 | 
				
			||||||
            String nom_projet,
 | 
					 | 
				
			||||||
            byte[] logo,
 | 
					 | 
				
			||||||
            LocalDate date_creation,
 | 
					 | 
				
			||||||
            String status_projet) {
 | 
					 | 
				
			||||||
        Optional<Projets> projet = this.projetsRepository.findById(id);
 | 
					 | 
				
			||||||
        if (projet.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce projet n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (nom_projet != null) {
 | 
					 | 
				
			||||||
            projet.get().setNom_projet(nom_projet);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (logo != null) {
 | 
					 | 
				
			||||||
            projet.get().setLogo(logo);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (date_creation != null) {
 | 
					 | 
				
			||||||
            projet.get().setDate_creation(date_creation);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (status_projet != null) {
 | 
					 | 
				
			||||||
            projet.get().setStatus_projet(status_projet);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return this.projetsRepository.save(projet.get());
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,67 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.RendezVous;
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.repository.RendezVousRepository;
 | 
					 | 
				
			||||||
import java.time.LocalDate;
 | 
					 | 
				
			||||||
import java.time.LocalTime;
 | 
					 | 
				
			||||||
import java.util.Optional;
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Autowired;
 | 
					 | 
				
			||||||
import org.springframework.http.HttpStatus;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.server.ResponseStatusException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class RendezVousController {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Autowired RendezVousRepository rendezVousRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/RendezVous")
 | 
					 | 
				
			||||||
    @ResponseBody
 | 
					 | 
				
			||||||
    public Iterable<RendezVous> allRendezVous() {
 | 
					 | 
				
			||||||
        return this.rendezVousRepository.findAll();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/RendezVous/{id}")
 | 
					 | 
				
			||||||
    public RendezVous getRendezVousById(@PathVariable Long id) {
 | 
					 | 
				
			||||||
        Optional<RendezVous> rendezVous = this.rendezVousRepository.findById(id);
 | 
					 | 
				
			||||||
        if (rendezVous.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce rendez vous n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return rendezVous.get();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/RendezVous")
 | 
					 | 
				
			||||||
    public RendezVous addRendezVous(@RequestBody RendezVous rendezVous) {
 | 
					 | 
				
			||||||
        return this.rendezVousRepository.save(rendezVous);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/RendezVous/{id}")
 | 
					 | 
				
			||||||
    public RendezVous updateRendezVous(
 | 
					 | 
				
			||||||
            @PathVariable Long id,
 | 
					 | 
				
			||||||
            LocalDate date_rdv,
 | 
					 | 
				
			||||||
            LocalTime heure_rdv,
 | 
					 | 
				
			||||||
            LocalTime duree_rdv,
 | 
					 | 
				
			||||||
            String lieu_rdv,
 | 
					 | 
				
			||||||
            String sujet_rdv) {
 | 
					 | 
				
			||||||
        Optional<RendezVous> rendezVous = this.rendezVousRepository.findById(id);
 | 
					 | 
				
			||||||
        if (rendezVous.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce rendez vous n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (date_rdv != null) {
 | 
					 | 
				
			||||||
            rendezVous.get().setDate_rdv(date_rdv);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (heure_rdv != null) {
 | 
					 | 
				
			||||||
            rendezVous.get().setHeure_rdv(heure_rdv);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (duree_rdv != null) {
 | 
					 | 
				
			||||||
            rendezVous.get().setDuree_rdv(duree_rdv);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (lieu_rdv != null) {
 | 
					 | 
				
			||||||
            rendezVous.get().setLieu_rdv(lieu_rdv);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (sujet_rdv != null) {
 | 
					 | 
				
			||||||
            rendezVous.get().setSujet_rdv(sujet_rdv);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return this.rendezVousRepository.save(rendezVous.get());
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,60 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Sections;
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.repository.SectionsRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Autowired;
 | 
					 | 
				
			||||||
import org.springframework.http.HttpStatus;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.server.ResponseStatusException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.time.LocalDateTime;
 | 
					 | 
				
			||||||
import java.util.Optional;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class SectionsController {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Autowired SectionsRepository sectionsRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Sections")
 | 
					 | 
				
			||||||
    @ResponseBody
 | 
					 | 
				
			||||||
    public Iterable<Sections> allSections() {
 | 
					 | 
				
			||||||
        return this.sectionsRepository.findAll();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Sections/{id}")
 | 
					 | 
				
			||||||
    public Sections getSectionsById(@PathVariable Long id) {
 | 
					 | 
				
			||||||
        Optional<Sections> section = this.sectionsRepository.findById(id);
 | 
					 | 
				
			||||||
        if (section.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Cette section n'extise pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return section.get();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Sections")
 | 
					 | 
				
			||||||
    public Sections addSections(@RequestBody Sections sections) {
 | 
					 | 
				
			||||||
        return this.sectionsRepository.save(sections);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Sections/{id}")
 | 
					 | 
				
			||||||
    public Sections updateSections(
 | 
					 | 
				
			||||||
            @PathVariable Long id,
 | 
					 | 
				
			||||||
            String titre,
 | 
					 | 
				
			||||||
            String contenu_section,
 | 
					 | 
				
			||||||
            LocalDateTime date_modification) {
 | 
					 | 
				
			||||||
        Optional<Sections> section = this.sectionsRepository.findById(id);
 | 
					 | 
				
			||||||
        if (section.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Cette section n'extise pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (titre != null) {
 | 
					 | 
				
			||||||
            section.get().setTitre(titre);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (contenu_section != null) {
 | 
					 | 
				
			||||||
            section.get().setContenu_section(contenu_section);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (date_modification != null) {
 | 
					 | 
				
			||||||
            section.get().setDate_modification(date_modification);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return this.sectionsRepository.save(section.get());
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,67 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Utilisateurs;
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.repository.UtilisateursRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.beans.factory.annotation.Autowired;
 | 
					 | 
				
			||||||
import org.springframework.http.HttpStatus;
 | 
					 | 
				
			||||||
import org.springframework.web.bind.annotation.*;
 | 
					 | 
				
			||||||
import org.springframework.web.server.ResponseStatusException;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.util.Optional;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RestController
 | 
					 | 
				
			||||||
public class UtilisateursController {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Autowired UtilisateursRepository utilisateursRepository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Utilisateurs")
 | 
					 | 
				
			||||||
    @ResponseBody
 | 
					 | 
				
			||||||
    public Iterable<Utilisateurs> allUtilisateurs() {
 | 
					 | 
				
			||||||
        return this.utilisateursRepository.findAll();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @GetMapping("/Utilisateurs/{id}")
 | 
					 | 
				
			||||||
    public Utilisateurs getUtilisateursById(@PathVariable Long id) {
 | 
					 | 
				
			||||||
        Optional<Utilisateurs> utilisateur = utilisateursRepository.findById(id);
 | 
					 | 
				
			||||||
        if (utilisateur.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Cet utilisateur n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return utilisateur.get();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Utilisateurs")
 | 
					 | 
				
			||||||
    public Utilisateurs addUtilisateurs(@RequestBody Utilisateurs utilisateurs) {
 | 
					 | 
				
			||||||
        return this.utilisateursRepository.save(utilisateurs);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @PostMapping("/Utilisateurs/{id}")
 | 
					 | 
				
			||||||
    public Utilisateurs updateUtilisateurs(
 | 
					 | 
				
			||||||
            @PathVariable Long id,
 | 
					 | 
				
			||||||
            String nom_utilisateur,
 | 
					 | 
				
			||||||
            String prenom_utilisateur,
 | 
					 | 
				
			||||||
            String mail_principal,
 | 
					 | 
				
			||||||
            String mail_secondaire,
 | 
					 | 
				
			||||||
            String numero_telephone) {
 | 
					 | 
				
			||||||
        Optional<Utilisateurs> utilisateur = utilisateursRepository.findById(id);
 | 
					 | 
				
			||||||
        if (utilisateur.isEmpty()) {
 | 
					 | 
				
			||||||
            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Cet utilisateur n'existe pas");
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (nom_utilisateur != null) {
 | 
					 | 
				
			||||||
            utilisateur.get().setNom_utilisateur(nom_utilisateur);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (prenom_utilisateur != null) {
 | 
					 | 
				
			||||||
            utilisateur.get().setPrenom_utilisateur(prenom_utilisateur);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (mail_principal != null) {
 | 
					 | 
				
			||||||
            utilisateur.get().setMail_principal(mail_principal);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (mail_secondaire != null) {
 | 
					 | 
				
			||||||
            utilisateur.get().setMail_secondaire(mail_secondaire);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (numero_telephone != null) {
 | 
					 | 
				
			||||||
            utilisateur.get().setNumero_telephone(numero_telephone);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return this.utilisateursRepository.save(utilisateur.get());
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,43 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.model;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import jakarta.persistence.*;
 | 
					 | 
				
			||||||
import jakarta.persistence.PrimaryKeyJoinColumn;
 | 
					 | 
				
			||||||
import jakarta.persistence.Table;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.util.ArrayList;
 | 
					 | 
				
			||||||
import java.util.List;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@Entity
 | 
					 | 
				
			||||||
@Table(name = "administrateurs")
 | 
					 | 
				
			||||||
@PrimaryKeyJoinColumn(name = "id_administrateur", referencedColumnName = "id_utilisateur")
 | 
					 | 
				
			||||||
public class Administrateurs extends Utilisateurs {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_projet")
 | 
					 | 
				
			||||||
    private Projets projetsAdministrateurs;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToMany(mappedBy = "administrateursSections", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private List<Sections> ListSections = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_rdv")
 | 
					 | 
				
			||||||
    private RendezVous rendezVousAdministrateurs;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Administrateurs() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Administrateurs(
 | 
					 | 
				
			||||||
            String nom_utilisateur,
 | 
					 | 
				
			||||||
            Long id_utilisateur,
 | 
					 | 
				
			||||||
            String prenom_utilisateur,
 | 
					 | 
				
			||||||
            String mail_principal,
 | 
					 | 
				
			||||||
            String mail_secondaire,
 | 
					 | 
				
			||||||
            String numero_telephone) {
 | 
					 | 
				
			||||||
        super(
 | 
					 | 
				
			||||||
                nom_utilisateur,
 | 
					 | 
				
			||||||
                id_utilisateur,
 | 
					 | 
				
			||||||
                prenom_utilisateur,
 | 
					 | 
				
			||||||
                mail_principal,
 | 
					 | 
				
			||||||
                mail_secondaire,
 | 
					 | 
				
			||||||
                numero_telephone);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,46 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.model;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import jakarta.persistence.*;
 | 
					 | 
				
			||||||
import jakarta.persistence.Entity;
 | 
					 | 
				
			||||||
import jakarta.persistence.Id;
 | 
					 | 
				
			||||||
import jakarta.persistence.Table;
 | 
					 | 
				
			||||||
import jakarta.validation.constraints.NotNull;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@Entity
 | 
					 | 
				
			||||||
@Table(name = "comptes_rendus")
 | 
					 | 
				
			||||||
public class ComptesRendus {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Id
 | 
					 | 
				
			||||||
    @NotNull
 | 
					 | 
				
			||||||
    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
					 | 
				
			||||||
    private Long id_compte_rendu;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private String contenu_compte_rendu;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_rdv")
 | 
					 | 
				
			||||||
    private RendezVous rendezVousComptesRendus;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public ComptesRendus() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public ComptesRendus(Long id_compte_rendu, String contenu_compte_rendu) {
 | 
					 | 
				
			||||||
        this.id_compte_rendu = id_compte_rendu;
 | 
					 | 
				
			||||||
        this.contenu_compte_rendu = contenu_compte_rendu;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Long getId_compte_rendu() {
 | 
					 | 
				
			||||||
        return id_compte_rendu;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setId_compte_rendu(Long id_compte_rendu) {
 | 
					 | 
				
			||||||
        this.id_compte_rendu = id_compte_rendu;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getContenu_compte_rendu() {
 | 
					 | 
				
			||||||
        return contenu_compte_rendu;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setContenu_compte_rendu(String contenu_compte_rendu) {
 | 
					 | 
				
			||||||
        this.contenu_compte_rendu = contenu_compte_rendu;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,80 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.model;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import jakarta.persistence.*;
 | 
					 | 
				
			||||||
import jakarta.persistence.Entity;
 | 
					 | 
				
			||||||
import jakarta.persistence.Table;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@Entity
 | 
					 | 
				
			||||||
@Table(name = "entrepreneurs")
 | 
					 | 
				
			||||||
@PrimaryKeyJoinColumn(name = "id_entrepreneur", referencedColumnName = "id_utilisateur")
 | 
					 | 
				
			||||||
public class Entrepreneurs extends Utilisateurs {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String ecole;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String filiere;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private boolean status_snee;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_projet_participation", referencedColumnName = "id_projet")
 | 
					 | 
				
			||||||
    private Projets projetsParticipation;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // @Column(insertable=false, updatable=false)
 | 
					 | 
				
			||||||
    @OneToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_projet_propose", referencedColumnName = "id_projet")
 | 
					 | 
				
			||||||
    private Projets projetsPropose;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_rdv")
 | 
					 | 
				
			||||||
    private RendezVous rendezVousEntrepreneurs;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Entrepreneurs() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Entrepreneurs(
 | 
					 | 
				
			||||||
            String nom_utilisateur,
 | 
					 | 
				
			||||||
            Long id_utilisateur,
 | 
					 | 
				
			||||||
            String prenom_utilisateur,
 | 
					 | 
				
			||||||
            String mail_principal,
 | 
					 | 
				
			||||||
            String mail_secondaire,
 | 
					 | 
				
			||||||
            String numero_telephone,
 | 
					 | 
				
			||||||
            String ecole,
 | 
					 | 
				
			||||||
            boolean status_snee,
 | 
					 | 
				
			||||||
            String filiere) {
 | 
					 | 
				
			||||||
        super(
 | 
					 | 
				
			||||||
                nom_utilisateur,
 | 
					 | 
				
			||||||
                id_utilisateur,
 | 
					 | 
				
			||||||
                prenom_utilisateur,
 | 
					 | 
				
			||||||
                mail_principal,
 | 
					 | 
				
			||||||
                mail_secondaire,
 | 
					 | 
				
			||||||
                numero_telephone);
 | 
					 | 
				
			||||||
        this.ecole = ecole;
 | 
					 | 
				
			||||||
        this.status_snee = status_snee;
 | 
					 | 
				
			||||||
        this.filiere = filiere;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getEcole() {
 | 
					 | 
				
			||||||
        return ecole;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setEcole(String ecole) {
 | 
					 | 
				
			||||||
        this.ecole = ecole;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getFiliere() {
 | 
					 | 
				
			||||||
        return filiere;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setFiliere(String filiere) {
 | 
					 | 
				
			||||||
        this.filiere = filiere;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public boolean isStatus_snee() {
 | 
					 | 
				
			||||||
        return status_snee;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setStatus_snee(boolean status_snee) {
 | 
					 | 
				
			||||||
        this.status_snee = status_snee;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,98 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.model;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import jakarta.persistence.*;
 | 
					 | 
				
			||||||
import jakarta.validation.constraints.NotNull;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.time.LocalDate;
 | 
					 | 
				
			||||||
import java.util.ArrayList;
 | 
					 | 
				
			||||||
import java.util.List;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@Entity
 | 
					 | 
				
			||||||
@Table(name = "projets")
 | 
					 | 
				
			||||||
public class Projets {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Id
 | 
					 | 
				
			||||||
    @NotNull
 | 
					 | 
				
			||||||
    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
					 | 
				
			||||||
    private Long id_projet;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String nom_projet;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private byte[] logo;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private LocalDate date_creation;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String status_projet;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToMany(mappedBy = "projetsAdministrateurs", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private List<Administrateurs> listAdministrateurs = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToMany(mappedBy = "projetsParticipation", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private List<Entrepreneurs> ListEntrepreneursParticipation = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToOne(mappedBy = "projetsPropose", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private Entrepreneurs entrepreneursPropose;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToMany(mappedBy = "projetsSections", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private List<Sections> ListSections = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    // Hibernate expects entities to have a no-arg constructor,
 | 
					 | 
				
			||||||
    // though it does not necessarily have to be public.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Projets() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Projets(
 | 
					 | 
				
			||||||
            Long id_projet,
 | 
					 | 
				
			||||||
            String nom_projet,
 | 
					 | 
				
			||||||
            byte[] logo,
 | 
					 | 
				
			||||||
            LocalDate date_creation,
 | 
					 | 
				
			||||||
            String status_projet) {
 | 
					 | 
				
			||||||
        this.id_projet = id_projet;
 | 
					 | 
				
			||||||
        this.nom_projet = nom_projet;
 | 
					 | 
				
			||||||
        this.logo = logo;
 | 
					 | 
				
			||||||
        this.date_creation = date_creation;
 | 
					 | 
				
			||||||
        this.status_projet = status_projet;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Long getId_projet() {
 | 
					 | 
				
			||||||
        return id_projet;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setId_projet(Long id_projet) {
 | 
					 | 
				
			||||||
        this.id_projet = id_projet;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getNom_projet() {
 | 
					 | 
				
			||||||
        return nom_projet;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setNom_projet(String nom_projet) {
 | 
					 | 
				
			||||||
        this.nom_projet = nom_projet;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public byte[] getLogo() {
 | 
					 | 
				
			||||||
        return logo;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setLogo(byte[] logo) {
 | 
					 | 
				
			||||||
        this.logo = logo;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public LocalDate getDate_creation() {
 | 
					 | 
				
			||||||
        return date_creation;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setDate_creation(LocalDate date_creation) {
 | 
					 | 
				
			||||||
        this.date_creation = date_creation;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getStatus_projet() {
 | 
					 | 
				
			||||||
        return status_projet;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setStatus_projet(String status_projet) {
 | 
					 | 
				
			||||||
        this.status_projet = status_projet;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,111 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.model;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import jakarta.persistence.*;
 | 
					 | 
				
			||||||
import jakarta.validation.constraints.NotNull;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.time.LocalDate;
 | 
					 | 
				
			||||||
import java.time.LocalTime;
 | 
					 | 
				
			||||||
import java.util.ArrayList;
 | 
					 | 
				
			||||||
import java.util.List;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@Entity
 | 
					 | 
				
			||||||
@Table(name = "rendez_vous")
 | 
					 | 
				
			||||||
public class RendezVous {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToMany(mappedBy = "rendezVousEntrepreneurs", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private final List<Entrepreneurs> ListEntrepreneurs = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToMany(mappedBy = "rendezVousAdministrateurs", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private final List<Administrateurs> ListAdministrateurs = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @OneToMany(mappedBy = "rendezVousComptesRendus", fetch = FetchType.LAZY, orphanRemoval = true)
 | 
					 | 
				
			||||||
    private final List<ComptesRendus> ListComptesRendus = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToMany(
 | 
					 | 
				
			||||||
            fetch = FetchType.LAZY,
 | 
					 | 
				
			||||||
            cascade = {CascadeType.ALL})
 | 
					 | 
				
			||||||
    @JoinTable(
 | 
					 | 
				
			||||||
            name = "concerner",
 | 
					 | 
				
			||||||
            joinColumns = @JoinColumn(name = "id_rdv"),
 | 
					 | 
				
			||||||
            inverseJoinColumns = @JoinColumn(name = "id_section"))
 | 
					 | 
				
			||||||
    List<Sections> ListSections = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Id
 | 
					 | 
				
			||||||
    @NotNull
 | 
					 | 
				
			||||||
    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
					 | 
				
			||||||
    private Long id_rdv;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private LocalDate date_rdv;
 | 
					 | 
				
			||||||
    private LocalTime heure_rdv;
 | 
					 | 
				
			||||||
    private LocalTime duree_rdv;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String lieu_rdv;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private String sujet_rdv;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public RendezVous() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public RendezVous(
 | 
					 | 
				
			||||||
            Long id_rdv,
 | 
					 | 
				
			||||||
            LocalDate date_rdv,
 | 
					 | 
				
			||||||
            LocalTime heure_rdv,
 | 
					 | 
				
			||||||
            LocalTime duree_rdv,
 | 
					 | 
				
			||||||
            String lieu_rdv,
 | 
					 | 
				
			||||||
            String sujet_rdv) {
 | 
					 | 
				
			||||||
        this.id_rdv = id_rdv;
 | 
					 | 
				
			||||||
        this.date_rdv = date_rdv;
 | 
					 | 
				
			||||||
        this.heure_rdv = heure_rdv;
 | 
					 | 
				
			||||||
        this.duree_rdv = duree_rdv;
 | 
					 | 
				
			||||||
        this.lieu_rdv = lieu_rdv;
 | 
					 | 
				
			||||||
        this.sujet_rdv = sujet_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Long getId_rdv() {
 | 
					 | 
				
			||||||
        return id_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setId_rdv(Long id_rdv) {
 | 
					 | 
				
			||||||
        this.id_rdv = id_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public LocalDate getDate_rdv() {
 | 
					 | 
				
			||||||
        return date_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setDate_rdv(LocalDate date_rdv) {
 | 
					 | 
				
			||||||
        this.date_rdv = date_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public LocalTime getHeure_rdv() {
 | 
					 | 
				
			||||||
        return heure_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setHeure_rdv(LocalTime heure_rdv) {
 | 
					 | 
				
			||||||
        this.heure_rdv = heure_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public LocalTime getDuree_rdv() {
 | 
					 | 
				
			||||||
        return duree_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setDuree_rdv(LocalTime duree_rdv) {
 | 
					 | 
				
			||||||
        this.duree_rdv = duree_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getLieu_rdv() {
 | 
					 | 
				
			||||||
        return lieu_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setLieu_rdv(String lieu_rdv) {
 | 
					 | 
				
			||||||
        this.lieu_rdv = lieu_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getSujet_rdv() {
 | 
					 | 
				
			||||||
        return sujet_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setSujet_rdv(String sujet_rdv) {
 | 
					 | 
				
			||||||
        this.sujet_rdv = sujet_rdv;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,81 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.model;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import jakarta.persistence.*;
 | 
					 | 
				
			||||||
import jakarta.validation.constraints.NotNull;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import java.time.LocalDateTime;
 | 
					 | 
				
			||||||
import java.util.ArrayList;
 | 
					 | 
				
			||||||
import java.util.List;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@Entity
 | 
					 | 
				
			||||||
@Table(name = "sections")
 | 
					 | 
				
			||||||
public class Sections {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Id
 | 
					 | 
				
			||||||
    @NotNull
 | 
					 | 
				
			||||||
    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
					 | 
				
			||||||
    private Long id_section;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String titre;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private String contenu_section;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    private LocalDateTime date_modification;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_projet")
 | 
					 | 
				
			||||||
    private Projets projetsSections;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToOne(fetch = FetchType.LAZY)
 | 
					 | 
				
			||||||
    @JoinColumn(name = "id_admnistrateur")
 | 
					 | 
				
			||||||
    private Administrateurs administrateursSections;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @ManyToMany(mappedBy = "ListSections")
 | 
					 | 
				
			||||||
    private List<RendezVous> rendezVous = new ArrayList<>();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Sections() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Sections(
 | 
					 | 
				
			||||||
            Long id_section,
 | 
					 | 
				
			||||||
            String titre,
 | 
					 | 
				
			||||||
            String contenu_section,
 | 
					 | 
				
			||||||
            LocalDateTime date_modification) {
 | 
					 | 
				
			||||||
        this.id_section = id_section;
 | 
					 | 
				
			||||||
        this.titre = titre;
 | 
					 | 
				
			||||||
        this.contenu_section = contenu_section;
 | 
					 | 
				
			||||||
        this.date_modification = date_modification;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getTitre() {
 | 
					 | 
				
			||||||
        return titre;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setTitre(String titre) {
 | 
					 | 
				
			||||||
        this.titre = titre;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Long getId_section() {
 | 
					 | 
				
			||||||
        return id_section;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setId_section(Long id_section) {
 | 
					 | 
				
			||||||
        this.id_section = id_section;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getContenu_section() {
 | 
					 | 
				
			||||||
        return contenu_section;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setContenu_section(String contenu_section) {
 | 
					 | 
				
			||||||
        this.contenu_section = contenu_section;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public LocalDateTime getDate_modification() {
 | 
					 | 
				
			||||||
        return date_modification;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setDate_modification(LocalDateTime date_modification) {
 | 
					 | 
				
			||||||
        this.date_modification = date_modification;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,95 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.model;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import jakarta.persistence.*;
 | 
					 | 
				
			||||||
import jakarta.validation.constraints.NotNull;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@Entity
 | 
					 | 
				
			||||||
@Table(name = "utilisateurs")
 | 
					 | 
				
			||||||
@Inheritance(strategy = InheritanceType.JOINED)
 | 
					 | 
				
			||||||
public class Utilisateurs {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Id
 | 
					 | 
				
			||||||
    @NotNull
 | 
					 | 
				
			||||||
    @GeneratedValue(strategy = GenerationType.IDENTITY)
 | 
					 | 
				
			||||||
    private Long id_utilisateur;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String nom_utilisateur;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String prenom_utilisateur;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String mail_principal;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 255)
 | 
					 | 
				
			||||||
    private String mail_secondaire;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Column(length = 20)
 | 
					 | 
				
			||||||
    private String numero_telephone;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Utilisateurs() {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Utilisateurs(
 | 
					 | 
				
			||||||
            String nom_utilisateur,
 | 
					 | 
				
			||||||
            Long id_utilisateur,
 | 
					 | 
				
			||||||
            String prenom_utilisateur,
 | 
					 | 
				
			||||||
            String mail_principal,
 | 
					 | 
				
			||||||
            String mail_secondaire,
 | 
					 | 
				
			||||||
            String numero_telephone) {
 | 
					 | 
				
			||||||
        this.nom_utilisateur = nom_utilisateur;
 | 
					 | 
				
			||||||
        this.id_utilisateur = id_utilisateur;
 | 
					 | 
				
			||||||
        this.prenom_utilisateur = prenom_utilisateur;
 | 
					 | 
				
			||||||
        this.mail_principal = mail_principal;
 | 
					 | 
				
			||||||
        this.mail_secondaire = mail_secondaire;
 | 
					 | 
				
			||||||
        this.numero_telephone = numero_telephone;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public Long getId_utilisateur() {
 | 
					 | 
				
			||||||
        return id_utilisateur;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setId_utilisateur(Long id_utilisateur) {
 | 
					 | 
				
			||||||
        this.id_utilisateur = id_utilisateur;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getNom_utilisateur() {
 | 
					 | 
				
			||||||
        return nom_utilisateur;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setNom_utilisateur(String nom_utilisateur) {
 | 
					 | 
				
			||||||
        this.nom_utilisateur = nom_utilisateur;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getPrenom_utilisateur() {
 | 
					 | 
				
			||||||
        return prenom_utilisateur;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setPrenom_utilisateur(String prenom_utilisateur) {
 | 
					 | 
				
			||||||
        this.prenom_utilisateur = prenom_utilisateur;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getMail_principal() {
 | 
					 | 
				
			||||||
        return mail_principal;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setMail_principal(String mail_principal) {
 | 
					 | 
				
			||||||
        this.mail_principal = mail_principal;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getMail_secondaire() {
 | 
					 | 
				
			||||||
        return mail_secondaire;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setMail_secondaire(String mail_secondaire) {
 | 
					 | 
				
			||||||
        this.mail_secondaire = mail_secondaire;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public String getNumero_telephone() {
 | 
					 | 
				
			||||||
        return numero_telephone;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public void setNumero_telephone(String numero_telephone) {
 | 
					 | 
				
			||||||
        this.numero_telephone = numero_telephone;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,14 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.repository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Administrateurs;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.data.jpa.repository.JpaRepository;
 | 
					 | 
				
			||||||
import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RepositoryRestResource
 | 
					 | 
				
			||||||
public interface AdministrateursRepository extends JpaRepository<Administrateurs, Long> {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /* @Query("SELECT a from Administrateurs a")
 | 
					 | 
				
			||||||
    Administrateurs findAllAdministrateurs(); */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,9 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.repository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.ComptesRendus;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.data.jpa.repository.JpaRepository;
 | 
					 | 
				
			||||||
import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RepositoryRestResource
 | 
					 | 
				
			||||||
public interface ComptesRendusRepository extends JpaRepository<ComptesRendus, Long> {}
 | 
					 | 
				
			||||||
@@ -1,14 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.repository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Entrepreneurs;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.data.jpa.repository.JpaRepository;
 | 
					 | 
				
			||||||
import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RepositoryRestResource
 | 
					 | 
				
			||||||
public interface EntrepreneursRepository extends JpaRepository<Entrepreneurs, Long> {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /* @Query("SELECT e from Entrepreneurs e")
 | 
					 | 
				
			||||||
    Entrepreneurs findAllEntrepreneurs(); */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,9 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.repository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Projets;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.data.jpa.repository.JpaRepository;
 | 
					 | 
				
			||||||
import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RepositoryRestResource
 | 
					 | 
				
			||||||
public interface ProjetsRepository extends JpaRepository<Projets, Long> {}
 | 
					 | 
				
			||||||
@@ -1,9 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.repository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.RendezVous;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.data.jpa.repository.JpaRepository;
 | 
					 | 
				
			||||||
import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RepositoryRestResource
 | 
					 | 
				
			||||||
public interface RendezVousRepository extends JpaRepository<RendezVous, Long> {}
 | 
					 | 
				
			||||||
@@ -1,9 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.repository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Sections;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.data.jpa.repository.JpaRepository;
 | 
					 | 
				
			||||||
import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RepositoryRestResource
 | 
					 | 
				
			||||||
public interface SectionsRepository extends JpaRepository<Sections, Long> {}
 | 
					 | 
				
			||||||
@@ -1,14 +0,0 @@
 | 
				
			|||||||
package enseirb.myinpulse.postgres_db.repository;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import enseirb.myinpulse.postgres_db.model.Utilisateurs;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import org.springframework.data.jpa.repository.JpaRepository;
 | 
					 | 
				
			||||||
import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@RepositoryRestResource
 | 
					 | 
				
			||||||
public interface UtilisateursRepository extends JpaRepository<Utilisateurs, Long> {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /* @Query("SELECT u from Utilisateurs u")
 | 
					 | 
				
			||||||
    Utilisateurs findAllUtilisateurs(); */
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -0,0 +1,17 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Administrator;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface AdministratorRepository extends JpaRepository<Administrator, Long> {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* @Query("SELECT a from Administrators a")
 | 
				
			||||||
 | 
					    Administrator findAllAdministrator(); */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Optional<Administrator> findByPrimaryMail(String PrimaryMail);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Annotation;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface AnnotationRepository extends JpaRepository<Annotation, Long> {}
 | 
				
			||||||
@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Appointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface AppointmentRepository extends JpaRepository<Appointment, Long> {}
 | 
				
			||||||
@@ -0,0 +1,17 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Entrepreneur;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface EntrepreneurRepository extends JpaRepository<Entrepreneur, Long> {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Iterable<Entrepreneur> getEntrepreneurByProjectParticipation(Project project);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* @Query("SELECT e from Entrepreneur e")
 | 
				
			||||||
 | 
					    Entrepreneur findAllEntrepreneurl(); */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.MakeAppointment;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface MakeAppointmentRepository extends JpaRepository<MakeAppointment, Long> {}
 | 
				
			||||||
@@ -0,0 +1,19 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Administrator;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.ProjectDecisionValue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface ProjectRepository extends JpaRepository<Project, Long> {
 | 
				
			||||||
 | 
					    Iterable<Project> findByProjectAdministrator(Administrator administrator);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Iterable<Project> findByProjectStatus(ProjectDecisionValue status);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Optional<Project> findByProjectName(String projectName);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Report;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface ReportRepository extends JpaRepository<Report, Long> {}
 | 
				
			||||||
@@ -0,0 +1,18 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.SectionCell;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDateTime;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface SectionCellRepository extends JpaRepository<SectionCell, Long> {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Iterable<SectionCell> findByProjectSectionCellAndSectionId(Project project, long sectionId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Iterable<SectionCell> findByProjectSectionCellAndSectionIdAndModificationDateBefore(
 | 
				
			||||||
 | 
					            Project project, long sectionId, LocalDateTime date);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,17 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.repository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.User;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.springframework.data.jpa.repository.JpaRepository;
 | 
				
			||||||
 | 
					import org.springframework.data.rest.core.annotation.RepositoryRestResource;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@RepositoryRestResource
 | 
				
			||||||
 | 
					public interface UserRepository extends JpaRepository<User, Long> {
 | 
				
			||||||
 | 
					    Optional<User> findByPrimaryMail(String email);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /* @Query("SELECT u from User u")
 | 
				
			||||||
 | 
					    User findAllUser(); */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,136 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import static enseirb.myinpulse.model.ProjectDecisionValue.ACTIVE;
 | 
				
			||||||
 | 
					import static enseirb.myinpulse.model.ProjectDecisionValue.REJECTED;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.*;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.AdministratorService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.AppointmentService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.ProjectService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.ReportService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.UserService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class AdminApiService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final ProjectService projectService;
 | 
				
			||||||
 | 
					    private final UserService userService;
 | 
				
			||||||
 | 
					    private final AdministratorService administratorService;
 | 
				
			||||||
 | 
					    private final UtilsService utilsService;
 | 
				
			||||||
 | 
					    private final AppointmentService appointmentService;
 | 
				
			||||||
 | 
					    private final ReportService reportService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    AdminApiService(
 | 
				
			||||||
 | 
					            ProjectService projectService,
 | 
				
			||||||
 | 
					            UserService userService,
 | 
				
			||||||
 | 
					            AdministratorService administratorService,
 | 
				
			||||||
 | 
					            UtilsService utilsService,
 | 
				
			||||||
 | 
					            AppointmentService appointmentService,
 | 
				
			||||||
 | 
					            ReportService reportService) {
 | 
				
			||||||
 | 
					        this.projectService = projectService;
 | 
				
			||||||
 | 
					        this.userService = userService;
 | 
				
			||||||
 | 
					        this.administratorService = administratorService;
 | 
				
			||||||
 | 
					        this.utilsService = utilsService;
 | 
				
			||||||
 | 
					        this.appointmentService = appointmentService;
 | 
				
			||||||
 | 
					        this.reportService = reportService;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: check if tests are sufficient - peer verification required
 | 
				
			||||||
 | 
					    public Iterable<Project> getProjectsOfAdmin(String mail) {
 | 
				
			||||||
 | 
					        return projectService.getProjectsByAdminId(
 | 
				
			||||||
 | 
					                administratorService.getAdministratorById(
 | 
				
			||||||
 | 
					                        this.userService.getUserByEmail(mail).getIdUser()));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO
 | 
				
			||||||
 | 
					    public Iterable<Appointment> getUpcomingAppointments(String mail) {
 | 
				
			||||||
 | 
					        logger.info("User {} check their upcoming appointments", mail);
 | 
				
			||||||
 | 
					        throw new ResponseStatusException(HttpStatus.NOT_IMPLEMENTED, "Not implemented yet");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: check if tests are sufficient - peer verification required
 | 
				
			||||||
 | 
					    public Iterable<Project> getPendingProjects() {
 | 
				
			||||||
 | 
					        return this.projectService.getPendingProjects();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: check if tests are sufficient - peer verification required
 | 
				
			||||||
 | 
					    public void validateProject(ProjectDecision decision) {
 | 
				
			||||||
 | 
					        projectService.updateProject(
 | 
				
			||||||
 | 
					                decision.projectId,
 | 
				
			||||||
 | 
					                null,
 | 
				
			||||||
 | 
					                null,
 | 
				
			||||||
 | 
					                null,
 | 
				
			||||||
 | 
					                (decision.isAccepted == 1) ? ACTIVE : REJECTED,
 | 
				
			||||||
 | 
					                this.administratorService.getAdministratorById(decision.adminId));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: check if tests are sufficient - peer verification required
 | 
				
			||||||
 | 
					    public void addNewProject(Project project) {
 | 
				
			||||||
 | 
					        project.setIdProject(null);
 | 
				
			||||||
 | 
					        // We remove the ID from the request to be sure that it will be auto generated
 | 
				
			||||||
 | 
					        try {
 | 
				
			||||||
 | 
					            this.projectService.getProjectByName(project.getProjectName(), true);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.CONFLICT, "Project already exists");
 | 
				
			||||||
 | 
					        } catch (ResponseStatusException e) {
 | 
				
			||||||
 | 
					            if (e.getStatusCode() == HttpStatus.CONFLICT) {
 | 
				
			||||||
 | 
					                throw new ResponseStatusException(HttpStatus.CONFLICT, "Project already exists");
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        Project newProject = projectService.addNewProject(project);
 | 
				
			||||||
 | 
					        if (project.getProjectAdministrator() != null) {
 | 
				
			||||||
 | 
					            newProject.getProjectAdministrator().updateListProject(newProject);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (newProject.getEntrepreneurProposed() != null) {
 | 
				
			||||||
 | 
					            newProject.getEntrepreneurProposed().setProjectProposed(newProject);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        newProject
 | 
				
			||||||
 | 
					                .getListEntrepreneurParticipation()
 | 
				
			||||||
 | 
					                .forEach(
 | 
				
			||||||
 | 
					                        participation -> {
 | 
				
			||||||
 | 
					                            participation.setProjectParticipation(newProject);
 | 
				
			||||||
 | 
					                        });
 | 
				
			||||||
 | 
					        newProject
 | 
				
			||||||
 | 
					                .getListSectionCell()
 | 
				
			||||||
 | 
					                .forEach(
 | 
				
			||||||
 | 
					                        sectionCell -> {
 | 
				
			||||||
 | 
					                            sectionCell.setProjectSectionCell(newProject);
 | 
				
			||||||
 | 
					                        });
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void createAppointmentReport(long appointmentId, Report report, String mail) {
 | 
				
			||||||
 | 
					        long projectId =
 | 
				
			||||||
 | 
					                this.appointmentService
 | 
				
			||||||
 | 
					                        .getAppointmentById(appointmentId)
 | 
				
			||||||
 | 
					                        .getAppointmentListSectionCell()
 | 
				
			||||||
 | 
					                        .getFirst()
 | 
				
			||||||
 | 
					                        .getProjectSectionCell()
 | 
				
			||||||
 | 
					                        .getIdProject();
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(mail, projectId)) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to add an report for appointment {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    projectId);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info("User {} added a report for appointment {}", mail, projectId);
 | 
				
			||||||
 | 
					        Report addedReport = this.reportService.addNewReport(report);
 | 
				
			||||||
 | 
					        addedReport.setAppointmentReport(this.appointmentService.getAppointmentById(appointmentId));
 | 
				
			||||||
 | 
					        this.appointmentService.getAppointmentById(appointmentId).setAppointmentReport(addedReport);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: test
 | 
				
			||||||
 | 
					    public void deleteProject(long projectId) {
 | 
				
			||||||
 | 
					        this.projectService.deleteProjectById(projectId);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,135 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import static enseirb.myinpulse.model.ProjectDecisionValue.PENDING;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.SectionCell;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.ProjectService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.SectionCellService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class EntrepreneurApiService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final SectionCellService sectionCellService;
 | 
				
			||||||
 | 
					    private final ProjectService projectService;
 | 
				
			||||||
 | 
					    private final UtilsService utilsService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    EntrepreneurApiService(
 | 
				
			||||||
 | 
					            SectionCellService sectionCellService,
 | 
				
			||||||
 | 
					            ProjectService projectService,
 | 
				
			||||||
 | 
					            UtilsService utilsService) {
 | 
				
			||||||
 | 
					        this.sectionCellService = sectionCellService;
 | 
				
			||||||
 | 
					        this.projectService = projectService;
 | 
				
			||||||
 | 
					        this.utilsService = utilsService;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void editSectionCell(Long sectionCellId, SectionCell sectionCell, String mail) {
 | 
				
			||||||
 | 
					        SectionCell editSectionCell = sectionCellService.getSectionCellById(sectionCellId);
 | 
				
			||||||
 | 
					        if (editSectionCell == null) {
 | 
				
			||||||
 | 
					            System.err.println("Trying to edit unknown section cell");
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cette cellule de section n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(
 | 
				
			||||||
 | 
					                mail, this.sectionCellService.getProjectId(sectionCellId))) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to edit section cells {} of the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    sectionCellId,
 | 
				
			||||||
 | 
					                    this.sectionCellService.getProjectId(sectionCellId));
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info(
 | 
				
			||||||
 | 
					                "User {} edited section cell {} of the project with id {}",
 | 
				
			||||||
 | 
					                mail,
 | 
				
			||||||
 | 
					                sectionCellId,
 | 
				
			||||||
 | 
					                this.sectionCellService.getProjectId(sectionCellId));
 | 
				
			||||||
 | 
					        sectionCellService.updateSectionCell(
 | 
				
			||||||
 | 
					                sectionCellId,
 | 
				
			||||||
 | 
					                sectionCell.getSectionId(),
 | 
				
			||||||
 | 
					                sectionCell.getContentSectionCell(),
 | 
				
			||||||
 | 
					                sectionCell.getModificationDate());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void removeSectionCell(Long sectionCellId, String mail) {
 | 
				
			||||||
 | 
					        SectionCell editSectionCell = sectionCellService.getSectionCellById(sectionCellId);
 | 
				
			||||||
 | 
					        if (editSectionCell == null) {
 | 
				
			||||||
 | 
					            System.err.println("Trying to remove unknown section cell");
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cette cellule de section n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(
 | 
				
			||||||
 | 
					                mail, this.sectionCellService.getProjectId(sectionCellId))) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to remove section cells {} of the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    sectionCellId,
 | 
				
			||||||
 | 
					                    this.sectionCellService.getSectionCellById(sectionCellId));
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info(
 | 
				
			||||||
 | 
					                "User {} removed section cell {} of the project with id {}",
 | 
				
			||||||
 | 
					                mail,
 | 
				
			||||||
 | 
					                sectionCellId,
 | 
				
			||||||
 | 
					                this.sectionCellService.getProjectId(sectionCellId));
 | 
				
			||||||
 | 
					        sectionCellService.removeSectionCellById(sectionCellId);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void addSectionCell(SectionCell sectionCell, String mail) {
 | 
				
			||||||
 | 
					        if (sectionCell == null) {
 | 
				
			||||||
 | 
					            System.err.println("Trying to create an empty section cell");
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.BAD_REQUEST, "La cellule de section fournie est vide");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(
 | 
				
			||||||
 | 
					                mail, this.sectionCellService.getProjectId(sectionCell.getIdSectionCell()))) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to add a section cell to the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    this.sectionCellService.getProjectId(sectionCell.getIdSectionCell()));
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info(
 | 
				
			||||||
 | 
					                "User {} added a new section cell {} to the project with id {}",
 | 
				
			||||||
 | 
					                mail,
 | 
				
			||||||
 | 
					                sectionCell.getIdSectionCell(),
 | 
				
			||||||
 | 
					                this.sectionCellService.getProjectId(sectionCell.getIdSectionCell()));
 | 
				
			||||||
 | 
					        SectionCell newSectionCell = sectionCellService.addNewSectionCell(sectionCell);
 | 
				
			||||||
 | 
					        newSectionCell.getProjectSectionCell().updateListSectionCell(newSectionCell);
 | 
				
			||||||
 | 
					        newSectionCell
 | 
				
			||||||
 | 
					                .getAppointmentSectionCell()
 | 
				
			||||||
 | 
					                .forEach(
 | 
				
			||||||
 | 
					                        appointment -> {
 | 
				
			||||||
 | 
					                            appointment.updateListSectionCell(newSectionCell);
 | 
				
			||||||
 | 
					                        });
 | 
				
			||||||
 | 
					        newSectionCell
 | 
				
			||||||
 | 
					                .getListAnnotation()
 | 
				
			||||||
 | 
					                .forEach(
 | 
				
			||||||
 | 
					                        annotation -> {
 | 
				
			||||||
 | 
					                            annotation.setSectionCellAnnotation(newSectionCell);
 | 
				
			||||||
 | 
					                        });
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void requestNewProject(Project project, String mail) {
 | 
				
			||||||
 | 
					        if (project == null) {
 | 
				
			||||||
 | 
					            logger.error("Trying to request the creation of a null project");
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Le projet fourni est vide");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info("User {} created a new project with id {}", mail, project.getIdProject());
 | 
				
			||||||
 | 
					        project.setProjectStatus(PENDING);
 | 
				
			||||||
 | 
					        projectService.addNewProject(project);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,10 +1,10 @@
 | 
				
			|||||||
package enseirb.myinpulse.utils.keycloak;
 | 
					package enseirb.myinpulse.service;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import static org.springframework.http.MediaType.APPLICATION_JSON;
 | 
					import static org.springframework.http.MediaType.APPLICATION_JSON;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import enseirb.myinpulse.exceptions.UserNotFoundException;
 | 
					import enseirb.myinpulse.exception.UserNotFoundException;
 | 
				
			||||||
import enseirb.myinpulse.utils.keycloak.datatypes.RoleRepresentation;
 | 
					import enseirb.myinpulse.model.RoleRepresentation;
 | 
				
			||||||
import enseirb.myinpulse.utils.keycloak.datatypes.UserRepresentation;
 | 
					import enseirb.myinpulse.model.UserRepresentation;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.springframework.web.client.RestClient;
 | 
					import org.springframework.web.client.RestClient;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -0,0 +1,233 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.itextpdf.text.*;
 | 
				
			||||||
 | 
					import com.itextpdf.text.pdf.PdfWriter;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.*;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.io.FileNotFoundException;
 | 
				
			||||||
 | 
					import java.io.FileOutputStream;
 | 
				
			||||||
 | 
					import java.time.LocalDateTime;
 | 
				
			||||||
 | 
					import java.time.format.DateTimeFormatter;
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class SharedApiService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final ProjectService projectService;
 | 
				
			||||||
 | 
					    private final EntrepreneurService entrepreneurService;
 | 
				
			||||||
 | 
					    private final SectionCellService sectionCellService;
 | 
				
			||||||
 | 
					    private final AppointmentService appointmentService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final UtilsService utilsService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    SharedApiService(
 | 
				
			||||||
 | 
					            ProjectService projectService,
 | 
				
			||||||
 | 
					            EntrepreneurService entrepreneurService,
 | 
				
			||||||
 | 
					            SectionCellService sectionCellService,
 | 
				
			||||||
 | 
					            AppointmentService appointmentService,
 | 
				
			||||||
 | 
					            UtilsService utilsService) {
 | 
				
			||||||
 | 
					        this.projectService = projectService;
 | 
				
			||||||
 | 
					        this.entrepreneurService = entrepreneurService;
 | 
				
			||||||
 | 
					        this.sectionCellService = sectionCellService;
 | 
				
			||||||
 | 
					        this.appointmentService = appointmentService;
 | 
				
			||||||
 | 
					        this.utilsService = utilsService;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO filter this with date
 | 
				
			||||||
 | 
					    public Iterable<SectionCell> getSectionCells(
 | 
				
			||||||
 | 
					            long projectId, long sectionId, String date, String mail) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(mail, projectId)) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to check section cells of the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    projectId);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm");
 | 
				
			||||||
 | 
					        LocalDateTime dateTime = LocalDateTime.parse(date, formatter);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        Project project = this.projectService.getProjectById(projectId);
 | 
				
			||||||
 | 
					        return this.sectionCellService.getSectionCellsByProjectAndSectionIdBeforeDate(
 | 
				
			||||||
 | 
					                project, sectionId, dateTime);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: test
 | 
				
			||||||
 | 
					    public Iterable<Entrepreneur> getEntrepreneursByProjectId(long projectId, String mail) {
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(mail, projectId)) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to check the member of the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    projectId);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        Project project = this.projectService.getProjectById(projectId);
 | 
				
			||||||
 | 
					        return this.entrepreneurService.GetEntrepreneurByProject(project);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: test
 | 
				
			||||||
 | 
					    public Administrator getAdminByProjectId(long projectId, String mail) {
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(mail, projectId)) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to check the admin of the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    projectId);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        Project project = this.projectService.getProjectById(projectId);
 | 
				
			||||||
 | 
					        return project.getProjectAdministrator();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO
 | 
				
			||||||
 | 
					    public Iterable<Appointment> getAppointmentsByProjectId(long projectId, String mail) {
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(mail, projectId)) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to check the appointments related to the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    projectId);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info(
 | 
				
			||||||
 | 
					                "User {} tried to check the appointments related to the project {}",
 | 
				
			||||||
 | 
					                mail,
 | 
				
			||||||
 | 
					                projectId);
 | 
				
			||||||
 | 
					        Iterable<SectionCell> sectionCells =
 | 
				
			||||||
 | 
					                this.sectionCellService.getSectionCellsByProject(
 | 
				
			||||||
 | 
					                        projectService.getProjectById(projectId),
 | 
				
			||||||
 | 
					                        2L); // sectionId useless in this function ?
 | 
				
			||||||
 | 
					        List<Appointment> appointments = new ArrayList<Appointment>();
 | 
				
			||||||
 | 
					        sectionCells.forEach(
 | 
				
			||||||
 | 
					                sectionCell -> {
 | 
				
			||||||
 | 
					                    appointments.addAll(
 | 
				
			||||||
 | 
					                            this.sectionCellService.getAppointmentsBySectionCellId(
 | 
				
			||||||
 | 
					                                    sectionCell.getIdSectionCell()));
 | 
				
			||||||
 | 
					                });
 | 
				
			||||||
 | 
					        return appointments;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //
 | 
				
			||||||
 | 
					    public void getPDFReport(long appointmentId, String mail)
 | 
				
			||||||
 | 
					            throws FileNotFoundException, DocumentException {
 | 
				
			||||||
 | 
					        long projectId =
 | 
				
			||||||
 | 
					                this.appointmentService
 | 
				
			||||||
 | 
					                        .getAppointmentById(appointmentId)
 | 
				
			||||||
 | 
					                        .getAppointmentListSectionCell()
 | 
				
			||||||
 | 
					                        .getFirst()
 | 
				
			||||||
 | 
					                        .getProjectSectionCell()
 | 
				
			||||||
 | 
					                        .getIdProject();
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(mail, projectId)) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to generate the PDF report {} related to the appointment {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    this.appointmentService
 | 
				
			||||||
 | 
					                            .getAppointmentById(appointmentId)
 | 
				
			||||||
 | 
					                            .getAppointmentReport()
 | 
				
			||||||
 | 
					                            .getIdReport(),
 | 
				
			||||||
 | 
					                    appointmentId);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info(
 | 
				
			||||||
 | 
					                "User {} generated the PDF report related to appointment {}", mail, appointmentId);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        String reportContent =
 | 
				
			||||||
 | 
					                this.appointmentService
 | 
				
			||||||
 | 
					                        .getAppointmentById(appointmentId)
 | 
				
			||||||
 | 
					                        .getAppointmentReport()
 | 
				
			||||||
 | 
					                        .getReportContent();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // PDF generation
 | 
				
			||||||
 | 
					        Document document = new Document();
 | 
				
			||||||
 | 
					        PdfWriter.getInstance(document, new FileOutputStream("Report" + appointmentId + ".pdf"));
 | 
				
			||||||
 | 
					        document.open();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        Paragraph title =
 | 
				
			||||||
 | 
					                new Paragraph(
 | 
				
			||||||
 | 
					                        new Phrase(
 | 
				
			||||||
 | 
					                                "Compte Rendu - Réunion du "
 | 
				
			||||||
 | 
					                                        + this.appointmentService
 | 
				
			||||||
 | 
					                                                .getAppointmentById(appointmentId)
 | 
				
			||||||
 | 
					                                                .getAppointmentDate()
 | 
				
			||||||
 | 
					                                                .toString(),
 | 
				
			||||||
 | 
					                                FontFactory.getFont(
 | 
				
			||||||
 | 
					                                        FontFactory.HELVETICA,
 | 
				
			||||||
 | 
					                                        20,
 | 
				
			||||||
 | 
					                                        Font.BOLDITALIC,
 | 
				
			||||||
 | 
					                                        BaseColor.BLACK)));
 | 
				
			||||||
 | 
					        title.setAlignment(Element.ALIGN_CENTER);
 | 
				
			||||||
 | 
					        document.add(title);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        Font subsection =
 | 
				
			||||||
 | 
					                FontFactory.getFont(FontFactory.HELVETICA, 14, Font.UNDERLINE, BaseColor.DARK_GRAY);
 | 
				
			||||||
 | 
					        Font body = FontFactory.getFont(FontFactory.COURIER, 12, BaseColor.BLACK);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        String[] split = reportContent.split(" ");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        String tmp = "";
 | 
				
			||||||
 | 
					        int counter = 1;
 | 
				
			||||||
 | 
					        for (String s : split) {
 | 
				
			||||||
 | 
					            if (s.equals("//")) {
 | 
				
			||||||
 | 
					                Chunk chunk = new Chunk(tmp, body);
 | 
				
			||||||
 | 
					                document.add(chunk);
 | 
				
			||||||
 | 
					                document.add(new Paragraph("\n"));
 | 
				
			||||||
 | 
					                tmp = "";
 | 
				
			||||||
 | 
					                Paragraph paragraph = new Paragraph("Point n°" + counter + " : ", subsection);
 | 
				
			||||||
 | 
					                document.add(paragraph);
 | 
				
			||||||
 | 
					                document.add(new Paragraph("\n"));
 | 
				
			||||||
 | 
					                counter++;
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                tmp = tmp.concat(s + " ");
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        Chunk chunk = new Chunk(tmp, body);
 | 
				
			||||||
 | 
					        document.add(chunk);
 | 
				
			||||||
 | 
					        document.add(new Paragraph("\n"));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        document.close();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO
 | 
				
			||||||
 | 
					    public void createAppointmentRequest(Appointment appointment, String mail) {
 | 
				
			||||||
 | 
					        long projectId =
 | 
				
			||||||
 | 
					                appointment
 | 
				
			||||||
 | 
					                        .getAppointmentListSectionCell()
 | 
				
			||||||
 | 
					                        .getFirst()
 | 
				
			||||||
 | 
					                        .getProjectSectionCell()
 | 
				
			||||||
 | 
					                        .getIdProject();
 | 
				
			||||||
 | 
					        if (!utilsService.isAllowedToCheckProject(mail, projectId)) {
 | 
				
			||||||
 | 
					            logger.warn(
 | 
				
			||||||
 | 
					                    "User {} tried to create for the project {} but is not allowed to.",
 | 
				
			||||||
 | 
					                    mail,
 | 
				
			||||||
 | 
					                    projectId);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.UNAUTHORIZED, "You're not allowed to check this project");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        logger.info("User {} tried to create an appointment for project {}", mail, projectId);
 | 
				
			||||||
 | 
					        Appointment newAppointment = this.appointmentService.addNewAppointment(appointment);
 | 
				
			||||||
 | 
					        newAppointment
 | 
				
			||||||
 | 
					                .getAppointmentListSectionCell()
 | 
				
			||||||
 | 
					                .forEach(
 | 
				
			||||||
 | 
					                        sectionCell -> {
 | 
				
			||||||
 | 
					                            sectionCell.updateAppointmentSectionCell(newAppointment);
 | 
				
			||||||
 | 
					                        });
 | 
				
			||||||
 | 
					        newAppointment.getAppointmentReport().setAppointmentReport(newAppointment);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,62 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Administrator;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Entrepreneur;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.User;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.AdministratorService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.EntrepreneurService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.ProjectService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.UserService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class UtilsService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final UserService userService;
 | 
				
			||||||
 | 
					    private final ProjectService projectService;
 | 
				
			||||||
 | 
					    private final EntrepreneurService entrepreneurService;
 | 
				
			||||||
 | 
					    private final AdministratorService administratorService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    UtilsService(
 | 
				
			||||||
 | 
					            ProjectService projectService,
 | 
				
			||||||
 | 
					            UserService userService,
 | 
				
			||||||
 | 
					            EntrepreneurService entrepreneurService,
 | 
				
			||||||
 | 
					            AdministratorService administratorService) {
 | 
				
			||||||
 | 
					        this.userService = userService;
 | 
				
			||||||
 | 
					        this.projectService = projectService;
 | 
				
			||||||
 | 
					        this.entrepreneurService = entrepreneurService;
 | 
				
			||||||
 | 
					        this.administratorService = administratorService;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: test?
 | 
				
			||||||
 | 
					    public Boolean isAllowedToCheckProject(String mail, long projectId) {
 | 
				
			||||||
 | 
					        if (isAnAdmin(mail)) {
 | 
				
			||||||
 | 
					            return true;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        User user = this.userService.getUserByEmail(mail);
 | 
				
			||||||
 | 
					        Entrepreneur entrepreneur = this.entrepreneurService.getEntrepreneurById(user.getIdUser());
 | 
				
			||||||
 | 
					        Project project = this.projectService.getProjectById(projectId);
 | 
				
			||||||
 | 
					        return entrepreneur.getProjectParticipation() == project;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: test
 | 
				
			||||||
 | 
					    Boolean isAnAdmin(String mail) {
 | 
				
			||||||
 | 
					        try {
 | 
				
			||||||
 | 
					            long userId = this.userService.getUserByEmail(mail).getIdUser();
 | 
				
			||||||
 | 
					            Administrator a = this.administratorService.getAdministratorById(userId);
 | 
				
			||||||
 | 
					            return true;
 | 
				
			||||||
 | 
					        } catch (ResponseStatusException e) {
 | 
				
			||||||
 | 
					            logger.info(e);
 | 
				
			||||||
 | 
					            return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,60 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Administrator;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.AdministratorRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class AdministratorService {
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final AdministratorRepository administratorRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    AdministratorService(AdministratorRepository administratorRepository) {
 | 
				
			||||||
 | 
					        this.administratorRepository = administratorRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Administrator> allAdministrators() {
 | 
				
			||||||
 | 
					        return this.administratorRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Administrator getAdministratorById(long id) {
 | 
				
			||||||
 | 
					        Optional<Administrator> administrator = this.administratorRepository.findById(id);
 | 
				
			||||||
 | 
					        if (administrator.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("No administrator found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cet administrateur n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return administrator.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Administrator getAdministratorByPrimaryMain(String primaryMail) {
 | 
				
			||||||
 | 
					        Optional<Administrator> administrator =
 | 
				
			||||||
 | 
					                this.administratorRepository.findByPrimaryMail(primaryMail);
 | 
				
			||||||
 | 
					        if (administrator.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("No administrator found with the mail {}", primaryMail);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cet administrateur n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return administrator.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Administrator addAdministrator(Administrator administrator) {
 | 
				
			||||||
 | 
					        return this.administratorRepository.save(administrator);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    /*
 | 
				
			||||||
 | 
					    public Administrator getAdministratorByProject(Project project) {
 | 
				
			||||||
 | 
					        r
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,61 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Annotation;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.AnnotationRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class AnnotationService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final AnnotationRepository annotationRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    AnnotationService(AnnotationRepository annotationRepository) {
 | 
				
			||||||
 | 
					        this.annotationRepository = annotationRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Annotation> getAllAnnotations() {
 | 
				
			||||||
 | 
					        return annotationRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Annotation getAnnotationById(Long id) {
 | 
				
			||||||
 | 
					        Optional<Annotation> annotation = annotationRepository.findById(id);
 | 
				
			||||||
 | 
					        if (annotation.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("getAnnotationById : No annotation found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cette annotation n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return annotation.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Annotation addNewAnnotation(Annotation annotation) {
 | 
				
			||||||
 | 
					        return this.annotationRepository.save(annotation);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void deleteAnnotationById(Long id) {
 | 
				
			||||||
 | 
					        this.annotationRepository.deleteById(id);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Annotation updateAnnotation(Long id, String comment) {
 | 
				
			||||||
 | 
					        Optional<Annotation> annotation = annotationRepository.findById(id);
 | 
				
			||||||
 | 
					        if (annotation.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("updateAnnotation : No annotation found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cette annotation n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (comment != null) {
 | 
				
			||||||
 | 
					            annotation.get().setComment(comment);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return this.annotationRepository.save(annotation.get());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,79 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Appointment;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.AppointmentRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDate;
 | 
				
			||||||
 | 
					import java.time.LocalTime;
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class AppointmentService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private static final Logger logger = LogManager.getLogger(AppointmentService.class);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private AppointmentRepository appointmentRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    AppointmentService(AppointmentRepository appointmentRepository) {
 | 
				
			||||||
 | 
					        this.appointmentRepository = appointmentRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Appointment> getallAppointments() {
 | 
				
			||||||
 | 
					        return this.appointmentRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Appointment getAppointmentById(Long id) {
 | 
				
			||||||
 | 
					        Optional<Appointment> appointment = this.appointmentRepository.findById(id);
 | 
				
			||||||
 | 
					        if (appointment.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("getAppointmentById : No appointment found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce rendez vous n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return appointment.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Appointment addNewAppointment(Appointment appointment) {
 | 
				
			||||||
 | 
					        return this.appointmentRepository.save(appointment);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void deleteAppointmentById(Long id) {
 | 
				
			||||||
 | 
					        this.appointmentRepository.deleteById(id);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Appointment updateAppointment(
 | 
				
			||||||
 | 
					            Long id,
 | 
				
			||||||
 | 
					            LocalDate appointmentDate,
 | 
				
			||||||
 | 
					            LocalTime appointmentTime,
 | 
				
			||||||
 | 
					            LocalTime appointmentDuration,
 | 
				
			||||||
 | 
					            String appointmentPlace,
 | 
				
			||||||
 | 
					            String appointmentSubject) {
 | 
				
			||||||
 | 
					        Optional<Appointment> appointment = this.appointmentRepository.findById(id);
 | 
				
			||||||
 | 
					        if (appointment.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("updateAppointment : No appointment found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce rendez vous n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (appointmentDate != null) {
 | 
				
			||||||
 | 
					            appointment.get().setAppointmentDate(appointmentDate);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (appointmentTime != null) {
 | 
				
			||||||
 | 
					            appointment.get().setAppointmentTime(appointmentTime);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (appointmentDuration != null) {
 | 
				
			||||||
 | 
					            appointment.get().setAppointmentDuration(appointmentDuration);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (appointmentPlace != null) {
 | 
				
			||||||
 | 
					            appointment.get().setAppointmentPlace(appointmentPlace);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (appointmentSubject != null) {
 | 
				
			||||||
 | 
					            appointment.get().setAppointmentSubject(appointmentSubject);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return this.appointmentRepository.save(appointment.get());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,67 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Entrepreneur;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.EntrepreneurRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class EntrepreneurService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final EntrepreneurRepository entrepreneurRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    EntrepreneurService(EntrepreneurRepository entrepreneurRepository) {
 | 
				
			||||||
 | 
					        this.entrepreneurRepository = entrepreneurRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Entrepreneur> getAllEntrepreneurs() {
 | 
				
			||||||
 | 
					        return this.entrepreneurRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Entrepreneur getEntrepreneurById(Long id) {
 | 
				
			||||||
 | 
					        Optional<Entrepreneur> entrepreneur = entrepreneurRepository.findById(id);
 | 
				
			||||||
 | 
					        if (entrepreneur.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("getEntrepreneurById : No entrepreneur found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cet entrepreneur n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return entrepreneur.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Entrepreneur addEntrepreneur(Entrepreneur entrepreneur) {
 | 
				
			||||||
 | 
					        return this.entrepreneurRepository.save(entrepreneur);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Entrepreneur updateEntrepreneur(
 | 
				
			||||||
 | 
					            Long id, String school, String course, Boolean sneeStatus) {
 | 
				
			||||||
 | 
					        Optional<Entrepreneur> entrepreneur = entrepreneurRepository.findById(id);
 | 
				
			||||||
 | 
					        if (entrepreneur.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("updateEntrepreneur : No entrepreneur found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cet entrepreneur n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (school != null) {
 | 
				
			||||||
 | 
					            entrepreneur.get().setSchool(school);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (course != null) {
 | 
				
			||||||
 | 
					            entrepreneur.get().setCourse(course);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (sneeStatus != null) {
 | 
				
			||||||
 | 
					            entrepreneur.get().setSneeStatus(sneeStatus);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return this.entrepreneurRepository.save(entrepreneur.get());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Entrepreneur> GetEntrepreneurByProject(Project project) {
 | 
				
			||||||
 | 
					        return this.entrepreneurRepository.getEntrepreneurByProjectParticipation(project);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,124 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import static enseirb.myinpulse.model.ProjectDecisionValue.PENDING;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Administrator;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.ProjectDecisionValue;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.ProjectRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDate;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class ProjectService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final ProjectRepository projectRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    ProjectService(ProjectRepository projectRepository) {
 | 
				
			||||||
 | 
					        this.projectRepository = projectRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Project> getAllProjects() {
 | 
				
			||||||
 | 
					        return this.projectRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project getProjectById(Long id) {
 | 
				
			||||||
 | 
					        Optional<Project> project = this.projectRepository.findById(id);
 | 
				
			||||||
 | 
					        if (project.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("No project found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce projet n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return project.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Project> getProjectsByAdminId(Administrator administrator) {
 | 
				
			||||||
 | 
					        return this.projectRepository.findByProjectAdministrator(administrator);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: validation
 | 
				
			||||||
 | 
					    public Project addNewProject(Project project) {
 | 
				
			||||||
 | 
					        return this.projectRepository.save(project);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project updateProject(
 | 
				
			||||||
 | 
					            Long id,
 | 
				
			||||||
 | 
					            String projectName,
 | 
				
			||||||
 | 
					            byte[] logo,
 | 
				
			||||||
 | 
					            LocalDate creationDate,
 | 
				
			||||||
 | 
					            ProjectDecisionValue projectStatus,
 | 
				
			||||||
 | 
					            Administrator administrator) {
 | 
				
			||||||
 | 
					        Optional<Project> project = this.projectRepository.findById(id);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (project.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("Project with id {} not found.", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce projet n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (projectName != null) {
 | 
				
			||||||
 | 
					            project.get().setProjectName(projectName);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (logo != null) {
 | 
				
			||||||
 | 
					            project.get().setLogo(logo);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (creationDate != null) {
 | 
				
			||||||
 | 
					            project.get().setCreationDate(creationDate);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (projectStatus != null) {
 | 
				
			||||||
 | 
					            // TODO: check if this is really useful
 | 
				
			||||||
 | 
					            /*
 | 
				
			||||||
 | 
					            if (!validateStatus(projectStatus)) {
 | 
				
			||||||
 | 
					                logger.error("updateProjectStatus: Invalid status {}", projectStatus);
 | 
				
			||||||
 | 
					                throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                        HttpStatus.NOT_ACCEPTABLE, "Ce status n'est pas accepté");
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            */
 | 
				
			||||||
 | 
					            project.get().setProjectStatus(projectStatus);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (administrator != null) {
 | 
				
			||||||
 | 
					            project.get().setProjectAdministrator(administrator);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return this.projectRepository.save(project.get());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Boolean validateStatus(String status) {
 | 
				
			||||||
 | 
					        return List.of("PENDING", "ACTIVE", "ENDED").contains(status);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Project> getPendingProjects() {
 | 
				
			||||||
 | 
					        return this.projectRepository.findByProjectStatus(PENDING);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void deleteProjectById(Long id) {
 | 
				
			||||||
 | 
					        this.projectRepository.deleteById(id);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project getProjectByName(String name, boolean noerror) {
 | 
				
			||||||
 | 
					        Optional<Project> project = this.projectRepository.findByProjectName(name);
 | 
				
			||||||
 | 
					        if (project.isEmpty()) {
 | 
				
			||||||
 | 
					            if (noerror) logger.error("No project found with name {}", name);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce projet n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return project.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Project getProjectByName(String name) {
 | 
				
			||||||
 | 
					        return getProjectByName(name, false);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,60 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Report;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.ReportRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class ReportService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final ReportRepository reportRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    ReportService(ReportRepository reportRepository) {
 | 
				
			||||||
 | 
					        this.reportRepository = reportRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<Report> getAllReports() {
 | 
				
			||||||
 | 
					        return this.reportRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Report getReportById(Long id) {
 | 
				
			||||||
 | 
					        Optional<Report> report = this.reportRepository.findById(id);
 | 
				
			||||||
 | 
					        if (report.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("getReportById : No report found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce compte rendu n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return report.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO: do some validation
 | 
				
			||||||
 | 
					    public Report addNewReport(Report report) {
 | 
				
			||||||
 | 
					        return this.reportRepository.save(report);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void deleteReportById(Long id) {
 | 
				
			||||||
 | 
					        this.reportRepository.deleteById(id);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Report updateReport(Long id, String reportContent) {
 | 
				
			||||||
 | 
					        Optional<Report> report = this.reportRepository.findById(id);
 | 
				
			||||||
 | 
					        if (report.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("updateReport : No report found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Ce compte rendu n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (reportContent != null) {
 | 
				
			||||||
 | 
					            report.get().setReportContent(reportContent);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return this.reportRepository.save(report.get());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,93 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Appointment;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.SectionCell;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.SectionCellRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDateTime;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class SectionCellService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final SectionCellRepository sectionCellRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    SectionCellService(SectionCellRepository sectionCellRepository) {
 | 
				
			||||||
 | 
					        this.sectionCellRepository = sectionCellRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<SectionCell> getAllSectionCells() {
 | 
				
			||||||
 | 
					        return this.sectionCellRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public SectionCell getSectionCellById(Long id) {
 | 
				
			||||||
 | 
					        Optional<SectionCell> sectionCell = this.sectionCellRepository.findById(id);
 | 
				
			||||||
 | 
					        if (sectionCell.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("getSectionCellById : No sectionCell found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cette cellule de section n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return sectionCell.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public SectionCell addNewSectionCell(SectionCell sectionCell) {
 | 
				
			||||||
 | 
					        return this.sectionCellRepository.save(sectionCell);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public void removeSectionCellById(Long id) {
 | 
				
			||||||
 | 
					        this.sectionCellRepository.deleteById(id);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public SectionCell updateSectionCell(
 | 
				
			||||||
 | 
					            Long id, Long sectionId, String contentSectionCell, LocalDateTime modificationDate) {
 | 
				
			||||||
 | 
					        Optional<SectionCell> sectionCell = this.sectionCellRepository.findById(id);
 | 
				
			||||||
 | 
					        if (sectionCell.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("updateSectionCell : No sectionCell found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(
 | 
				
			||||||
 | 
					                    HttpStatus.NOT_FOUND, "Cette cellule de section n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (sectionId != null) {
 | 
				
			||||||
 | 
					            sectionCell.get().setSectionId(sectionId);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (contentSectionCell != null) {
 | 
				
			||||||
 | 
					            sectionCell.get().setContentSectionCell(contentSectionCell);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (modificationDate != null) {
 | 
				
			||||||
 | 
					            sectionCell.get().setModificationDate(modificationDate);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return this.sectionCellRepository.save(sectionCell.get());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<SectionCell> getSectionCellsByProject(Project project, Long sectionId) {
 | 
				
			||||||
 | 
					        return this.sectionCellRepository.findByProjectSectionCellAndSectionId(project, sectionId);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Long getProjectId(Long sectionCellId) {
 | 
				
			||||||
 | 
					        SectionCell sectionCell = getSectionCellById(sectionCellId);
 | 
				
			||||||
 | 
					        Project sectionProject = sectionCell.getProjectSectionCell();
 | 
				
			||||||
 | 
					        return sectionProject.getIdProject();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public List<Appointment> getAppointmentsBySectionCellId(Long sectionCellId) {
 | 
				
			||||||
 | 
					        SectionCell sectionCell = getSectionCellById(sectionCellId);
 | 
				
			||||||
 | 
					        return sectionCell.getAppointmentSectionCell();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<SectionCell> getSectionCellsByProjectAndSectionIdBeforeDate(
 | 
				
			||||||
 | 
					            Project project, long sectionId, LocalDateTime date) {
 | 
				
			||||||
 | 
					        return sectionCellRepository.findByProjectSectionCellAndSectionIdAndModificationDateBefore(
 | 
				
			||||||
 | 
					                project, sectionId, date);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,81 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse.service.database;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.User;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.repository.UserRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.http.HttpStatus;
 | 
				
			||||||
 | 
					import org.springframework.stereotype.Service;
 | 
				
			||||||
 | 
					import org.springframework.web.bind.annotation.PathVariable;
 | 
				
			||||||
 | 
					import org.springframework.web.bind.annotation.RequestBody;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Optional;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@Service
 | 
				
			||||||
 | 
					public class UserService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    protected static final Logger logger = LogManager.getLogger();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final UserRepository userRepository;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Autowired
 | 
				
			||||||
 | 
					    UserService(UserRepository userRepository) {
 | 
				
			||||||
 | 
					        this.userRepository = userRepository;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<User> getAllUsers() {
 | 
				
			||||||
 | 
					        return this.userRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    // TODO
 | 
				
			||||||
 | 
					    public User getUserByEmail(String email) {
 | 
				
			||||||
 | 
					        Optional<User> opt_user = this.userRepository.findByPrimaryMail(email);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (opt_user.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("getUserByEmail : No user found with email {}", email);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Cet utilisateur n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return opt_user.get();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public Iterable<User> allUsers() {
 | 
				
			||||||
 | 
					        return this.userRepository.findAll();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public User addUser(@RequestBody User user) {
 | 
				
			||||||
 | 
					        return this.userRepository.save(user);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public User updateUser(
 | 
				
			||||||
 | 
					            @PathVariable Long id,
 | 
				
			||||||
 | 
					            String userSurname,
 | 
				
			||||||
 | 
					            String userName,
 | 
				
			||||||
 | 
					            String primaryMail,
 | 
				
			||||||
 | 
					            String secondaryMail,
 | 
				
			||||||
 | 
					            String phoneNumber) {
 | 
				
			||||||
 | 
					        Optional<User> user = userRepository.findById(id);
 | 
				
			||||||
 | 
					        if (user.isEmpty()) {
 | 
				
			||||||
 | 
					            logger.error("updateUser : No user found with id {}", id);
 | 
				
			||||||
 | 
					            throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Cet utilisateur n'existe pas");
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (userName != null) {
 | 
				
			||||||
 | 
					            user.get().setUserName(userName);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (userSurname != null) {
 | 
				
			||||||
 | 
					            user.get().setUserSurname(userSurname);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (primaryMail != null) {
 | 
				
			||||||
 | 
					            user.get().setPrimaryMail(primaryMail);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (secondaryMail != null) {
 | 
				
			||||||
 | 
					            user.get().setSecondaryMail(secondaryMail);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (phoneNumber != null) {
 | 
				
			||||||
 | 
					            user.get().setPhoneNumber(phoneNumber);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return this.userRepository.save(user.get());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,8 +1,8 @@
 | 
				
			|||||||
spring.application.name=myinpulse
 | 
					spring.application.name=myinpulse
 | 
				
			||||||
spring.security.oauth2.resourceserver.jwt.jwk-set-uri=http://localhost:7080/realms/test/protocol/openid-connect/certs
 | 
					spring.security.oauth2.resourceserver.jwt.jwk-set-uri=http://localhost:7080/realms/test/protocol/openid-connect/certs
 | 
				
			||||||
spring.security.oauth2.resourceserver.jwt.issuer-uri=http://localhost:7080/realms/test
 | 
					spring.security.oauth2.resourceserver.jwt.issuer-uri=http://localhost:7080/realms/test
 | 
				
			||||||
logging.level.org.springframework.security=DEBUG
 | 
					 | 
				
			||||||
spring.datasource.url=jdbc:postgresql://${DATABASE_URL}/${BACKEND_DB}
 | 
					spring.datasource.url=jdbc:postgresql://${DATABASE_URL}/${BACKEND_DB}
 | 
				
			||||||
spring.datasource.username=${BACKEND_USER}
 | 
					spring.datasource.username=${BACKEND_USER}
 | 
				
			||||||
spring.datasource.password=${BACKEND_PASSWORD}
 | 
					spring.datasource.password=${BACKEND_PASSWORD}
 | 
				
			||||||
spring.jpa.hibernate.ddl-auto=update
 | 
					spring.jpa.hibernate.ddl-auto=update
 | 
				
			||||||
 | 
					logging.pattern.console=%d{yyyy-MMM-dd HH:mm:ss.SSS} [%thread] %highlight(%-5level) %cyan(%logger{15}) - %msg %n
 | 
				
			||||||
@@ -1,57 +1,88 @@
 | 
				
			|||||||
TRUNCATE projets, utilisateurs, entrepreneurs, sections, rendez_vous, comptes_rendus CASCADE;
 | 
					TRUNCATE project, user_inpulse, entrepreneur, administrator, section_cell, appointment, report, annotation CASCADE;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
INSERT INTO projets (nom_projet, logo, date_creation, status_projet)
 | 
					SELECT setval('annotation_id_annotation_seq', 1, false);
 | 
				
			||||||
 | 
					SELECT setval('appointment_id_appointment_seq', 1, false);
 | 
				
			||||||
 | 
					SELECT setval('make_appointment_id_make_appointment_seq', 1, false);
 | 
				
			||||||
 | 
					SELECT setval('project_id_project_seq', 1, false);
 | 
				
			||||||
 | 
					SELECT setval('report_id_report_seq', 1, false);
 | 
				
			||||||
 | 
					SELECT setval('section_cell_id_section_cell_seq', 1, false);
 | 
				
			||||||
 | 
					SELECT setval('user_inpulse_id_user_seq', 1, false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					INSERT INTO user_inpulse (user_surname, user_name, primary_mail, secondary_mail, phone_number)
 | 
				
			||||||
 | 
					VALUES ('Dupont', 'Dupond', 'super@mail.fr', 'super2@mail.fr', '06 45 72 45 98'),
 | 
				
			||||||
 | 
					       ('Martin', 'Matin', 'genial@mail.fr', 'genial2@mail.fr', '06 52 14 58 73'),
 | 
				
			||||||
 | 
					       ('Charvet', 'Lautre', 'mieux@tmail.fr', 'mieux2@tmail.fr', '07 49 82 16 35'),
 | 
				
			||||||
 | 
					       ('Leguez', 'Theo', 'bof@mesmails.fr', 'bof2@mesmails.fr', '+33 6 78 14 25 29'),
 | 
				
			||||||
 | 
					       ('Kia', 'Bi', 'special@mail.fr', 'special2@mail.fr', '07 65 31 38 95'),
 | 
				
			||||||
 | 
					       ('Ducaillou', 'Pierre', 'maildefou@xyz.fr', 'maildefou2@xyz.fr', '06 54 78 12 62'),
 | 
				
			||||||
 | 
					       ('Janine', 'Dave', 'janine@labri.fr', 'janine2@labri.fr', '06 87 12 45 95');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					INSERT INTO administrator (id_administrator)
 | 
				
			||||||
 | 
					VALUES (7);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					INSERT INTO project (project_name, logo, creation_date, project_status, id_administrator)
 | 
				
			||||||
VALUES ('Eau du robinet', decode('013d7d16d7ad4fefb61bd95b765c8ceb', 'hex'), TO_DATE('01-OCT-2023', 'DD-MON-YYYY'),
 | 
					VALUES ('Eau du robinet', decode('013d7d16d7ad4fefb61bd95b765c8ceb', 'hex'), TO_DATE('01-OCT-2023', 'DD-MON-YYYY'),
 | 
				
			||||||
        'En cours'),
 | 
					        'En cours', 7),
 | 
				
			||||||
       ('Air oxygéné', decode('150647a0984e8f228cd14b54', 'hex'), TO_DATE('04-APR-2024', 'DD-MON-YYYY'), 'En cours'),
 | 
					       ('Air oxygéné', decode('150647a0984e8f228cd14b54', 'hex'), TO_DATE('04-APR-2024', 'DD-MON-YYYY'), 'En cours', 7),
 | 
				
			||||||
       ('Débat concours', decode('022024abd5486e245c145dda65116f', 'hex'), TO_DATE('22-NOV-2023', 'DD-MON-YYYY'),
 | 
					       ('Débat concours', decode('022024abd5486e245c145dda65116f', 'hex'), TO_DATE('22-NOV-2023', 'DD-MON-YYYY'),
 | 
				
			||||||
        'Suspendu'),
 | 
					        'Suspendu', 7),
 | 
				
			||||||
       ('HDeirbMI', decode('ab548d6c1d595a2975e6476f544d14c55a', 'hex'), TO_DATE('07-DEC-2024', 'DD-MON-YYYY'),
 | 
					       ('HDeirbMI', decode('ab548d6c1d595a2975e6476f544d14c55a', 'hex'), TO_DATE('07-DEC-2024', 'DD-MON-YYYY'),
 | 
				
			||||||
        'Lancement');
 | 
					        'Lancement', 7);
 | 
				
			||||||
 | 
					 | 
				
			||||||
INSERT INTO utilisateurs (nom_utilisateur, prenom_utilisateur, mail_principal, mail_secondaire, numero_telephone) VALUES
 | 
					 | 
				
			||||||
('Dupont', 'Dupond', 'super@mail.fr', 'super2@mail.fr', '06 45 72 45 98'),
 | 
					 | 
				
			||||||
('Martin', 'Matin', 'genial@mail.fr', 'genial2@mail.fr', '06 52 14 58 73'),
 | 
					 | 
				
			||||||
('Charvet', 'Lautre', 'mieux@tmail.fr', 'mieux2@tmail.fr', '07 49 82 16 35'),
 | 
					 | 
				
			||||||
('Leguez', 'Theo', 'bof@mesmails.fr', 'bof2@mesmails.fr', '+33 6 78 14 25 29'),
 | 
					 | 
				
			||||||
('Kia', 'Bi', 'special@mail.fr', 'special2@mail.fr', '07 65 31 38 95'),
 | 
					 | 
				
			||||||
('Ducaillou', 'Pierre', 'maildefou@xyz.fr', 'maildefou2@xyz.fr', '06 54 78 12 62');
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
INSERT INTO entrepreneurs (ecole, filiere, status_snee, id_entrepreneur) VALUES
 | 
					INSERT INTO entrepreneur (school, course, snee_status, id_entrepreneur, id_project_participation, id_project_proposed)
 | 
				
			||||||
('ENSEIRB-MATMECA', 'INFO', TRUE, 1),
 | 
					VALUES ('ENSEIRB-MATMECA', 'INFO', TRUE, 1, 4, 4),
 | 
				
			||||||
('ENSC', 'Cognitique', TRUE, 2),
 | 
					       ('ENSC', 'Cognitique', TRUE, 2, 2, null),
 | 
				
			||||||
('ENSEIRB-MATMECA', 'MATMECA', FALSE, 3),
 | 
					       ('ENSEIRB-MATMECA', 'MATMECA', FALSE, 3, 3, 3),
 | 
				
			||||||
('SupOptique', 'Classique', TRUE, 4),
 | 
					       ('SupOptique', 'Classique', TRUE, 4, 1, 1),
 | 
				
			||||||
('ENSEGID', 'Géoscience', FALSE, 5),
 | 
					       ('ENSEGID', 'Géoscience', FALSE, 5, 1, null),
 | 
				
			||||||
('ENSMAC', 'Matériaux composites - Mécanique', FALSE, 6);
 | 
					       ('ENSMAC', 'Matériaux composites - Mécanique', FALSE, 6, 2, 2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
INSERT INTO sections (titre, contenu_section, date_modification) VALUES
 | 
					 | 
				
			||||||
('Problème', 'les problèmes...', TO_TIMESTAMP('15-JAN-2025 09:30:20', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Segment de client', 'Le segment AB passant le client n°8 est de longueur 32mm.
 | 
					 | 
				
			||||||
    Le segment BC a quant à lui un longueur de 28mm. Quelle la longueur du segment AC ?', TO_TIMESTAMP('12-OCT-2022 17:47:38', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Proposition de valeur unique', '''Son prix est de 2594€'' ''Ah oui c''est unique en effet', TO_TIMESTAMP('25-MAY-2024 11:12:04', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Solution', 'Un problème ? Une solution', TO_TIMESTAMP('08-FEB-2024 10:17:53', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Canaux', 'Ici nous avons la Seine, là-bas le Rhin, oh et plus loin le canal de Suez', TO_TIMESTAMP('19-JUL-2023 19:22:45', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Sources de revenus', 'Y''en n''a pas on est pas payé. Enfin y''a du café quoi', TO_TIMESTAMP('12-JAN-2025 11:40:26', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Structure des coûts', '''Ah oui là ça va faire au moins 1000€ par mois'', Eirbware', TO_TIMESTAMP('06-FEB-2025 13:04:06', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Indicateurs clés', 'On apprend les clés comme des badges, ça se fait', TO_TIMESTAMP('05-FEB-2025 12:42:38', 'DD-MON-YYYY, HH24:MI:SS')),
 | 
					 | 
				
			||||||
('Avantages concurrentiel', 'On est meilleur', TO_TIMESTAMP('23-APR-2024 16:24:02', 'DD-MON-YYYY, HH24:MI:SS'));
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
INSERT INTO rendez_vous (date_rdv, heure_rdv, duree_rdv, lieu_rdv, sujet_rdv) VALUES
 | 
					INSERT INTO section_cell (title, content_section_cell, modification_date, id_project)
 | 
				
			||||||
(TO_DATE('24-DEC-2023', 'DD-MON-YYYY'), '00:00:00', '00:37:53', 'À la maison', 'Ouvrir les cadeaux'),
 | 
					VALUES ('Problème', 'les problèmes...', TO_TIMESTAMP('15-JAN-2025 09:30:20', 'DD-MON-YYYY, HH24:MI:SS'), 2),
 | 
				
			||||||
(TO_DATE('15-AUG-2024', 'DD-MON-YYYY'), '22:35:00', '00:12:36', 'Sur les quais ou dans un champ probablement', 'BOUM BOUM les feux d''artifices (on fête quoi déjà ?)'),
 | 
					       ('Segment de client', 'Le segment AB passant le client n°8 est de longueur 32mm.
 | 
				
			||||||
(TO_DATE('28-FEB-2023', 'DD-MON-YYYY'), '14:20:00', '00:20:00', 'Salle TD 15', 'Ah mince c''est pas une année bissextile !'),
 | 
					    Le segment BC a quant à lui un longueur de 28mm. Quelle la longueur du segment AC ?',
 | 
				
			||||||
(TO_DATE('23-JAN-2024', 'DD-MON-YYYY'), '12:56:27', '11:03:33', 'Là où le vent nous porte', 'Journée la plus importante de l''année'),
 | 
					        TO_TIMESTAMP('12-OCT-2022 17:47:38', 'DD-MON-YYYY, HH24:MI:SS'), 3),
 | 
				
			||||||
(TO_DATE('25-AUG-2025', 'DD-MON-YYYY'), '00:09:00', '01:00:00', 'Euh c''est par où l''amphi 56 ?', 'Rentrée scolaire (il fait trop froid c''est quoi ça on est en août)');
 | 
					       ('Proposition de valeur unique', '''Son prix est de 2594€'' ''Ah oui c''est unique en effet',
 | 
				
			||||||
 | 
					        TO_TIMESTAMP('25-MAY-2024 11:12:04', 'DD-MON-YYYY, HH24:MI:SS'), 2),
 | 
				
			||||||
 | 
					       ('Solution', 'Un problème ? Une solution', TO_TIMESTAMP('08-FEB-2024 10:17:53', 'DD-MON-YYYY, HH24:MI:SS'), 1),
 | 
				
			||||||
 | 
					       ('Canaux', 'Ici nous avons la Seine, là-bas le Rhin, oh et plus loin le canal de Suez',
 | 
				
			||||||
 | 
					        TO_TIMESTAMP('19-JUL-2023 19:22:45', 'DD-MON-YYYY, HH24:MI:SS'), 4),
 | 
				
			||||||
 | 
					       ('Sources de revenus', 'Y''en n''a pas on est pas payé. Enfin y''a du café quoi',
 | 
				
			||||||
 | 
					        TO_TIMESTAMP('12-JAN-2025 11:40:26', 'DD-MON-YYYY, HH24:MI:SS'), 1),
 | 
				
			||||||
 | 
					       ('Structure des coûts', '''Ah oui là ça va faire au moins 1000€ par mois'', Eirbware',
 | 
				
			||||||
 | 
					        TO_TIMESTAMP('06-FEB-2025 13:04:06', 'DD-MON-YYYY, HH24:MI:SS'), 3),
 | 
				
			||||||
 | 
					       ('Indicateurs clés', 'On apprend les clés comme des badges, ça se fait',
 | 
				
			||||||
 | 
					        TO_TIMESTAMP('05-FEB-2025 12:42:38', 'DD-MON-YYYY, HH24:MI:SS'), 4),
 | 
				
			||||||
 | 
					       ('Avantages concurrentiel', 'On est meilleur', TO_TIMESTAMP('23-APR-2024 16:24:02', 'DD-MON-YYYY, HH24:MI:SS'),
 | 
				
			||||||
 | 
					        2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
INSERT INTO comptes_rendus (contenu_compte_rendu) VALUES
 | 
					INSERT INTO appointment (appointment_date, appointment_time, appointment_duration, appointment_place,
 | 
				
			||||||
('Ah oui ça c''est super, ah ouais j''aime bien, bien vu de penser à ça'),
 | 
					                         appointment_subject)
 | 
				
			||||||
('Bonne réunion'),
 | 
					VALUES (TO_DATE('24-DEC-2023', 'DD-MON-YYYY'), '00:00:00', '00:37:53', 'À la maison', 'Ouvrir les cadeaux'),
 | 
				
			||||||
('Ouais, j''ai rien compris mais niquel on fait comme vous avez dit'),
 | 
					       (TO_DATE('15-AUG-2024', 'DD-MON-YYYY'), '22:35:00', '00:12:36', 'Sur les quais ou dans un champ probablement',
 | 
				
			||||||
('Non non ça va pas du tout ce que tu me proposes, faut tout refaire'),
 | 
					        'BOUM BOUM les feux d''artifices (on fête quoi déjà ?)'),
 | 
				
			||||||
('Réponse de la DSI : non'),
 | 
					       (TO_DATE('28-FEB-2023', 'DD-MON-YYYY'), '14:20:00', '00:20:00', 'Salle TD 15',
 | 
				
			||||||
('Trop dommage qu''Apple ait sorti leur logiciel avant nous, on avait la même idée et tout on aurait tellement pu leur faire de la concurrence');
 | 
					        'Ah mince c''est pas une année bissextile !'),
 | 
				
			||||||
 | 
					       (TO_DATE('23-JAN-2024', 'DD-MON-YYYY'), '12:56:27', '11:03:33', 'Là où le vent nous porte',
 | 
				
			||||||
 | 
					        'Journée la plus importante de l''année'),
 | 
				
			||||||
 | 
					       (TO_DATE('25-AUG-2025', 'DD-MON-YYYY'), '00:09:00', '01:00:00', 'Euh c''est par où l''amphi 56 ?',
 | 
				
			||||||
 | 
					        'Rentrée scolaire (il fait trop froid c''est quoi ça on est en août)');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					INSERT INTO report (report_content, id_appointment)
 | 
				
			||||||
 | 
					VALUES ('Ah oui ça c''est super, ah ouais j''aime bien, bien vu de penser à ça', 1),
 | 
				
			||||||
 | 
					       ('Bonne réunion', 3),
 | 
				
			||||||
 | 
					       ('Ouais, j''ai rien compris mais niquel on fait comme vous avez dit', 3),
 | 
				
			||||||
 | 
					       ('Non non ça va pas du tout ce que tu me proposes, faut tout refaire', 4),
 | 
				
			||||||
 | 
					       ('Réponse de la DSI : non', 2),
 | 
				
			||||||
 | 
					       ('Trop dommage qu''Apple ait sorti leur logiciel avant nous, on avait la même idée et tout on aurait tellement pu leur faire de la concurrence',
 | 
				
			||||||
 | 
					        5);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					INSERT INTO annotation (comment, id_administrator, id_section_cell)
 | 
				
			||||||
 | 
					VALUES ('faut changer ça hein', 7, 5),
 | 
				
			||||||
 | 
					       ('??? sérieusement, vous pensez que c''est une bonne idée ?', 7, 7),
 | 
				
			||||||
 | 
					       ('ok donc ça c''est votre business plan, bah glhf la team', 7, 2);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1 +1,2 @@
 | 
				
			|||||||
DROP TABLE IF EXISTS administrateurs, projets, utilisateurs, entrepreneurs, sections, rendez_vous, comptes_rendus, concerner CASCADE;
 | 
					DROP TABLE IF EXISTS administrateurs, projets, utilisateurs, entrepreneurs, sections, rendez_vous, comptes_rendus, concerner CASCADE;
 | 
				
			||||||
 | 
					DROP TABLE IF EXISTS administrator, project, user_inpulse, entrepreneur, section_cell, appointment, make_appointment, report, annotation, concern CASCADE;
 | 
				
			||||||
@@ -1,134 +0,0 @@
 | 
				
			|||||||
DROP TABLE IF EXISTS projets CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS utilisateurs CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS entrepreneurs CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS administrateurs CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS sections CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS rendez_vous CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS comptes_rendus CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS concerner CASCADE;
 | 
					 | 
				
			||||||
DROP TABLE IF EXISTS formes CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE projets
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
    id_projet     SERIAL NOT NULL,
 | 
					 | 
				
			||||||
    nom_projet    VARCHAR(255),
 | 
					 | 
				
			||||||
    logo          BYTEA,
 | 
					 | 
				
			||||||
    date_creation DATE,
 | 
					 | 
				
			||||||
    status_projet VARCHAR(255),
 | 
					 | 
				
			||||||
    CONSTRAINT pk_projet PRIMARY KEY (id_projet)
 | 
					 | 
				
			||||||
);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE utilisateurs
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
id_utilisateur      SERIAL    NOT NULL,
 | 
					 | 
				
			||||||
nom_utilisateur     VARCHAR(255)      ,
 | 
					 | 
				
			||||||
prenom_utilisateur  VARCHAR(255)      ,
 | 
					 | 
				
			||||||
mail_principal      VARCHAR(255)      ,
 | 
					 | 
				
			||||||
mail_secondaire     VARCHAR(255)      ,
 | 
					 | 
				
			||||||
numero_telephone    VARCHAR(20)       ,
 | 
					 | 
				
			||||||
CONSTRAINT pk_utilisateur PRIMARY KEY (id_utilisateur) );
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE entrepreneurs
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
    id_entrepreneur SERIAL REFERENCES utilisateurs (id_utilisateur),
 | 
					 | 
				
			||||||
    ecole           VARCHAR(255),
 | 
					 | 
				
			||||||
    filiere         VARCHAR(255),
 | 
					 | 
				
			||||||
    status_snee     BOOLEAN,
 | 
					 | 
				
			||||||
    CONSTRAINT pk_entrepreneur PRIMARY KEY (id_entrepreneur)
 | 
					 | 
				
			||||||
);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE administrateurs
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
    id_administrateur SERIAL REFERENCES utilisateurs (id_utilisateur),
 | 
					 | 
				
			||||||
    CONSTRAINT pk_administrateur PRIMARY KEY (id_administrateur)
 | 
					 | 
				
			||||||
);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE sections
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
    id_section        SERIAL NOT NULL,
 | 
					 | 
				
			||||||
    titre             VARCHAR(255),
 | 
					 | 
				
			||||||
    contenu_section   TEXT,
 | 
					 | 
				
			||||||
    date_modification TIMESTAMP,
 | 
					 | 
				
			||||||
    CONSTRAINT pk_section PRIMARY KEY (id_section)
 | 
					 | 
				
			||||||
);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE rendez_vous
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
    id_rdv    SERIAL NOT NULL,
 | 
					 | 
				
			||||||
    date_rdv  DATE,
 | 
					 | 
				
			||||||
    heure_rdv TIME,
 | 
					 | 
				
			||||||
    duree_rdv TIME,
 | 
					 | 
				
			||||||
    lieu_rdv  VARCHAR(255),
 | 
					 | 
				
			||||||
    sujet_rdv TEXT,
 | 
					 | 
				
			||||||
    CONSTRAINT pk_rdv PRIMARY KEY (id_rdv)
 | 
					 | 
				
			||||||
);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE comptes_rendus
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
    id_compte_rendu      SERIAL NOT NULL,
 | 
					 | 
				
			||||||
    contenu_compte_rendu TEXT,
 | 
					 | 
				
			||||||
    CONSTRAINT pk_compte_rendu PRIMARY KEY (id_compte_rendu)
 | 
					 | 
				
			||||||
);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CREATE TABLE concerner
 | 
					 | 
				
			||||||
(
 | 
					 | 
				
			||||||
    id_section SERIAL REFERENCES sections (id_section),
 | 
					 | 
				
			||||||
    id_rdv     SERIAL REFERENCES sections (id_rdv),
 | 
					 | 
				
			||||||
    CONSTRAINT pk_concerner PRIMARY KEY (id_section, id_rdv)
 | 
					 | 
				
			||||||
);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE projets
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk1_projet FOREIGN KEY (id_administrateur)
 | 
					 | 
				
			||||||
        REFERENCES administrateurs (id_administrateur)
 | 
					 | 
				
			||||||
        ON DELETE CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE projets
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk2_projet FOREIGN KEY (id_entrepreneur_participation)
 | 
					 | 
				
			||||||
        REFERENCES entrepreneurs (id_entrepreneur)
 | 
					 | 
				
			||||||
        ON DELETE CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE entrepreneurs
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk1_entrepreneur FOREIGN KEY (id_projet_propose)
 | 
					 | 
				
			||||||
        REFERENCES projets (id_projet)
 | 
					 | 
				
			||||||
        ON DELETE CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE sections
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk1_section FOREIGN KEY (id_projet)
 | 
					 | 
				
			||||||
        REFERENCES projets (id_projet)
 | 
					 | 
				
			||||||
        ON DELETE CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE sections
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk2_section FOREIGN KEY (id_administrateur)
 | 
					 | 
				
			||||||
        REFERENCES administrateurs (id_administrateur)
 | 
					 | 
				
			||||||
        ON DELETE CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE rendez-vous
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk1_rdv FOREIGN KEY (id_entrepreneur)
 | 
					 | 
				
			||||||
    REFERENCES entrepreneurs (id_entrepreneur)
 | 
					 | 
				
			||||||
    ON
 | 
					 | 
				
			||||||
DELETE
 | 
					 | 
				
			||||||
CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE rendez-vous
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk2_rdv FOREIGN KEY (id_administrateur)
 | 
					 | 
				
			||||||
    REFERENCES administrateurs (id_administrateur)
 | 
					 | 
				
			||||||
    ON
 | 
					 | 
				
			||||||
DELETE
 | 
					 | 
				
			||||||
CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ALTER TABLE comptes-rendus
 | 
					 | 
				
			||||||
    ADD CONSTRAINT fk1_compte_rendu FOREIGN KEY (id_rdv)
 | 
					 | 
				
			||||||
    REFERENCES rendez_vous (id_rdv)
 | 
					 | 
				
			||||||
    ON
 | 
					 | 
				
			||||||
DELETE
 | 
					 | 
				
			||||||
CASCADE;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@@ -0,0 +1,173 @@
 | 
				
			|||||||
 | 
					package enseirb.myinpulse;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import static enseirb.myinpulse.model.ProjectDecisionValue.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import static org.junit.jupiter.api.Assertions.*;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Administrator;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.Project;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.model.ProjectDecision;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.AdminApiService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.AdministratorService;
 | 
				
			||||||
 | 
					import enseirb.myinpulse.service.database.ProjectService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.junit.jupiter.api.BeforeAll;
 | 
				
			||||||
 | 
					import org.junit.jupiter.api.Test;
 | 
				
			||||||
 | 
					import org.springframework.beans.factory.annotation.Autowired;
 | 
				
			||||||
 | 
					import org.springframework.boot.test.context.SpringBootTest;
 | 
				
			||||||
 | 
					import org.springframework.transaction.annotation.Transactional;
 | 
				
			||||||
 | 
					import org.springframework.web.server.ResponseStatusException;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.time.LocalDate;
 | 
				
			||||||
 | 
					import java.util.ArrayList;
 | 
				
			||||||
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@SpringBootTest
 | 
				
			||||||
 | 
					@Transactional
 | 
				
			||||||
 | 
					public class AdminApiServiceTest {
 | 
				
			||||||
 | 
					    private static long administratorid;
 | 
				
			||||||
 | 
					    @Autowired private AdminApiService adminApiService;
 | 
				
			||||||
 | 
					    @Autowired private ProjectService projectService;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @BeforeAll
 | 
				
			||||||
 | 
					    static void setup(
 | 
				
			||||||
 | 
					            @Autowired AdministratorService administratorService,
 | 
				
			||||||
 | 
					            @Autowired ProjectService projectService) {
 | 
				
			||||||
 | 
					        administratorService.addAdministrator(
 | 
				
			||||||
 | 
					                new Administrator(
 | 
				
			||||||
 | 
					                        "admin",
 | 
				
			||||||
 | 
					                        "admin",
 | 
				
			||||||
 | 
					                        "testAdminEmpty@example.com",
 | 
				
			||||||
 | 
					                        "testAdmin@example.com",
 | 
				
			||||||
 | 
					                        ""));
 | 
				
			||||||
 | 
					        Administrator a =
 | 
				
			||||||
 | 
					                administratorService.addAdministrator(
 | 
				
			||||||
 | 
					                        new Administrator(
 | 
				
			||||||
 | 
					                                "admin2",
 | 
				
			||||||
 | 
					                                "admin2",
 | 
				
			||||||
 | 
					                                "testAdminFull@example.com",
 | 
				
			||||||
 | 
					                                "testAdmin@example.com",
 | 
				
			||||||
 | 
					                                ""));
 | 
				
			||||||
 | 
					        administratorid = a.getIdUser();
 | 
				
			||||||
 | 
					        projectService.addNewProject(
 | 
				
			||||||
 | 
					                new Project(
 | 
				
			||||||
 | 
					                        "sampleProjectAdminApiService",
 | 
				
			||||||
 | 
					                        null,
 | 
				
			||||||
 | 
					                        LocalDate.now(),
 | 
				
			||||||
 | 
					                        ACTIVE,
 | 
				
			||||||
 | 
					                        administratorService.getAdministratorByPrimaryMain(
 | 
				
			||||||
 | 
					                                "testAdminFull@example.com")));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private <T> List<T> IterableToList(Iterable<T> iterable) {
 | 
				
			||||||
 | 
					        List<T> l = new ArrayList<>();
 | 
				
			||||||
 | 
					        iterable.forEach(l::add);
 | 
				
			||||||
 | 
					        return l;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void getProjectOfAdminIsEmpty() {
 | 
				
			||||||
 | 
					        Iterable<Project> projects =
 | 
				
			||||||
 | 
					                adminApiService.getProjectsOfAdmin("testAdminEmpty@example.com");
 | 
				
			||||||
 | 
					        assertEquals(0, IterableToList(projects).size());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void getProjectOfInexistantAdminFails() {
 | 
				
			||||||
 | 
					        String nonExistentAdminEmail = "testInexistantAdmin@example.com";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        assertThrows(
 | 
				
			||||||
 | 
					                ResponseStatusException.class,
 | 
				
			||||||
 | 
					                () -> {
 | 
				
			||||||
 | 
					                    adminApiService.getProjectsOfAdmin(nonExistentAdminEmail);
 | 
				
			||||||
 | 
					                });
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void getProjectOfAdminNotEmpty() {
 | 
				
			||||||
 | 
					        Iterable<Project> projects =
 | 
				
			||||||
 | 
					                adminApiService.getProjectsOfAdmin("testAdminFull@example.com");
 | 
				
			||||||
 | 
					        List<Project> l = IterableToList(projects);
 | 
				
			||||||
 | 
					        assertEquals(1, l.size());
 | 
				
			||||||
 | 
					        Project p = l.getFirst();
 | 
				
			||||||
 | 
					        assertEquals(p.getProjectName(), "sampleProjectAdminApiService");
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void getPendingProjectsEmpty() {
 | 
				
			||||||
 | 
					        assertEquals(0, IterableToList(this.adminApiService.getPendingProjects()).size());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void getPendingProjectsNotEmpty() {
 | 
				
			||||||
 | 
					        this.projectService.addNewProject(
 | 
				
			||||||
 | 
					                new Project(
 | 
				
			||||||
 | 
					                        "PendingProjectAdminApiService1", null, LocalDate.now(), PENDING, null));
 | 
				
			||||||
 | 
					        this.projectService.addNewProject(
 | 
				
			||||||
 | 
					                new Project(
 | 
				
			||||||
 | 
					                        "PendingProjectAdminApiService2", null, LocalDate.now(), PENDING, null));
 | 
				
			||||||
 | 
					        Iterable<Project> pendingProjects = this.adminApiService.getPendingProjects();
 | 
				
			||||||
 | 
					        List<Project> pendingProjectsList = IterableToList(pendingProjects);
 | 
				
			||||||
 | 
					        assertEquals(2, pendingProjectsList.size());
 | 
				
			||||||
 | 
					        assertTrue(
 | 
				
			||||||
 | 
					                List.of("PendingProjectAdminApiService1", "PendingProjectAdminApiService2")
 | 
				
			||||||
 | 
					                        .contains(pendingProjectsList.getFirst().getProjectName()));
 | 
				
			||||||
 | 
					        assertTrue(
 | 
				
			||||||
 | 
					                List.of("PendingProjectAdminApiService1", "PendingProjectAdminApiService2")
 | 
				
			||||||
 | 
					                        .contains(pendingProjectsList.getLast().getProjectName()));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void validateInexistantProject() {
 | 
				
			||||||
 | 
					        ProjectDecision d = new ProjectDecision(-1, 0, 1);
 | 
				
			||||||
 | 
					        assertThrows(ResponseStatusException.class, () -> this.adminApiService.validateProject(d));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void validateExistantProject() {
 | 
				
			||||||
 | 
					        Project p =
 | 
				
			||||||
 | 
					                new Project("PendingProjectAdminApiService2", null, LocalDate.now(), PENDING, null);
 | 
				
			||||||
 | 
					        this.projectService.addNewProject(p);
 | 
				
			||||||
 | 
					        assertEquals(PENDING, p.getProjectStatus());
 | 
				
			||||||
 | 
					        ProjectDecision d = new ProjectDecision(p.getIdProject(), administratorid, 1);
 | 
				
			||||||
 | 
					        this.adminApiService.validateProject(d);
 | 
				
			||||||
 | 
					        assertEquals(ACTIVE, p.getProjectStatus());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // Check if the project was really updated in the database
 | 
				
			||||||
 | 
					        assertEquals(0, IterableToList(this.adminApiService.getPendingProjects()).size());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void refuseExistantProject() {
 | 
				
			||||||
 | 
					        Project p =
 | 
				
			||||||
 | 
					                new Project("PendingProjectAdminApiService2", null, LocalDate.now(), PENDING, null);
 | 
				
			||||||
 | 
					        this.projectService.addNewProject(p);
 | 
				
			||||||
 | 
					        assertEquals(PENDING, p.getProjectStatus());
 | 
				
			||||||
 | 
					        ProjectDecision d = new ProjectDecision(p.getIdProject(), administratorid, 0);
 | 
				
			||||||
 | 
					        this.adminApiService.validateProject(d);
 | 
				
			||||||
 | 
					        assertEquals(REJECTED, p.getProjectStatus());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // Check if the project was really updated in the database
 | 
				
			||||||
 | 
					        assertEquals(0, IterableToList(this.adminApiService.getPendingProjects()).size());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void addProject() {
 | 
				
			||||||
 | 
					        assertEquals(0, IterableToList(this.adminApiService.getPendingProjects()).size());
 | 
				
			||||||
 | 
					        Project p1 =
 | 
				
			||||||
 | 
					                new Project("PendingProjectAdminApiService2", null, LocalDate.now(), PENDING, null);
 | 
				
			||||||
 | 
					        this.adminApiService.addNewProject(p1);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        assertEquals(1, IterableToList(this.adminApiService.getPendingProjects()).size());
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Test
 | 
				
			||||||
 | 
					    void addDuplicateProject() {
 | 
				
			||||||
 | 
					        Project p1 =
 | 
				
			||||||
 | 
					                new Project("PendingProjectAdminApiService2", null, LocalDate.now(), PENDING, null);
 | 
				
			||||||
 | 
					        Project p2 =
 | 
				
			||||||
 | 
					                new Project("PendingProjectAdminApiService2", null, LocalDate.now(), PENDING, null);
 | 
				
			||||||
 | 
					        this.adminApiService.addNewProject(p1);
 | 
				
			||||||
 | 
					        assertThrows(ResponseStatusException.class, () -> this.adminApiService.addNewProject(p2));
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -1,5 +1,6 @@
 | 
				
			|||||||
package enseirb.myinpulse;
 | 
					package enseirb.myinpulse;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.junit.jupiter.api.DisplayName;
 | 
				
			||||||
import org.junit.jupiter.api.Test;
 | 
					import org.junit.jupiter.api.Test;
 | 
				
			||||||
import org.springframework.boot.test.context.SpringBootTest;
 | 
					import org.springframework.boot.test.context.SpringBootTest;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -7,5 +8,6 @@ import org.springframework.boot.test.context.SpringBootTest;
 | 
				
			|||||||
class MyinpulseApplicationTests {
 | 
					class MyinpulseApplicationTests {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Test
 | 
					    @Test
 | 
				
			||||||
 | 
					    @DisplayName("contextLoad => Test if the context can load, i.e. the application can start")
 | 
				
			||||||
    void contextLoads() {}
 | 
					    void contextLoads() {}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										10
									
								
								MyINPulse-back/src/test/resources/application.properties
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								MyINPulse-back/src/test/resources/application.properties
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,10 @@
 | 
				
			|||||||
 | 
					spring.datasource.driver-class-name=org.h2.Driver
 | 
				
			||||||
 | 
					spring.datasource.url=jdbc:h2:mem:db;DB_CLOSE_DELAY=-1
 | 
				
			||||||
 | 
					spring.datasource.username=sa
 | 
				
			||||||
 | 
					spring.datasource.password=sa
 | 
				
			||||||
 | 
					spring.sql.init.mode=never
 | 
				
			||||||
 | 
					spring.application.name=myinpulse-test
 | 
				
			||||||
 | 
					spring.security.oauth2.resourceserver.jwt.jwk-set-uri=http://localhost:7080/realms/test/protocol/openid-connect/certs
 | 
				
			||||||
 | 
					spring.security.oauth2.resourceserver.jwt.issuer-uri=http://localhost:7080/realms/test
 | 
				
			||||||
 | 
					spring.jpa.hibernate.ddl-auto=update
 | 
				
			||||||
 | 
					logging.pattern.console=%d{yyyy-MMM-dd HH:mm:ss.SSS} [%thread] %highlight(%-5level) %cyan(%logger{15}) - %msg %n
 | 
				
			||||||
							
								
								
									
										22
									
								
								config/.env.dev
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								config/.env.dev
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,22 @@
 | 
				
			|||||||
 | 
					POSTGRES_DB=postgres_db
 | 
				
			||||||
 | 
					POSTGRES_USER=postgres
 | 
				
			||||||
 | 
					POSTGRES_PASSWORD=postgres_db_user_password
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					KEYCLOAK_ADMIN=admin
 | 
				
			||||||
 | 
					KEYCLOAK_ADMIN_PASSWORD=admin
 | 
				
			||||||
 | 
					KEYCLOAK_HOSTNAME=localhost
 | 
				
			||||||
 | 
					KEYCLOAK_DB=keycloak_db
 | 
				
			||||||
 | 
					KEYCLOAK_USER=keycloak_db_user
 | 
				
			||||||
 | 
					KEYCLOAK_PASSWORD=keycloak_db_user_password
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					BACKEND_DB=backend_db
 | 
				
			||||||
 | 
					BACKEND_USER=backend_db_user
 | 
				
			||||||
 | 
					BACKEND_PASSWORD=backend_db_user_password
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					DATABASE_URL=localhost:5433
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					VITE_KEYCLOAK_URL=http://localhost:7080
 | 
				
			||||||
 | 
					VITE_KEYCLOAK_CLIENT_ID=myinpulse-dev
 | 
				
			||||||
 | 
					VITE_KEYCLOAK_REALM=test
 | 
				
			||||||
 | 
					VITE_APP_URL=http://localhost:5173
 | 
				
			||||||
 | 
					VITE_BACKEND_URL=http://localhost:8081/
 | 
				
			||||||
							
								
								
									
										12
									
								
								documentation/Doc.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								documentation/Doc.txt
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,12 @@
 | 
				
			|||||||
 | 
					Format des comptes rendus de réunion :
 | 
				
			||||||
 | 
					Texte organisé par bullet point, chaque bullet point est séparé par "//" pour pouvoir être correctement généré.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Exemple :
 | 
				
			||||||
 | 
					Le texte "// blablabla // oui bonjour"
 | 
				
			||||||
 | 
					donne le résultat
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Point n°1 :
 | 
				
			||||||
 | 
					  blablabla
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Point n°2 :
 | 
				
			||||||
 | 
					  oui bonjour
 | 
				
			||||||
@@ -53,7 +53,7 @@ const CustomRequest = ref("");
 | 
				
			|||||||
            <tr>
 | 
					            <tr>
 | 
				
			||||||
                <td>Unauth API call</td>
 | 
					                <td>Unauth API call</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <button @click="callApi('random3')">call</button>
 | 
					                    <button @click="callApi('unauth/dev')">call</button>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
                <td>res</td>
 | 
					                <td>res</td>
 | 
				
			||||||
                <td id="3"></td>
 | 
					                <td id="3"></td>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								hooks/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								hooks/README.md
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,2 @@
 | 
				
			|||||||
 | 
					# Useful hooks in this project
 | 
				
			||||||
 | 
					To use, just add the content of the wanted hook in `.git/hook/pre-commit`. You may need to use `chmod +x pre-commit`
 | 
				
			||||||
							
								
								
									
										24
									
								
								hooks/google-java-format
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										24
									
								
								hooks/google-java-format
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,24 @@
 | 
				
			|||||||
 | 
					#!/bin/bash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Path to the Google Java Formatter JAR
 | 
				
			||||||
 | 
					FORMATTER_JAR="$HOME/.local/share/java/google-java-format.jar"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Download the Google Java Formatter JAR if it doesn't exist
 | 
				
			||||||
 | 
					if [ ! -f "$FORMATTER_JAR" ]; then
 | 
				
			||||||
 | 
					  echo "Downloading Google Java Formatter..."
 | 
				
			||||||
 | 
					  mkdir -p "$(dirname "$FORMATTER_JAR")"
 | 
				
			||||||
 | 
					  curl -L -o "$FORMATTER_JAR" https://github.com/google/google-java-format/releases/download/v1.20.0/google-java-format-1.20.0-all-deps.jar
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Format all staged Java files
 | 
				
			||||||
 | 
					STAGED_JAVA_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep "\.java$")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if [ -n "$STAGED_JAVA_FILES" ]; then
 | 
				
			||||||
 | 
					  echo "Formatting Java files..."
 | 
				
			||||||
 | 
					  java -jar "$FORMATTER_JAR" --skip-sorting-imports --skip-reflowing-long-strings --aosp --replace $STAGED_JAVA_FILES
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  # Re-stage the formatted files
 | 
				
			||||||
 | 
					  git add $STAGED_JAVA_FILES
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					exit 0
 | 
				
			||||||
		Reference in New Issue
	
	Block a user