msgr

package module
v0.0.4 Latest Latest
Warning

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

Go to latest
Published: Dec 23, 2024 License: MIT Imports: 13 Imported by: 0

README

Fyro Messenger

Configuration

type ClientOpts struct {
	// Path to email layout, locales, and templates
	TemplatesRoot string
	DefaultFrom   string
	MailProvider  provider.MailProvider
	SMSProvider   provider.SMSProvider
	DefaultLocale string
	// Dynamic data to be used in the layout
	LayoutData MessageData
}

Create a client instance using:

msgr.NewClient(ClientOpts{})

Messages

Each message has its own templates and locales.

type AddMessageOpts struct {
	Name            string           // Must be unique
	MailChannelOpts *MailChannelOpts // Email channel options
}

Register messages using:

mailer.AddMessage(AddMessageOpts{})

Templates

File structure should be as follows:

templates
  layout_mail.html.tmpl // Root layout
	layout_sms.html.tmpl // Root layout
  locale.en.yml
  locale.zh-cn.yml
  [entryName]/
    index_mail.html.tmpl
		index_mail.text.tmpl
		index_sms.text.tmpl
    locale.en.yml
    locale.zh-cn.yml

Locale files should be named locale.[lang].yml

Subject

Message locale files must include a mandatory subject message entry, this is templated using data passed in.

# YAML
subject: Hello {{ .Name }}

Sending

type SendOpts struct {
	MessageName string
	MailTo      string // If MailTo is defined, it will send email
	SMSTo       string // If SMSTo is defined, it will send SMS
	Data        MessageData
	Locale      string
}

Example

Check example/preview.go for a working example

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrInvalidMessage = errors.New("invalid message")
	ErrNoProviders    = errors.New("no providers found")
	ErrInvalidFormat  = errors.New(`invalid format, needs to be "html" or "text"`)
)

Functions

func RenderHTML

func RenderHTML(opts RenderOpts) (string, error)

func RenderText

func RenderText(opts RenderOpts) (string, error)

Types

type AddMessageOpts

type AddMessageOpts struct {
	Name            string          // Must be unique
	MailChannelOpts MailChannelOpts // Email channel options
}

type Channel

type Channel int
const (
	MailChannel Channel = iota
	SMSChannel
)

func (Channel) String

func (c Channel) String() string

type ClientOpts

type ClientOpts struct {
	// Path to email layout, locales, and templates
	TemplatesRoot string
	// Set the mail provider and default opts
	MailProvider  provider.MailProvider
	MailOpts      *MailChannelOpts
	SMSProvider   provider.SMSProvider
	DefaultLocale string
	// Dynamic data to be used in the layout
	LayoutData MessageData
}

type ComposeOpts

type ComposeOpts struct {
	Message Message
	Channel Channel
	Format  RenderFormat
	Locale  string
	Data    MessageData
}

type MailChannelOpts

type MailChannelOpts struct {
	From    string
	ReplyTo string
}

type Message

type Message struct {
	// contains filtered or unexported fields
}

func NewMessage

func NewMessage(opts NewMessageOpts) (*Message, error)

func (*Message) Localizer

func (msg *Message) Localizer(locale string) *i18n.Localizer

func (*Message) MailSubject

func (msg *Message) MailSubject(
	locale string, data MessageData,
) (string, error)

func (*Message) TemplateFiles

func (msg *Message) TemplateFiles(channel Channel, format RenderFormat) []string

type MessageData

type MessageData map[string]any

type Messenger

type Messenger struct {
	// contains filtered or unexported fields
}

func NewClient

func NewClient(opts ClientOpts) (*Messenger, error)

func (*Messenger) AddMessage

func (msgr *Messenger) AddMessage(opts AddMessageOpts) error

func (*Messenger) Compose

func (msgr *Messenger) Compose(opts ComposeOpts) (string, error)

func (*Messenger) LayoutFile

func (msgr *Messenger) LayoutFile(channel Channel, format RenderFormat) string

func (*Messenger) Preview

func (msgr *Messenger) Preview(opts PreviewOpts) error

func (*Messenger) Send

func (msgr *Messenger) Send(opts SendOpts) error

type NewMessageOpts

type NewMessageOpts struct {
	// contains filtered or unexported fields
}

type PreviewOpts

type PreviewOpts struct {
	MessageName string
	Data        MessageData
	Locale      string
}

type RenderFormat

type RenderFormat string
var (
	RenderKindText RenderFormat = "text"
	RenderKindHTML RenderFormat = "html"
)

type RenderOpts

type RenderOpts struct {
	Templates     []string
	Data          MessageData
	Locale        string
	LayoutBundle  *i18n.Bundle
	MessageBundle *i18n.Bundle
}

type SendOpts

type SendOpts struct {
	MessageName string
	MailTo      string // If MailTo is defined, it will send email
	SMSTo       string // If SMSTo is defined, it will send SMS
	Data        MessageData
	Locale      string
}

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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