httpserver

package
v0.2.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 17, 2024 License: BSD-3-Clause Imports: 17 Imported by: 0

README

httpserver

The httpserver package implements the core functionality of a coder-based http server.

Getting Started

package main

import (
	"encoding/json"
	"net/http"

	"github.com/easy-techno-lab/proton/coder"
	"github.com/easy-techno-lab/proton/httpserver"
)

func main() {
	cdrJSON := coder.NewCoder("application/json", json.Marshal, json.Unmarshal, false)

	fmtJSON := httpserver.NewFormatter(cdrJSON)

	handlerFunc := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
		ctx := r.Context()

		if r.Method != http.MethodGet {
			req := &struct {
				// some fields
			}{}

			if err := fmtJSON.Decode(ctx, r.Body, req); err != nil {
				panic(err)
			}
		}

		res := &struct {
			ID int `json:"id"`
		}{ID: 1}

		fmtJSON.WriteResponse(ctx, w, http.StatusOK, res)
	})

	http.Handle("/example/", handlerFunc)

	if err := http.ListenAndServe(":8080", nil); err != nil {
		panic(err)
	}
}

For all responses with a body:
  • The default is to use the Content-Type set in the coder.
  • If you don't set the Content-Type in the coder, it will be set automatically by the net/http package.
  • If you need to set a different Content-Type you must set it before calling WriteResponse.
For all responses without a body:
  • Content-Type will not be set by default.
  • If you need to set Content-Type you must set it before calling WriteResponse.
package main

import (
	"fmt"
	"net/http"
	"time"

	"github.com/easy-techno-lab/proton/httpserver"
)

func main() {
	handlerFunc := http.HandlerFunc(func(w http.ResponseWriter, _ *http.Request) {
		w.WriteHeader(http.StatusOK)
		_, _ = fmt.Fprint(w, "Hello!")
	})

	handler := http.NewServeMux()
	handler.HandleFunc("/example/", handlerFunc)

	srv := new(http.Server)
	srv.Addr = ":8080"
	srv.Handler = handler

	hcr := new(httpserver.Controller)
	hcr.Server = srv
	hcr.GracefulTimeout = time.Second * 10

	if err := hcr.Start(); err != nil {
		panic(err)
	}
}

The httpserver package contains functions that are used as middleware on the http server side.

Getting Started

package main

import (
	"fmt"
	"log/slog"
	"net/http"

	"github.com/easy-techno-lab/proton/httpserver"
)

func main() {
	handlerFunc := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
		if _, err := fmt.Fprintln(w, "Hello World!"); err != nil {
			panic(err)
		}
	})

	http.Handle("/example/", handlerFunc)

	corsOpts := new(httpserver.CORSOptions)

	corsOpts.AllowOrigins = []string{"*"}
	corsOpts.AllowMethods = []string{"OPTIONS", "GET", "POST", "PUT", "PATCH", "DELETE"}
	corsOpts.AllowHeaders = []string{"Authorization", "Content-Type"}
	corsOpts.MaxAge = 86400
	corsOpts.AllowCredentials = false

	handler := httpserver.MiddlewareSequencer(
		http.DefaultServeMux,
		httpserver.DumpHttp(slog.LevelDebug),
		httpserver.Timer(slog.LevelInfo),
		httpserver.Tracer,
		httpserver.AllowCORS(corsOpts),
		httpserver.PanicCatcher,
	)

	if err := http.ListenAndServe(":8080", handler); err != nil {
		panic(err)
	}
}

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func AllowCORS added in v0.1.0

func AllowCORS(opts *CORSOptions) func(next http.Handler) http.Handler

AllowCORS sets headers for CORS mechanism supports secure.

func DumpHttp

func DumpHttp(level slog.Level) func(http.Handler) http.Handler

DumpHttp dumps the HTTP request and response, and prints out.

func MiddlewareSequencer

func MiddlewareSequencer(baseHandler http.Handler, mws ...func(http.Handler) http.Handler) http.Handler

MiddlewareSequencer chains middleware functions in a chain.

func PanicCatcher

func PanicCatcher(next http.Handler) http.Handler

PanicCatcher handles panics in http.HandlerFunc.

func Timer

func Timer(level slog.Level) func(http.Handler) http.Handler

Timer measures the time taken by http.HandlerFunc.

func Tracer added in v0.2.0

func Tracer(next http.Handler) http.Handler

Tracer adds trace ID to the request context.

Types

type CORSOptions added in v0.1.0

type CORSOptions struct {
	AllowOrigins     []string // List of origins that the server allows.
	AllowMethods     []string // List of methods that the server allows.
	AllowHeaders     []string // List of headers that the server allows.
	MaxAge           int      // Tells the browser how long (in seconds) to cache the response to the preflight request.
	AllowCredentials bool     // Allow browsers to expose the response to the external JavaScript code.
}

CORSOptions represents a functional option for configuring the CORS middleware.

type Controller

type Controller struct {
	Server          *http.Server
	GracefulTimeout time.Duration
	// contains filtered or unexported fields
}

Controller is a wrapper around *http.Server to control the server.

Server — *http.Server, which will be managed.
GracefulTimeout — time that is given to the server to shut down gracefully.

func (*Controller) Restart

func (c *Controller) Restart()

Restart restarts the server if necessary. For changes to the following parameters to take effect:

Addr; TLSConfig; TLSNextProto; ConnState; BaseContext; ConnContext,

a server restart is required. Other parameters can be changed without restarting the server. If the server is not running, the function will be skipped.

func (*Controller) Shutdown

func (c *Controller) Shutdown()

Shutdown gracefully shuts down the server.

func (*Controller) Start

func (c *Controller) Start() (err error)

Start starts the *http.Server. If *tls.Config on the server is non nil, the server listens and serves using tls.

type Formatter

type Formatter interface {
	coder.Coder
	WriteResponse(ctx context.Context, w http.ResponseWriter, statusCode int, v any)
}

func NewFormatter

func NewFormatter(coder coder.Coder) Formatter

NewFormatter returns a new Formatter.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL