0 purchases
annotated shelf
Powerful, Lightweight, Fast development, Easy to learn
Documentation: #
https://annotated-shelf.readthedocs.io/en/features-add_docs/Rest/index.html
Annotated Shelf is a powerful and lightweight Dart framework for generating REST APIs using annotations. Based on the popular Shelf library. Annotated Shelf provides a simple and intuitive interface for building APIs fast, efficiently, and easy to use without losing what Shelf can offer.
Features #
Support for multiple HTTP methods and request types.
Support for File upload.
Automatic validation of request parameters.
Automatic Error responses based on exceptions.
Installation #
To install Annotated Shelf, add it as a dependency in your pubspec.yaml file:
dependencies:
annotated_shelf: ^0.1.0
copied to clipboard
Then, run pub get to install the package.
Getting Started #
To use Annotated Shelf to create a REST API, import the library and annotate your models and controllers with the following annotations:
@RestAPI,
@GET,
@POST,
@PUT,
@DELETE,
@PATCH,
copied to clipboard
Annotated Shelf will automatically generate the necessary routes and endpoints based on the annotations you have provided.
Example #
import 'package:annotated_shelf/annotated_shelf.dart';
import 'package:shelf/shelf.dart';
import 'package:shelf/shelf_io.dart' as io;
const _hostname = 'localhost';
const _port = 8080;
var itemsList = [Item("first item"), Item("second Item")];
class Item extends Payload {
final String? name;
Item(this.name);
@override
factory Item.fromJson(Map<String, dynamic> json) {
return Item(json["name"]);
}
@override
Map<String, dynamic> toJson() => {"name": name};
}
class TestForm extends Form {
String name;
int number;
File image;
TestForm(this.name, this.number, this.image);
@override
factory TestForm.fromJson(Map<String, dynamic> json) {
return TestForm(
json['name'] as String,
json['number'] as int,
File.fromJson(json['image'] as Map<String, dynamic>),
);
}
@override
Map<String, dynamic> toJson() => <String, dynamic>{
'name': name,
'number': number,
'image': image,
};
}
@RestAPI(baseUrl: '/to-do/list')
class ItemsAdaptor {
@GET()
List<Item> getAllItems(Request request) {
return itemsList;
}
@GET(url: "/<itemName>")
Item getItemByName(String itemName) {
var index = itemsList.lastIndexWhere((element) => element.name == itemName);
if (index >= 0) {
return itemsList[index];
} else {
throw NotFoundError('item not found'); // this creates a 404 response
}
}
@PUT(url: "/<itemName>")
Item updateItem(Item item, String itemName) {
var index = itemsList.lastIndexWhere((element) => element.name == itemName);
if (index >= 0) {
itemsList[index] = item;
return getItemByName(item.name ?? '');
} else {
throw NotFoundError('item not found'); // this creates a 404 response
}
}
@POST(url: "/")
Response createNewItem(Item item) {
var index =
itemsList.lastIndexWhere((element) => element.name == item.name);
if (index == -1) {
itemsList.add(item);
return Response(201); // pass a shelf response
} else {
throw BadRequestError('item with name in list');
}
}
// examplo of uploading a file
@POST(url: '/upload')
Future<RestResponse> upload(TestForm form) async {
print(form);
return new RestResponse(201, {"msj": 'ok'}, "application/json");
}
}
Future<void> main(List<String> args) async {
var router = Cascade();
router = await mount(ItemsAdaptor(), router);
var server = await io.serve(router.handler, _hostname, _port);
print('Serving at http://${server.address.host}:${server.port}');
}
/*
-------------------------------------
mounting Instance of 'ItemsAdaptor'
adding get to-do/list
adding get to-do/list/<iteName>
adding put to-do/list/<iteName>
adding post to-do/list/
adding post to-do/list/upload
-------------------------------------
Serving at http://localhost:8080
*/
copied to clipboard
Contributing #
We welcome contributions to Annotation Shelf! If you have an idea for a new feature or have found a bug, please open an issue on GitHub.
License #
Annotation Shelf is released under the BSD-3-Clause. See LICENSE for details.
thanks #
Special thanks to the Shelf project team for providing us with the opportunity to create servers using this beautiful language.
For personal and professional use. You cannot resell or redistribute these repositories in their original state.
There are no reviews.