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