add master data api
This commit is contained in:
@@ -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();
|
||||
}
|
||||
}
|
@@ -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()+'%');
|
||||
}
|
||||
}
|
||||
}
|
@@ -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();
|
||||
}
|
||||
}
|
@@ -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();
|
||||
|
||||
}
|
||||
}
|
@@ -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();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user