Merge pull request #12145 from amitiw4u/BAEL-5295_RequestLine

Initial Changes for RequestLine
This commit is contained in:
Greg Martin 2022-05-23 12:30:21 -04:00 committed by GitHub
commit 545926bd86
3 changed files with 49 additions and 0 deletions

View File

@ -0,0 +1,12 @@
package com.baeldung.cloud.openfeign.client;
import com.baeldung.cloud.openfeign.model.Employee;
import feign.Headers;
import feign.Param;
import feign.RequestLine;
public interface EmployeeClient {
@RequestLine("GET /empployee/{id}?active={isActive}")
@Headers("Content-Type: application/json")
Employee getEmployee(@Param long id, @Param boolean isActive);
}

View File

@ -0,0 +1,22 @@
package com.baeldung.cloud.openfeign.controller;
import com.baeldung.cloud.openfeign.client.EmployeeClient;
import com.baeldung.cloud.openfeign.model.Employee;
import feign.Feign;
import feign.form.spring.SpringFormEncoder;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class EmployeeController {
private static final String HTTP_FILE_EMPLOYEE_URL = "http://localhost:8081";
@GetMapping("/employee/{id}")
public Employee getEmployee(@RequestParam("id") long id) {
EmployeeClient employeeResource = Feign.builder().encoder(new SpringFormEncoder())
.target(EmployeeClient.class, HTTP_FILE_EMPLOYEE_URL);
return employeeResource.getEmployee(id, true);
}
}

View File

@ -0,0 +1,15 @@
package com.baeldung.cloud.openfeign.model;
public class Employee {
private Long id;
private String name;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
}