Documentation
¶
Overview ¶
Package webgo is a lightweight framework for building web apps. It has a multiplexer, middleware plugging mechanism & context management of its own. The primary goal of webgo is to get out of the developer's way as much as possible. i.e. it does not enforce you to build your app in any particular pattern, instead just helps you get all the trivial things done faster and easier.
e.g. 1. Getting named URI parameters. 2. Multiplexer for regex matching of URI and such. 3. Inject special app level configurations or any such objects to the request context as required.
Index ¶
- Constants
- Variables
- func R200(w http.ResponseWriter, data interface{})
- func R201(w http.ResponseWriter, data interface{})
- func R204(w http.ResponseWriter)
- func R302(w http.ResponseWriter, data interface{})
- func R400(w http.ResponseWriter, data interface{})
- func R403(w http.ResponseWriter, data interface{})
- func R404(w http.ResponseWriter, data interface{})
- func R406(w http.ResponseWriter, data interface{})
- func R451(w http.ResponseWriter, data interface{})
- func R500(w http.ResponseWriter, data interface{})
- func Render(w http.ResponseWriter, data interface{}, rCode int, tpl *template.Template)
- func Render404(w http.ResponseWriter, tpl *template.Template)
- func Send(w http.ResponseWriter, contentType string, data interface{}, rCode int)
- func SendError(w http.ResponseWriter, data interface{}, rCode int)
- func SendHeader(w http.ResponseWriter, rCode int)
- func SendResponse(w http.ResponseWriter, data interface{}, rCode int)
- type Config
- type ErrorData
- type Logger
- type Route
- type Router
- func (rtr *Router) ServeHTTP(rw http.ResponseWriter, req *http.Request)
- func (router *Router) Shutdown() error
- func (router *Router) ShutdownHTTPS() error
- func (router *Router) Start()
- func (router *Router) StartHTTPS()
- func (rtr *Router) Use(f func(http.ResponseWriter, *http.Request, http.HandlerFunc))
- type WC
Constants ¶
const ( // HeaderContentType is the key for mentioning the response header content type HeaderContentType = "Content-Type" // JSONContentType is the MIME type when the response is JSON JSONContentType = "application/json" // HTMLContentType is the MIME type when the response is HTML HTMLContentType = "text/html; charset=UTF-8" // ErrInternalServer to send when there's an internal server error ErrInternalServer = "Internal server error." )
Variables ¶
var ( // ErrInvalidPort is the error returned when the port number provided in the config file is invalid ErrInvalidPort = errors.New("Port number not provided or is invalid (should be between 0 - 65535)") )
Functions ¶
func R400 ¶
func R400(w http.ResponseWriter, data interface{})
R400 - Invalid request, any incorrect/erraneous value in the request body
func R406 ¶
func R406(w http.ResponseWriter, data interface{})
R406 - Unacceptable header. For any error related to values set in header
func R451 ¶
func R451(w http.ResponseWriter, data interface{})
R451 - Resource taken down because of a legal request
func Render ¶
func Render(w http.ResponseWriter, data interface{}, rCode int, tpl *template.Template)
Render is used for rendering templates (HTML)
func Render404 ¶
func Render404(w http.ResponseWriter, tpl *template.Template)
Render404 - used to render a 404 page
func Send ¶
func Send(w http.ResponseWriter, contentType string, data interface{}, rCode int)
Send sends a completely custom response without wrapping in the `{data: <data>, status: <int>` struct
func SendError ¶
func SendError(w http.ResponseWriter, data interface{}, rCode int)
SendError is used to respond to any request with an error
func SendHeader ¶
func SendHeader(w http.ResponseWriter, rCode int)
SendHeader is used to send only a response header, i.e no response body
func SendResponse ¶
func SendResponse(w http.ResponseWriter, data interface{}, rCode int)
SendResponse is used to respond to any request (JSON response) based on the code, data etc.
Types ¶
type Config ¶
type Config struct { // Host is the host on which the server is listening Host string `json:"host,omitempty"` // Port is the port number where the server has to listen for the HTTP requests Port string `json:"port,omitempty"` // CertFile is the TLS/SSL certificate file path, required for HTTPS CertFile string `json:"certFile,omitempty"` // KeyFile is the filepath of private key of the certificate KeyFile string `json:"keyFile,omitempty"` // HTTPSPort is the port number where the server has to listen for the HTTP requests HTTPSPort string `json:"httpsPort,omitempty"` // ReadTimeout is the maximum duration for which the server would read a request ReadTimeout time.Duration `json:"readTimeout,omitempty"` // WriteTimeout is the maximum duration for which the server would try to respond WriteTimeout time.Duration `json:"writeTimeout,omitempty"` // InsecureSkipVerify is the HTTP certificate verification InsecureSkipVerify bool `json:"insecureSkipVerify,omitempty"` // ShutdownTimeout is the duration in which graceful shutdown is completed, in seconds ShutdownTimeout time.Duration }
Config is used for reading app's configuration from json file
type Logger ¶
type Logger interface { Debug(data ...interface{}) Info(data ...interface{}) Warn(data ...interface{}) Error(data ...interface{}) Fatal(data ...interface{}) }
Service defines all the logging methods to be implemented
var LOGHANDLER Logger
type Route ¶
type Route struct { // Name is unique identifier for the route Name string // Method is the HTTP request method/type Method string // Pattern is the URI pattern to match Pattern string // TrailingSlash if set to true, the URI will be matched with or without // a trailing slash. Note: It does not *do* a redirect. TrailingSlash bool // FallThroughPostResponse if enabled will execute all the handlers even if a response was already sent to the client FallThroughPostResponse bool // Handlers is a slice of http.HandlerFunc which can be middlewares or anything else. Though only 1 of them will be allowed to respond to client. // subsequent writes from the following handlers will be ignored Handlers []http.HandlerFunc // contains filtered or unexported fields }
Route defines a route for each API
type Router ¶
type Router struct { // NotFound is the generic handler for 404 resource not found response NotFound http.HandlerFunc // AppContext holds all the app specific context which is to be injected into all HTTP // request context AppContext map[string]interface{} // contains filtered or unexported fields }
Router is the HTTP router
func NewRouter ¶
NewRouter initializes returns a new router instance with all the configurations and routes set
func (*Router) ShutdownHTTPS ¶
ShutdownHTTPS gracefully shuts down HTTPS server
func (*Router) Start ¶
func (router *Router) Start()
Start starts the HTTP server with the appropriate configurations
func (*Router) StartHTTPS ¶
func (router *Router) StartHTTPS()
StartHTTPS starts the server with HTTPS enabled
func (*Router) Use ¶
func (rtr *Router) Use(f func(http.ResponseWriter, *http.Request, http.HandlerFunc))
Use adds a middleware layer
Directories
¶
Path | Synopsis |
---|---|
Package middleware defines the signature/type which can be added as a middleware to Webgo.
|
Package middleware defines the signature/type which can be added as a middleware to Webgo. |