Merge branch 'environment-vars'

This commit is contained in:
2025-06-11 23:34:32 +02:00
4 changed files with 30 additions and 34 deletions

View File

@@ -6,6 +6,7 @@ import _11.asktpk.artisanconnectbackend.service.NoticeService;
import jakarta.persistence.EntityNotFoundException; import jakarta.persistence.EntityNotFoundException;
import org.springframework.beans.factory.annotation.Value; import org.springframework.beans.factory.annotation.Value;
import org.springframework.core.io.Resource; import org.springframework.core.io.Resource;
import org.springframework.data.repository.query.Param;
import org.springframework.http.HttpStatus; import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType; import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity; import org.springframework.http.ResponseEntity;
@@ -29,7 +30,7 @@ public class ImageController {
private String uploadDir; private String uploadDir;
@PostMapping("/upload/{id}") @PostMapping("/upload/{id}")
public ResponseEntity<RequestResponseDTO> uploadImage(@RequestParam("file") MultipartFile file, @PathVariable("id") Long noticeId) { public ResponseEntity<RequestResponseDTO> uploadImage(@RequestParam("file") MultipartFile file, @PathVariable("id") Long noticeId, @Param("isMainImage") Boolean isMainImage) {
try { try {
if(file.isEmpty()) { if(file.isEmpty()) {
return ResponseEntity.badRequest().body(new RequestResponseDTO("File is empty")); return ResponseEntity.badRequest().body(new RequestResponseDTO("File is empty"));
@@ -44,10 +45,11 @@ public class ImageController {
} }
String newImageName = imageService.saveImageToStorage(uploadDir, file); String newImageName = imageService.saveImageToStorage(uploadDir, file);
imageService.addImageNameToDB(newImageName, noticeId); imageService.addImageNameToDB(newImageName, noticeId, isMainImage);
return ResponseEntity.ok(new RequestResponseDTO("Image uploaded successfully with new name: " + newImageName)); return ResponseEntity.ok(new RequestResponseDTO("Image uploaded successfully with new name: " + newImageName));
} catch (Exception e) { } catch (Exception e) {
System.out.println(e.getMessage());
return ResponseEntity.status(HttpStatus.UNSUPPORTED_MEDIA_TYPE).body(new RequestResponseDTO(e.getMessage())); return ResponseEntity.status(HttpStatus.UNSUPPORTED_MEDIA_TYPE).body(new RequestResponseDTO(e.getMessage()));
} }
} }

View File

@@ -1,9 +0,0 @@
package _11.asktpk.artisanconnectbackend.dto;
import org.springframework.core.io.Resource;
public class ImageRequestDTO {
public Resource image;
public Long noticeId;
public boolean isMainImage;
}

View File

@@ -40,10 +40,11 @@ public class ImageService {
return uniqueFileName; return uniqueFileName;
} }
public void addImageNameToDB(String filename, Long noticeId) { public void addImageNameToDB(String filename, Long noticeId, boolean isMainImage) {
Image image = new Image(); Image image = new Image();
image.setImageName(filename); image.setImageName(filename);
image.setNoticeId(noticeId); image.setNoticeId(noticeId);
image.setMainImage(isMainImage);
imageRepository.save(image); imageRepository.save(image);
} }

View File

@@ -1,39 +1,41 @@
spring.application.name=ArtisanConnectBackend spring.application.name=ArtisanConnectBackend
## PostgreSQL ## PostgreSQL
spring.datasource.url=jdbc:postgresql://localhost:5432/postgres spring.datasource.url=${DB_URL:jdbc:postgresql://db:5432/postgres}
spring.datasource.username=${DB_USER:postgres}
spring.datasource.password=${DB_PASS:postgres}
spring.datasource.driver-class-name=org.postgresql.Driver spring.datasource.driver-class-name=org.postgresql.Driver
spring.datasource.username=postgres
spring.datasource.password=postgres
#initial data for db injection #Injekcja danych przyk?adowych przy starcie bazy
spring.sql.init.data-locations=classpath:sql/data.sql spring.sql.init.data-locations=classpath:sql/data.sql
spring.sql.init.mode=always spring.sql.init.mode=always
spring.jpa.defer-datasource-initialization=true spring.jpa.defer-datasource-initialization=true
# create and drop table, good for testing, production set to none or comment it #Sposób zachowania JPA
spring.jpa.hibernate.ddl-auto=create-drop spring.jpa.hibernate.ddl-auto=create-drop
file.upload-dir=/Users/andsol/Desktop/uploads #Gdzie uploadujemy zdj?cia i maksymalny rozmiar
spring.servlet.multipart.max-file-size=10MB file.upload-dir=${IMAGES_UPLOAD_DIR:/app/images}
spring.servlet.multipart.max-request-size=10MB spring.servlet.multipart.max-file-size=${MAX_FILE_SIZE:10MB}
spring.servlet.multipart.max-request-size=${MAX_REQUEST_SIZE:10MB}
spring.mail.host=smtp.sendgrid.net #Ustawienia wysy?ania maili
spring.mail.port=587 spring.mail.host=${MAIL_HOST}
spring.mail.username=apikey spring.mail.port=${MAIL_PORT}
spring.mail.password=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 spring.mail.username=${MAIL_USER}
spring.mail.properties.mail.smtp.auth=true spring.mail.password=${MAIL_PASSWORD}
spring.mail.properties.mail.smtp.starttls.enable=true
tpay.clientId = 01JQKC048X62ST9V59HNRSXD92-01JQKC2CQHPYXQFSFX8BKC24BX #Ustawienia TPay
tpay.clientSecret = 44898642be53381cdcc47f3e44bf5a15e592f5d270fc3a6cf6fb81a8b8ebffb9 tpay.clientId=${TPAY_CLIENT_ID}
tpay.authUrl = https://openapi.sandbox.tpay.com/oauth/auth tpay.clientSecret=${TPAY_SECRET}
tpay.transactionUrl = https://openapi.sandbox.tpay.com/transactions tpay.authUrl=${TPAY_AUTH_URL}
tpay.securityCode = )IY7E)YSM!A)Q6O-GN#U7U_33s9qObk8 tpay.transactionUrl=${TPAY_TRANSACTION_URL}
tpay.securityCode = ${TPAY_SECURITY_CODE}
#jwt settings #Ustawienia JWT
jwt.secret=DIXLsOs3FKmCAQwISd0SKsHMXJrPl3IKIRkVlkOvYW7kEcdUTbxh8zFe1B3eZWkY jwt.secret=${JWT_SECRET}
jwt.expiration=300000 jwt.expiration=1200000
#Ustawienia logowania
logging.file.name=logs/payment-notifications.log logging.file.name=logs/payment-notifications.log
logging.level.TpayLogger=INFO logging.level.TpayLogger=INFO