http_annotations 0.0.3 http_annotations: ^0.0.3 copied to clipboard
http annotation for code generation
Provides annotations for http code gen
-
Add the generated file as a part of this file and annotate your class with @HttpApi()
part 'file_name.http.dart'; @HttpApi('http://localhost:3000') abstract class MyApi { // create a factory redirect (this is required) factory MyApi() = _MyApi; // optional close method to dispose resources void close(); }
-
Annotate methods with appropirate HTTP Method and path
@Route.get('/api/v0/todos') Future<List<Todo>> getTodos();
Parameter replacement support
@Route.get('/api/v0/todo/{id}') Future<Todo> getTodo(int id);
-
Annotate methods with headers
@Route.get('/api/v0/todos') @Header.contentTypeJson() @Header('cache', 'never') Future<List<Todo>> getTodos();
-
Annotate methods with HTTP status codes that have body
By default only status code 200 is supported Example, if you want to add for status codes 400 and 401
@Route.get('/api/v0/user/login') @StatusCodesWithBody([200, 400, 401]) Future<LoginResponse> login();
-
Annotate a parameter with the body of the request (post, put, patch, delete)
@Route.post('/api/v0/todo') Future<CreateTodoResponse>(@Body() Map<String, dynamic> json);
-
Annotate a parameter with query parameter
@Route.get('/api/v0/todos') Future<List<Todo>>( @QueryParam() int page, @QueryParam('named_limit') int limit, );