add master data api

This commit is contained in:
dirgantarasiahaan
2023-05-26 10:39:31 +07:00
parent c573eb2fb3
commit fe72608465
67 changed files with 2376 additions and 307 deletions

View File

@@ -0,0 +1,38 @@
package com.iconplus.smartproc.service.metodepengadaan;
import com.iconplus.smartproc.exception.BusinessException;
import com.iconplus.smartproc.helper.model.EmptyResponse;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.request.MetodePengadaanRequest;
import com.iconplus.smartproc.repository.MetodePengadaanRepository;
import com.iconplus.smartproc.util.Constants;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Service;
@Service
@Slf4j
public class DeleteMetodePengadaanService implements BaseService<MetodePengadaanRequest, EmptyResponse> {
private MetodePengadaanRepository metodePengadaanRepository;
public DeleteMetodePengadaanService(MetodePengadaanRepository metodePengadaanRepository) {
this.metodePengadaanRepository = metodePengadaanRepository;
}
@Override
public EmptyResponse execute(MetodePengadaanRequest input) {
var metodePengadaan = metodePengadaanRepository.findByIdAndIsDeleteFalse(input.getId())
.orElseThrow(() -> new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10001,
Constants.ERR_TTL_10001,
String.format(Constants.ERR_MSG_10001, input.getId())));
metodePengadaan.setIsDelete(true);
metodePengadaanRepository.save(metodePengadaan);
log.info("success delete metode pengadaan id {}", metodePengadaan.getIsDelete());
return new EmptyResponse();
}
}

View File

@@ -0,0 +1,61 @@
package com.iconplus.smartproc.service.metodepengadaan;
import com.iconplus.smartproc.helper.model.Pagination;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.projection.MetodePengadaanView;
import com.iconplus.smartproc.model.request.MetodePengadaanRequest;
import com.iconplus.smartproc.model.response.GetListMetodePengadaanResponse;
import com.iconplus.smartproc.model.response.MetodePengadaanResponse;
import com.iconplus.smartproc.repository.MetodePengadaanRepository;
import org.apache.commons.lang3.StringUtils;
import org.springframework.data.domain.Page;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
import java.util.List;
@Service
public class GetListMetodePengadaanService implements BaseService<MetodePengadaanRequest, GetListMetodePengadaanResponse> {
private MetodePengadaanRepository metodePengadaanRepository;
public GetListMetodePengadaanService(MetodePengadaanRepository metodePengadaanRepository) {
this.metodePengadaanRepository = metodePengadaanRepository;
}
@Override
public GetListMetodePengadaanResponse execute(MetodePengadaanRequest input) {
validateRequest(input);
List<MetodePengadaanResponse> metodePengadaanResponseList = new ArrayList<>();
Page<MetodePengadaanView> metodePengadaanViews = metodePengadaanRepository.getAllMetodePengadaan(input.getSearch(), input.getPageable());
for (MetodePengadaanView metodePengadaanView : metodePengadaanViews) {
MetodePengadaanResponse metodePengadaanResponse = MetodePengadaanResponse.builder()
.id(metodePengadaanView.getId())
.metodePengadaan(metodePengadaanView.getMetodePengadaan())
.keterangan(metodePengadaanView.getKeterangan())
.isActive(metodePengadaanView.getIsActive())
.isDelete(metodePengadaanView.getIsDelete())
.build();
metodePengadaanResponseList.add(metodePengadaanResponse);
}
return GetListMetodePengadaanResponse.builder()
.data(metodePengadaanResponseList)
.pagination(Pagination.builder()
.pageSize(input.getPageable().getPageSize())
.currentPage(input.getPageable().getPageNumber())
.totalPages(metodePengadaanViews.getTotalPages())
.totalRecords(metodePengadaanViews.getTotalElements())
.isFirstPage(metodePengadaanViews.isFirst())
.isLastPage(metodePengadaanViews.isLast())
.build())
.build();
}
private void validateRequest(MetodePengadaanRequest input) {
if (StringUtils.isNotBlank(input.getSearch())) {
input.setSearch('%'+ input.getSearch().toUpperCase()+'%');
}
}
}

View File

@@ -0,0 +1,40 @@
package com.iconplus.smartproc.service.metodepengadaan;
import com.iconplus.smartproc.exception.BusinessException;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.request.MetodePengadaanRequest;
import com.iconplus.smartproc.model.response.MetodePengadaanResponse;
import com.iconplus.smartproc.repository.MetodePengadaanRepository;
import com.iconplus.smartproc.util.Constants;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Service;
@Service
public class GetMetodePengadaanByIdService implements BaseService<MetodePengadaanRequest, MetodePengadaanResponse> {
private final MetodePengadaanRepository metodePengadaanRepository;
public GetMetodePengadaanByIdService(MetodePengadaanRepository metodePengadaanRepository) {
this.metodePengadaanRepository = metodePengadaanRepository;
}
@Override
public MetodePengadaanResponse execute(MetodePengadaanRequest input) {
var metodePengadaanView = metodePengadaanRepository.findByIdAndIsDeleteFalse(input.getId());
if (metodePengadaanView.isEmpty()) {
throw new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10001,
Constants.ERR_TTL_10001,
String.format(Constants.ERR_MSG_10001, input.getId()));
}
return MetodePengadaanResponse.builder()
.id(metodePengadaanView.get().getId())
.metodePengadaan(metodePengadaanView.get().getMetodePengadaan())
.keterangan(metodePengadaanView.get().getKeterangan())
.isActive(metodePengadaanView.get().getIsActive())
.isDelete(metodePengadaanView.get().getIsDelete())
.build();
}
}

View File

@@ -0,0 +1,49 @@
package com.iconplus.smartproc.service.metodepengadaan;
import com.iconplus.smartproc.exception.BusinessException;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.entity.MetodePengadaan;
import com.iconplus.smartproc.model.request.MetodePengadaanRequest;
import com.iconplus.smartproc.model.response.MetodePengadaanResponse;
import com.iconplus.smartproc.repository.MetodePengadaanRepository;
import com.iconplus.smartproc.util.Constants;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Service;
@Service
@Slf4j
public class PostCreateMetodePengadaanService implements BaseService<MetodePengadaanRequest, MetodePengadaanResponse> {
private final MetodePengadaanRepository metodePengadaanRepository;
public PostCreateMetodePengadaanService(MetodePengadaanRepository metodePengadaanRepository) {
this.metodePengadaanRepository = metodePengadaanRepository;
}
@Override
public MetodePengadaanResponse execute(MetodePengadaanRequest input) {
var existMetodePengadaan = metodePengadaanRepository.findByMetodePengadaanAndIsDeleteFalse(input.getMetodePengadaan());
if (existMetodePengadaan.isPresent()) {
throw new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10002,
Constants.ERR_TTL_10002,
String.format(Constants.ERR_MSG_10002, input.getMetodePengadaan()));
}
MetodePengadaan metodePengadaan = MetodePengadaan.builder()
.metodePengadaan(input.getMetodePengadaan())
.keterangan(input.getKeterangan())
.isActive(input.getIsActive())
.isDelete(false)
.build();
var result = metodePengadaanRepository.save(metodePengadaan);
log.info("success insert metode pengadaan id : {}", result.getId());
return MetodePengadaanResponse.builder()
.id(result.getId())
.build();
}
}

View File

@@ -0,0 +1,44 @@
package com.iconplus.smartproc.service.metodepengadaan;
import com.iconplus.smartproc.exception.BusinessException;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.request.MetodePengadaanRequest;
import com.iconplus.smartproc.model.response.MetodePengadaanResponse;
import com.iconplus.smartproc.repository.MetodePengadaanRepository;
import com.iconplus.smartproc.util.Constants;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.BooleanUtils;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Service;
import java.sql.Timestamp;
@Service
@Slf4j
public class PutUpdateMetodePengadaanService implements BaseService<MetodePengadaanRequest, MetodePengadaanResponse> {
private MetodePengadaanRepository metodePengadaanRepository;
public PutUpdateMetodePengadaanService(MetodePengadaanRepository metodePengadaanRepository) {
this.metodePengadaanRepository = metodePengadaanRepository;
}
@Override
public MetodePengadaanResponse execute(MetodePengadaanRequest input) {
var metodePengadaan = metodePengadaanRepository.findByIdAndIsDeleteFalse(input.getId())
.orElseThrow(() -> new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10001,
Constants.ERR_TTL_10001,
String.format(Constants.ERR_MSG_10001, input.getId())));
metodePengadaan.setMetodePengadaan(input.getMetodePengadaan());
metodePengadaan.setKeterangan(input.getKeterangan());
metodePengadaan.setIsActive(input.getIsActive());
metodePengadaanRepository.save(metodePengadaan);
log.info("Success edit metode pengadaan id {}", metodePengadaan.getId());
return MetodePengadaanResponse.builder()
.id(metodePengadaan.getId())
.build();
}
}