Api Declaration
Annotations on the interface methods and its parameters indicate how a request will be handled.
Request Method
Every method must have an HTTP annotation that provides the request method and relative path. There are eight built-in annotations: GET, POST, PUT, PATCH, DELETE, OPTIONS and HEAD. The relative path of the resource can be defined in the annotation.
@RestClient("client-one")
interface UserService {
@GET("api/v1/users")
List getUsers();
}
The purpose of the annotations in the code above is the following:
@RestClient
Identify this interface to be available as a REST Client@GET
define the http method
URL Manipulation
A request URL can be updated dynamically using replacement blocks and parameters on the method.
A replacement block is an alphanumeric string surrounded by {
and }
.
A corresponding parameter must be annotated with @Path using the same string or variable name.
@RestClient(value = "client-one", path = "api/v1/users")
interface UserService {
@GET("{id}")
User getUserById(@Path UUID id);
@GET("api/v1/users/{id}/profiles/{profile-id}")
User getUserProfile(@Path UUID id, @Path("profile-id") String profileId);
}
A query parameter can also be added:
@RestClient("client-one")
interface UserService {
// result: api/v1/users?sort=""&nickname=""
@GET("api/v1/users")
List<User> getAll(@Query String sort, @Query("nickname") String name);
}
Request Body
An object can be specified for use as an HTTP request body with the @Body
annotation.
@RestClient("client-one")
interface UserService {
@POST("api/v1/users")
User create(@Body User user);
}
Header Manipulation
You can set static headers for a method using the @Headers
annotation.
@RestClient("client-one")
interface UserService {
@Headers("x-ping: pong")
@POST("api/v1/users")
User create(@Body User user);
@Headers({
"Accept: application/txt",
"x-api-key: secret"
})
@PUT("api/v1/users")
User create(@Body User user);
@GET("api/v1/users")
User getUser(@Header("Authorization") String admin);
}