http

package
v0.0.0-...-db4472a Latest Latest
Warning

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

Go to latest
Published: Apr 17, 2024 License: MIT Imports: 9 Imported by: 0

README

Generic HTTP service

go.dev reference

Prerequisites

Technically, you don't need any prerequisites to use this service. However, you will need an HTTP endpoint to send requests to.

See our Notify Test Server for a simple HTTP server that can be used for testing.

Usage

package main

import (
	"context"
	"log"
	stdhttp "net/http"

	"github.com/nikoksr/notify"
	"github.com/nikoksr/notify/service/http"
)

func main() {
	// Create http service
	httpService := http.New()

	//
	// In the following example, we will send two requests to the same HTTP endpoint. This is meant to be used with
	// Notify's test http server: https://github.com/nikoksr/notify-http-test. It supports multiple content-types on the
	// same endpoint, to simplify testing. All you have to do is run `go run main.go` in the test server's directory and
	// this example will work.
	// So the following example should send two requests to the same endpoint, one with content-type application/json and
	// one with content-type text/plain. The requests should be logged differently by the test server since we provide
	// a custom payload builder func for the second webhook.

	// Add a default webhook; this uses application/json as content type and POST as request method.
	httpService.AddReceiversURLs("http://localhost:8080")

	// Add a custom webhook; the build payload function is used to build the payload that will be sent to the receiver
	// from the given subject and message.
	httpService.AddReceivers(&http.Webhook{
		URL:         "http://localhost:8080",
		Header:      stdhttp.Header{},
		ContentType: "text/plain",
		Method:      stdhttp.MethodPost,
		BuildPayload: func(subject, message string) (payload any) {
			return "[text/plain]: " + subject + " - " + message
		},
	})

	//
	// NOTE: In case of an unsupported content type, we could provide a custom marshaller here.
	// See http.Service.Serializer and http.defaultMarshaller.Marshal for details.
	//

	// Add pre-send hook to log the request before it is sent.
	httpService.PreSend(func(ctx context.Context, req *stdhttp.Request) error {
		log.Printf("Sending request to %s", req.URL)
		return nil
	})

	// Add post-send hook to log the response after it is received.
	httpService.PostSend(func(ctx context.Context, req *stdhttp.Request, resp *stdhttp.Response) error {
		log.Printf("Received response from %s", resp.Request.URL)
		return nil
	})

	// Create the notifier and use the HTTP service
	n := notify.NewWithServices(httpService)

	// Send a test message.
	if err := n.Send(context.Background(), "Testing new features", "Notify's HTTP service is here."); err != nil {
		log.Fatal(err)
	}
}

Documentation

Overview

Package http provides an HTTP service. It is used to send notifications to HTTP endpoints. The service is configured with a list of webhooks. Each webhook contains the URL of the endpoint, the HTTP method to use, the content type of the HTTP request and a function that builds the payload of the request.

The service also allows to register pre and post send hooks. These hooks are called before and after the request is sent to the receiver. The pre send hook can be used to modify the request before it is sent. The post send hook can be used to modify the response after it is received. The hooks are called in the order they are registered.

Usage:

    package main

    import (
	    "context"
	    "log"
	    stdhttp "net/http"

	    "github.com/nikoksr/notify"
	    "github.com/nikoksr/notify/service/http"
    )

    func main() {
		// Create http service
		httpService := http.New()

		//
		// In the following example, we will send two requests to the same HTTP endpoint. This is meant to be used with
		// Notify's test http server: https://github.com/nikoksr/notify-http-test. It supports multiple content-types on the
		// same endpoint, to simplify testing. All you have to do is run `go run main.go` in the test server's directory and
		// this example will work.
		// So the following example should send two requests to the same endpoint, one with content-type application/json and
		// one with content-type text/plain. The requests should be logged differently by the test server since we provide
		// a custom payload builder func for the second webhook.

		// Add a default webhook; this uses application/json as content type and POST as request method.
		httpService.AddReceiversURLs("http://localhost:8080")

		// Add a custom webhook; the build payload function is used to build the payload that will be sent to the receiver
		// from the given subject and message.
		httpService.AddReceivers(&http.Webhook{
			URL:         "http://localhost:8080",
			Header:      stdhttp.Header{},
			ContentType: "text/plain",
			Method:      stdhttp.MethodPost,
			BuildPayload: func(subject, message string) (payload any) {
				return "[text/plain]: " + subject + " - " + message
			},
		})

		//
		// NOTE: In case of an unsupported content type, we could provide a custom marshaller here.
		// See http.Service.Serializer and http.defaultMarshaller.Marshal for details.
		//

		// Add pre-send hook to log the request before it is sent.
		httpService.PreSend(func(ctx context.Context, req *stdhttp.Request) error {
			log.Printf("Sending request to %s", req.URL)
			return nil
		})

		// Add post-send hook to log the response after it is received.
		httpService.PostSend(func(ctx context.Context, req *stdhttp.Request, resp *stdhttp.Response) error {
			log.Printf("Received response from %s", resp.Request.URL)
			return nil
		})

		// Create the notifier and use the HTTP service
		n := notify.NewWithServices(httpService)

		// Send a test message.
		if err := n.Send(context.Background(), "Testing new features", "Notify's HTTP service is here."); err != nil {
			log.Fatal(err)
		}
	}

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type BuildPayloadFn

type BuildPayloadFn func(subject, message string) (payload any)

BuildPayloadFn defines a function signature for a function that builds a payload.

type PostSendHookFn

type PostSendHookFn func(req *http.Request, resp *http.Response) error

PostSendHookFn defines a function signature for a post-send hook.

type PreSendHookFn

type PreSendHookFn func(req *http.Request) error

PreSendHookFn defines a function signature for a pre-send hook.

type Serializer

type Serializer interface {
	Marshal(contentType string, payload any) (payloadRaw []byte, err error)
}

Serializer is used to serialize the payload to a byte slice.

type Service

type Service struct {
	Serializer Serializer
	// contains filtered or unexported fields
}

Service is the main struct of this package. It contains all the information needed to send notifications to a list of receivers. The receivers are represented by Webhooks and are expected to be valid HTTP endpoints. The Service also allows

func New

func New() *Service

New returns a new instance of a Service notification service. Parameter 'tag' is used as a log prefix and may be left empty, it has a fallback value.

func (*Service) AddReceivers

func (s *Service) AddReceivers(webhooks ...*Webhook)

AddReceivers accepts a list of Webhooks and adds them as receivers. The Webhooks are expected to be valid HTTP endpoints.

func (*Service) AddReceiversURLs

func (s *Service) AddReceiversURLs(urls ...string)

AddReceiversURLs accepts a list of URLs and adds them as receivers. Internally it converts the URLs to Webhooks by using the default content-type ("application/json") and request method ("POST").

func (*Service) PostSend

func (s *Service) PostSend(hook PostSendHookFn)

PostSend adds a post-send hook to the service. The hook will be executed after sending a request to a receiver.

func (*Service) PreSend

func (s *Service) PreSend(hook PreSendHookFn)

PreSend adds a pre-send hook to the service. The hook will be executed before sending a request to a receiver.

func (*Service) Send

func (s *Service) Send(ctx context.Context, subject, message string) error

Send takes a message and sends it to all webhooks.

func (*Service) WithClient

func (s *Service) WithClient(client *http.Client)

WithClient sets the http client to be used for sending requests. Calling this method is optional, the default client will be used if this method is not called.

type Webhook

type Webhook struct {
	ContentType  string
	Header       http.Header
	Method       string
	URL          string
	BuildPayload BuildPayloadFn
}

Webhook represents a single webhook receiver. It contains all the information needed to send a valid request to the receiver. The BuildPayload function is used to build the payload that will be sent to the receiver from the given subject and message.

func (*Webhook) String

func (w *Webhook) String() string

String returns a string representation of the webhook. It implements the fmt.Stringer interface.

Jump to

Keyboard shortcuts

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