Documentation ¶
Overview ¶
Package fcm provides message notification integration for Firebase Cloud Messaging (FCM).
Usage:
package main import ( "context" "log" "github.com/nikoksr/notify" "github.com/nikoksr/notify/service/fcm" ) func main() { fcmSvc, err := fcm.New("server_api_key") if err != nil { log.Fatalf("fcm.New() failed: %s", err.Error()) } fcmSvc.AddReceivers("deviceToken1") notifier := notify.New() notifier.UseServices(fcmSvc) // Use context.Background() if you want to send a simple notification message. ctx := context.Background() // Optionally, you can include additional data in the message payload by adding the corresponding value to the // context. ctxWithData := context.WithValue(ctx, fcm.DataKey, map[string]interface{}{ "some-key": "some-value", "other-key": "other-value", }) // Optionally, you can specify a total of retry attempts per each message by adding the corresponding value to // the context. ctxWithDataAndRetries := context.WithValue(ctxWithData, fcm.RetriesKey, 3) err = notifier.Send(ctxWithDataAndRetries, "subject", "message") if err != nil { log.Fatalf("notifier.Send() failed: %s", err.Error()) } log.Println("notification sent") }
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Option ¶ added in v1.0.0
Option is a function that configures a Service.
func WithCredentialsFile ¶ added in v1.0.0
WithCredentialsFile returns an Option to configure the FCM client with a credentials file.
func WithHTTPClient ¶ added in v1.0.0
WithHTTPClient returns an Option to configure the FCM client with a custom HTTP client.
func WithProjectID ¶ added in v1.0.0
WithProjectID returns an Option to configure the FCM client with a project ID.
type Service ¶
type Service struct {
// contains filtered or unexported fields
}
Service encapsulates the FCM client along with internal state for storing device tokens.
func (*Service) AddReceivers ¶
AddReceivers takes FCM device tokens and appends them to the internal device tokens slice.
Click to show internal directories.
Click to hide internal directories.