Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Get orders by Customer Id #537

Merged
merged 7 commits into from
Oct 5, 2023
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 25 additions & 0 deletions order-service/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,5 +14,30 @@
* Actuator Endpoint: http://localhost:18282/order-service/actuator
* Catalog Service : http://localhost:18080/catalog-service/swagger-ui.html

## Running only this Service Locally - Tips

To run only the Order Service locally with clean logs, you can follow these steps:



1.start the Kafka and Postgres servers by using below command(You should be inside appropriate directory and docker setup should be done :- ) :
```shell
docker compose up kafka postgres
```
2.In IntelIj Open Modify Run Configuration from Main class:
`com.example.orderservice.OrderServiceApplication`
Set the Environment variable value to
```text
SPRING_PROFILES_ACTIVE=local
```

3.In case local profile doesn't due to any issues possible not able to connect to postgresDB
Modify the Environment Variable Value as below this brings application up by connecting to H2 database.
```text
SPRING_PROFILES_ACTIVE=local1
```



### Notes
* KafkaStream DeadLetter is configured in `KafkaStreamsConfig.java`
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
/***
<p>
Licensed under MIT License Copyright (c) 2023 Raja Kolli.
</p>
***/

package com.example.common.dtos;
rajadilipkolli marked this conversation as resolved.
Show resolved Hide resolved

import jakarta.validation.constraints.NotEmpty;
import jakarta.validation.constraints.Positive;
import java.io.Serializable;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class OrderResponse implements Serializable {

private Long orderId;

@Positive(message = "CustomerId should be positive")
manepullavamsi marked this conversation as resolved.
Show resolved Hide resolved
private Long customerId;

private String status = "NEW";

private String source;

private LocalDateTime createdDate;

@NotEmpty(message = "Order without items not valid")
rajadilipkolli marked this conversation as resolved.
Show resolved Hide resolved
private List<OrderItemDto> items = new ArrayList<>();
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ Licensed under MIT License Copyright (c) 2021-2023 Raja Kolli.

import com.example.common.dtos.OrderDto;
import com.example.common.dtos.OrderItemDto;
import com.example.common.dtos.OrderResponse;
import com.example.orderservice.entities.Order;
import com.example.orderservice.entities.OrderItem;
import com.example.orderservice.model.request.OrderItemRequest;
Expand Down Expand Up @@ -65,4 +66,7 @@ default void addOrderItemRequestToOrderEntity(
@Mapping(target = "lastModifiedBy", ignore = true)
@Mapping(target = "lastModifiedDate", ignore = true)
void updateOrderFromOrderRequest(OrderRequest orderRequest, @MappingTarget Order order);

@Mapping(source = "id", target = "orderId")
OrderResponse toResponse(Order order);
}
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,11 @@ public interface OrderRepository extends JpaRepository<Order, Long> {
@Query("select o from Order o join fetch o.items oi where o.id = :id")
Optional<Order> findOrderById(@Param("id") Long id);

@Query(
value = "select o from Order o join fetch o.items oi where o.customerId = :customerId",
countQuery = "select count(o) from Order o where o.customerId=:customerId")
Page<Order> findByCustomerId(@Param("customerId") Long customerId, Pageable pageable);

@Modifying
@Transactional
@Query("update Order o set o.status =:status, o.source =:source where o.id = :id")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ Licensed under MIT License Copyright (c) 2021-2023 Raja Kolli.
package com.example.orderservice.services;

import com.example.common.dtos.OrderDto;
import com.example.common.dtos.OrderResponse;
import com.example.orderservice.config.logging.Loggable;
import com.example.orderservice.entities.Order;
import com.example.orderservice.exception.ProductNotFoundException;
Expand Down Expand Up @@ -124,4 +125,27 @@ public Optional<Order> findById(Long id) {
public Optional<OrderDto> findOrderByIdAsDto(Long id) {
return orderRepository.findOrderById(id).map(this.orderMapper::toDto);
}

public PagedResult<OrderResponse> getOrdersByCustomerId(Long customerId, Pageable pageable) {
var ordersList = orderRepository.findByCustomerId(customerId, pageable);
List<CompletableFuture<OrderResponse>> completableFutureList =
ordersList.stream()
.map(
order ->
CompletableFuture.supplyAsync(
() -> this.orderMapper.toResponse(order)))
.toList();
// Joining all completeable future to get DTOs
List<OrderResponse> orderListDto =
completableFutureList.stream().map(CompletableFuture::join).toList();
return new PagedResult<>(
orderListDto,
ordersList.getTotalElements(),
ordersList.getNumber(),
ordersList.getTotalPages(),
ordersList.isFirst(),
ordersList.isLast(),
ordersList.hasNext(),
ordersList.hasPrevious());
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ Licensed under MIT License Copyright (c) 2021-2023 Raja Kolli.
package com.example.orderservice.web.controllers;

import com.example.common.dtos.OrderDto;
import com.example.common.dtos.OrderResponse;
import com.example.orderservice.model.request.OrderRequest;
import com.example.orderservice.model.response.PagedResult;
import com.example.orderservice.services.OrderGeneratorService;
Expand All @@ -18,6 +19,7 @@ Licensed under MIT License Copyright (c) 2021-2023 Raja Kolli.
import java.net.URI;
import java.util.List;
import lombok.RequiredArgsConstructor;
import org.springframework.data.domain.Pageable;
import org.springframework.http.ResponseEntity;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.DeleteMapping;
Expand Down Expand Up @@ -131,4 +133,10 @@ public List<OrderDto> all(
int pageSize) {
return orderKafkaStreamService.getAllOrders(pageNo, pageSize);
}

@GetMapping("customer/id")
public ResponseEntity<PagedResult<OrderResponse>> ordersByCustomerId(
rajadilipkolli marked this conversation as resolved.
Show resolved Hide resolved
@RequestParam Long customerId, Pageable pageable) {
return ResponseEntity.ok(orderService.getOrdersByCustomerId(customerId, pageable));
}
}
2 changes: 2 additions & 0 deletions order-service/src/main/resources/application-local.properties
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ spring.datasource.url=jdbc:postgresql://localhost:5432/appdb
spring.datasource.username=appuser
spring.datasource.password=secret

spring.cloud.config.enabled=false
rajadilipkolli marked this conversation as resolved.
Show resolved Hide resolved

application.catalog-service-url=http://localhost:18080/catalog-service

spring.config.import=optional:configserver:${CONFIG_SERVER:http://localhost:8888}/
15 changes: 14 additions & 1 deletion order-service/src/main/resources/application.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,21 @@ server:
servlet:
contextPath: /${spring.application.name}
forward-headers-strategy: framework

application:
catalog-service-url: http://localhost:18080/catalog-service
spring:
cloud:
rajadilipkolli marked this conversation as resolved.
Show resolved Hide resolved
config:
enabled: false
datasource:
url: jdbc:h2:file:/data/demo
username: sa
password: password
driverClassName: org.h2.Driver
jpa:
spring.jpa.database-platform: org.hibernate.dialect.H2Dialect
config:
import: optional:configserver:${CONFIG_SERVER:http://localhost:8888}/
application:
name: order-service
threads.virtual.enabled: true
Expand Down