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.strategipengadaan;
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.StrategiPengadaanRequest;
import com.iconplus.smartproc.repository.StrategiPengadaanRepository;
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 DeleteStrategiPengadaanService implements BaseService<StrategiPengadaanRequest, EmptyResponse> {
private StrategiPengadaanRepository strategiPengadaanRepository;
public DeleteStrategiPengadaanService(StrategiPengadaanRepository strategiPengadaanRepository) {
this.strategiPengadaanRepository = strategiPengadaanRepository;
}
@Override
public EmptyResponse execute(StrategiPengadaanRequest input) {
var strategiPengadaan = strategiPengadaanRepository.findByIdAndIsDeleteFalse(input.getId())
.orElseThrow(() -> new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10001,
Constants.ERR_TTL_10001,
String.format(Constants.ERR_MSG_10001, input.getId())));
strategiPengadaan.setIsDelete(true);
strategiPengadaanRepository.save(strategiPengadaan);
log.info("success delete strategi pengadaan id {}", strategiPengadaan.getIsDelete());
return new EmptyResponse();
}
}

View File

@@ -0,0 +1,61 @@
package com.iconplus.smartproc.service.strategipengadaan;
import com.iconplus.smartproc.helper.model.Pagination;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.projection.StrategiPengadaanView;
import com.iconplus.smartproc.model.request.StrategiPengadaanRequest;
import com.iconplus.smartproc.model.response.GetListStrategiPengadaanResponse;
import com.iconplus.smartproc.model.response.StrategiPengadaanResponse;
import com.iconplus.smartproc.repository.StrategiPengadaanRepository;
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 GetListStrategiPengadaanService implements BaseService<StrategiPengadaanRequest, GetListStrategiPengadaanResponse> {
private StrategiPengadaanRepository strategiPengadaanRepository;
public GetListStrategiPengadaanService(StrategiPengadaanRepository strategiPengadaanRepository) {
this.strategiPengadaanRepository = strategiPengadaanRepository;
}
@Override
public GetListStrategiPengadaanResponse execute(StrategiPengadaanRequest input) {
validateRequest(input);
List<StrategiPengadaanResponse> strategiPengadaanResponseList = new ArrayList<>();
Page<StrategiPengadaanView> strategiPengadaanViews = strategiPengadaanRepository.getAllStrategiPengadaan(input.getSearch(), input.getPageable());
for (StrategiPengadaanView strategiPengadaanView : strategiPengadaanViews) {
StrategiPengadaanResponse strategiPengadaanResponse = StrategiPengadaanResponse.builder()
.id(strategiPengadaanView.getId())
.strategiPengadaan(strategiPengadaanView.getStrategiPengadaan())
.keterangan(strategiPengadaanView.getKeterangan())
.isActive(strategiPengadaanView.getIsActive())
.isDelete(strategiPengadaanView.getIsDelete())
.build();
strategiPengadaanResponseList.add(strategiPengadaanResponse);
}
return GetListStrategiPengadaanResponse.builder()
.data(strategiPengadaanResponseList)
.pagination(Pagination.builder()
.pageSize(input.getPageable().getPageSize())
.currentPage(input.getPageable().getPageNumber())
.totalPages(strategiPengadaanViews.getTotalPages())
.totalRecords(strategiPengadaanViews.getTotalElements())
.isFirstPage(strategiPengadaanViews.isFirst())
.isLastPage(strategiPengadaanViews.isLast())
.build())
.build();
}
private void validateRequest(StrategiPengadaanRequest input) {
if (StringUtils.isNotBlank(input.getSearch())) {
input.setSearch('%'+ input.getSearch().toUpperCase()+'%');
}
}
}

View File

@@ -0,0 +1,39 @@
package com.iconplus.smartproc.service.strategipengadaan;
import com.iconplus.smartproc.exception.BusinessException;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.request.StrategiPengadaanRequest;
import com.iconplus.smartproc.model.response.StrategiPengadaanResponse;
import com.iconplus.smartproc.repository.StrategiPengadaanRepository;
import com.iconplus.smartproc.util.Constants;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Service;
@Service
public class GetStrategiPengadaanByIdService implements BaseService<StrategiPengadaanRequest, StrategiPengadaanResponse> {
private final StrategiPengadaanRepository strategiPengadaanRepository;
public GetStrategiPengadaanByIdService(StrategiPengadaanRepository strategiPengadaanRepository) {
this.strategiPengadaanRepository = strategiPengadaanRepository;
}
@Override
public StrategiPengadaanResponse execute(StrategiPengadaanRequest input) {
var strategiPengadaanView = strategiPengadaanRepository.findByIdAndIsDeleteFalse(input.getId());
if (strategiPengadaanView.isEmpty()) {
throw new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10001,
Constants.ERR_TTL_10001,
String.format(Constants.ERR_MSG_10001, input.getId()));
}
return StrategiPengadaanResponse.builder()
.id(strategiPengadaanView.get().getId())
.strategiPengadaan(strategiPengadaanView.get().getStrategiPengadaan())
.keterangan(strategiPengadaanView.get().getKeterangan())
.isActive(strategiPengadaanView.get().getIsActive())
.isDelete(strategiPengadaanView.get().getIsDelete())
.build();
}
}

View File

@@ -0,0 +1,49 @@
package com.iconplus.smartproc.service.strategipengadaan;
import com.iconplus.smartproc.exception.BusinessException;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.entity.StrategiPengadaan;
import com.iconplus.smartproc.model.request.StrategiPengadaanRequest;
import com.iconplus.smartproc.model.response.StrategiPengadaanResponse;
import com.iconplus.smartproc.repository.StrategiPengadaanRepository;
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 PostCreateStrategiPengadaanService implements BaseService<StrategiPengadaanRequest, StrategiPengadaanResponse> {
private final StrategiPengadaanRepository strategiPengadaanRepository;
public PostCreateStrategiPengadaanService(StrategiPengadaanRepository strategiPengadaanRepository) {
this.strategiPengadaanRepository = strategiPengadaanRepository;
}
@Override
public StrategiPengadaanResponse execute(StrategiPengadaanRequest input) {
var existStrategiPengadaan = strategiPengadaanRepository.findByStrategiPengadaanAndIsDeleteFalse(input.getStrategiPengadaan());
if (existStrategiPengadaan.isPresent()) {
throw new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10002,
Constants.ERR_TTL_10002,
String.format(Constants.ERR_MSG_10002, input.getStrategiPengadaan()));
}
StrategiPengadaan strategiPengadaan = StrategiPengadaan.builder()
.strategiPengadaan(input.getStrategiPengadaan())
.keterangan(input.getKeterangan())
.isActive(input.getIsActive())
.isDelete(false)
.build();
var result = strategiPengadaanRepository.save(strategiPengadaan);
log.info("success insert strategi pengadaan id : {}", result.getId());
return StrategiPengadaanResponse.builder()
.id(result.getId())
.build();
}
}

View File

@@ -0,0 +1,44 @@
package com.iconplus.smartproc.service.strategipengadaan;
import com.iconplus.smartproc.exception.BusinessException;
import com.iconplus.smartproc.helper.service.BaseService;
import com.iconplus.smartproc.model.request.StrategiPengadaanRequest;
import com.iconplus.smartproc.model.response.StrategiPengadaanResponse;
import com.iconplus.smartproc.repository.StrategiPengadaanRepository;
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 PutUpdateStrategiPengadaanService implements BaseService<StrategiPengadaanRequest, StrategiPengadaanResponse> {
private StrategiPengadaanRepository strategiPengadaanRepository;
public PutUpdateStrategiPengadaanService(StrategiPengadaanRepository strategiPengadaanRepository) {
this.strategiPengadaanRepository = strategiPengadaanRepository;
}
@Override
public StrategiPengadaanResponse execute(StrategiPengadaanRequest input) {
var strategiPengadaan = strategiPengadaanRepository.findByIdAndIsDeleteFalse(input.getId())
.orElseThrow(() -> new BusinessException(HttpStatus.CONFLICT,
Constants.ERR_CODE_10001,
Constants.ERR_TTL_10001,
String.format(Constants.ERR_MSG_10001, input.getId())));
strategiPengadaan.setStrategiPengadaan(input.getStrategiPengadaan());
strategiPengadaan.setKeterangan(input.getKeterangan());
strategiPengadaan.setIsActive(input.getIsActive());
strategiPengadaanRepository.save(strategiPengadaan);
log.info("Success edit strategi pengadaan id {}", strategiPengadaan.getId());
return StrategiPengadaanResponse.builder()
.id(strategiPengadaan.getId())
.build();
}
}