Web API Scaffolding
Key points
What is API ?
What is Scaffolding ?
How to do it ?
Best Practices of API
What is api ?
Application Programming Interface
- An API is a set of definitions and protocols for building and integrating application software.
- APIs let your product or service communicate with other products and services without having to know how they’re implemented. This can simplify app development, saving time and money.
What is Scaffolding ?
Scaffolding is a code generation framework
Scaffolding, as used in computing, refers to one of two techniques: The first is a code generation technique related to database access in some model–view–controller frameworks; the second is a project generation technique supported by various tools.
There are two options for scaffolding MVC; Minimal and Full. If you select Minimal, only the NuGet packages and references for ASP.NET MVC are added to your project. If you select the Full option, the Minimal dependencies are added, as well as the required content files for an MVC project. To easily use scaffolding, select Full dependencies.
How to do it?
- Scaffolding By Database via Entity Framework
- Scaffolding by open api specification document like swagger Or other client-side tool like postman
How to do it ?
- Create Database or use old created database
- Create .NET Core Project – Choose API template while creating project
- Install NuGet packages like Entity Framework Core, Entity Framework Core Tools, Entity Framework Core Design, Entity Framework Core SQL, Entity Framework Core SQL Design
- Open Package Manage Console and execute command: Scaffold-DbContext "Server=.;Database=SchoolDB;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models
- Go to controller folder and add new scaffolded item or Controller.
- Choose API controller with Actions using Entity Framework
- Choose Model, Context and DB and Add
- Write your business code
Best practices of api
What to consider: Documentation, Stability and Consistency, Flexibility, Security
- Ease of Adoption
- Use JSON
- Use Nouns instead of Verbs - like - GET /books/123, DELETE /books/123, POST /books, PUT /books/123, PATCH /books/123
- Name the collections using Plural Nouns
- Use resource nesting to show relations or hierarchy
- Error Handling
- Filtering, sorting, paging, and field selection like Filtering: GET /users?country=USA, GET /users?creation_date=2019-11-11, GET /users?creation_date=2019-11-11
- Sorting: GET /users?sort=birthdate_date:asc, GET /users?sort=birthdate_date:desc
- Paging: GET /users?limit=100, GET /users?offset=2
- Versioning https://us6.api.mailchimp.com/3.0/ (major + minor version indication) https://api.stripe.com/v1/ (major version indication only) https://developer.github.com/v3/ (major version indication only) https://api.twilio.com/2010-04-01/ (date based indication)
- API Documentation
- Using SSL/TLS
Comments
Post a Comment