1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
package shoutrrr
import (
"fmt"
"github.com/nicholas-fedor/shoutrrr/internal/meta"
"github.com/nicholas-fedor/shoutrrr/pkg/router"
"github.com/nicholas-fedor/shoutrrr/pkg/types"
)
// defaultRouter manages the creation and routing of notification services.
var defaultRouter = router.ServiceRouter{}
// SetLogger configures the logger for all services in the default router.
func SetLogger(logger types.StdLogger) {
defaultRouter.SetLogger(logger)
}
// Send delivers a notification message using the specified URL.
func Send(rawURL string, message string) error {
service, err := defaultRouter.Locate(rawURL)
if err != nil {
return fmt.Errorf("locating service for URL %q: %w", rawURL, err)
}
if err := service.Send(message, &types.Params{}); err != nil {
return fmt.Errorf("sending message via service at %q: %w", rawURL, err)
}
return nil
}
// CreateSender constructs a new service router for the given URLs without a logger.
func CreateSender(rawURLs ...string) (*router.ServiceRouter, error) {
sr, err := router.New(nil, rawURLs...)
if err != nil {
return nil, fmt.Errorf("creating sender for URLs %v: %w", rawURLs, err)
}
return sr, nil
}
// NewSender constructs a new service router with a logger for the given URLs.
func NewSender(logger types.StdLogger, serviceURLs ...string) (*router.ServiceRouter, error) {
sr, err := router.New(logger, serviceURLs...)
if err != nil {
return nil, fmt.Errorf("creating sender with logger for URLs %v: %w", serviceURLs, err)
}
return sr, nil
}
// Version returns the current Shoutrrr version.
func Version() string {
return meta.Version
}
|