You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This proposal introduces support for "API Schemas" in the Fiber framework, inspired by the implementation in [Encore](https://encore.dev/docs/go/primitives/defining-apis). API Schemas allow developers to define HTTP APIs declaratively using Go structs, enabling seamless type safety, validation, and automated documentation generation.
Key benefits of API Schemas include:
Type-Safe API Definitions: Ensures compile-time safety by leveraging Go’s type system to define endpoints, request bodies, and response structures.
Validation and Consistency: Enforces schema-based validation for request and response data, improving API robustness.
Ease of Use: Simplifies the process of creating, maintaining, and evolving APIs in Fiber applications.
By adopting this feature, Fiber can elevate its usability for developers building modern, scalable REST APIs, while ensuring best practices for API design.
Conclusion
Adding support for API Schemas in Fiber V3 will greatly enhance the framework’s functionality, enabling developers to define APIs in a structured, type-safe, and declarative manner. This feature aligns Fiber with modern API development practices, bridging the gap between simplicity and scalability while ensuring adherence to HTTP standards and long-term stability.
Let’s make Fiber V3 the go-to framework for robust Go-based API development! ;P
Alignment with Express API
The addition of API Schemas aligns Fiber closer to Express.js-like API frameworks. Fiber has traditionally emphasized high performance and simplicity, but Express’s ecosystem thrives due to middleware and declarative features like JSON Schema validations (via libraries). API Schemas in Fiber would natively close this gap, allowing for similar or enhanced developer experiences in Go.
HTTP RFC Standards Compliance
API Schemas inherently adhere to HTTP RFC standards by standardizing request and response structures based on predefined schemas. This ensures that:
HTTP methods (GET, POST, etc.) and status codes align with defined API behaviors.
Headers, query parameters, and bodies comply with schema definitions, enabling better compatibility and client-server integration.
Including such standards compliance natively in Fiber will boost its adoption for enterprise-grade applications requiring strict adherence to HTTP specifications.
API Stability
Integrating API Schemas would also provide a clear foundation for API versioning and backward compatibility:
Versioned Schemas: Developers can define multiple schemas for different versions of an API, ensuring smooth migrations.
Static Analysis: Compile-time type checking reduces runtime errors and ensures that API changes are predictable.
Schema Validation Tools: Fiber could include built-in or pluggable tools for validating API stability during development and deployment.
By focusing on these aspects, API Schemas in Fiber will promote stable and reliable APIs that are future-proof and maintainable.
Feature Examples
// PingParams is the request data for the Ping endpoint.typePingParamsstruct {
Headerstring`f_header:"X-Header"`// this field will be read from the http headerQuerystring`f_query:"q"`// this field will be read from the query stringCompanystring`f_url:"company"`// this field will be read from the URL pathIDstring`f_url:"id"`Namestring`json:"name"`
}
// PingResponse is the response data for the Ping endpoint.typePingResponsestruct {
Messagestring
}
// Ping is an API endpoint that responds with a simple response.// This is exposed as "/project/:company/:id?q=foo".////fiber:api method=POST path=/project/:company/:idfuncPing(c*fiber.Ctx, params*PingParams) (*PingResponse, error) {
msg:=fmt.Sprintf("hello %s", params.Name)
return&PingResponse{Message: msg}, nil
}
Feature Proposal Description
This proposal introduces support for "API Schemas" in the Fiber framework, inspired by the implementation in [Encore](https://encore.dev/docs/go/primitives/defining-apis). API Schemas allow developers to define HTTP APIs declaratively using Go structs, enabling seamless type safety, validation, and automated documentation generation.
Key benefits of API Schemas include:
By adopting this feature, Fiber can elevate its usability for developers building modern, scalable REST APIs, while ensuring best practices for API design.
Conclusion
Adding support for API Schemas in Fiber V3 will greatly enhance the framework’s functionality, enabling developers to define APIs in a structured, type-safe, and declarative manner. This feature aligns Fiber with modern API development practices, bridging the gap between simplicity and scalability while ensuring adherence to HTTP standards and long-term stability.
Let’s make Fiber V3 the go-to framework for robust Go-based API development! ;P
Alignment with Express API
The addition of API Schemas aligns Fiber closer to Express.js-like API frameworks. Fiber has traditionally emphasized high performance and simplicity, but Express’s ecosystem thrives due to middleware and declarative features like JSON Schema validations (via libraries). API Schemas in Fiber would natively close this gap, allowing for similar or enhanced developer experiences in Go.
HTTP RFC Standards Compliance
API Schemas inherently adhere to HTTP RFC standards by standardizing request and response structures based on predefined schemas. This ensures that:
Including such standards compliance natively in Fiber will boost its adoption for enterprise-grade applications requiring strict adherence to HTTP specifications.
API Stability
Integrating API Schemas would also provide a clear foundation for API versioning and backward compatibility:
By focusing on these aspects, API Schemas in Fiber will promote stable and reliable APIs that are future-proof and maintainable.
Feature Examples
Checklist:
The text was updated successfully, but these errors were encountered: