Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/piusalfred/whatsapp
golang wrapper for whatsapp cloud api
https://github.com/piusalfred/whatsapp
bot whatsapp whatsapp-api whatsapp-api-go whatsapp-bot whatsapp-clo whatsapp-cloud-api-client
Last synced: 3 months ago
JSON representation
golang wrapper for whatsapp cloud api
- Host: GitHub
- URL: https://github.com/piusalfred/whatsapp
- Owner: piusalfred
- License: mit
- Created: 2023-01-28T03:17:03.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-09-29T12:22:20.000Z (3 months ago)
- Last Synced: 2024-10-01T00:24:45.867Z (3 months ago)
- Topics: bot, whatsapp, whatsapp-api, whatsapp-api-go, whatsapp-bot, whatsapp-clo, whatsapp-cloud-api-client
- Language: Go
- Homepage:
- Size: 16.8 MB
- Stars: 33
- Watchers: 3
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
[![GoDoc](https://godoc.org/github.com/piusalfred/whatsapp?status.svg)](https://godoc.org/github.com/piusalfred/whatsapp)
[![Go Report Card](https://goreportcard.com/badge/github.com/piusalfred/whatsapp)](https://goreportcard.com/report/github.com/piusalfred/whatsapp)
![Status](https://img.shields.io/badge/status-alpha-red)A highly configurable golang client for [Whatsapp Cloud API](https://www.postman.com/meta/whatsapp-business-platform/collection/wlk6lh4/whatsapp-cloud-api)
> [!WARNING]
> The library is usable but not pretty stable yet. There maybe some breaking changes.## Supported API
- [Message](./message)
- [Text](./message)
- [Media](./message)
- [Templates](./message)
- [Interactive Messages](./message)
- [Replies and Reactions](./message)
- [QR Code Management](./qrcode)
- [Phone Number Management](./phonenumber)
- [Get Phone Number Information](./phonenumber)
- [Update Phone Number](./phonenumber)
- [Media Management](./media)
- [Webhooks](./webhooks)
- [Message Webhooks](./webhooks/message)
- [Business Management Webhooks](./webhooks/business)
- [Flow Management Webhooks](./webhooks/flow)## setup
- Go to [apps](https://developers.facebook.com/apps) you have registered click on the one you want to develop API for and go to `API setup` if not create one.
- Get these details `access token`,`phone number id`,`business account id` and make sure you have authorized one or more whatsapp phone numbers to receive these messages
- While on the root directory of the project run `task build-examples` to build all the examples that will be in [examples/bin](./examples/bin) directory
- Then run `cp examples/api.env examples/bin/api.env`
- And populate the values you have got to this `api.env` file, The given values here are not valid
```dotenv
WHATSAPP_CLOUD_API_BASE_URL=https://graph.facebook.com
WHATSAPP_CLOUD_API_API_VERSION=v20.0
WHATSAPP_CLOUD_API_ACCESS_TOKEN=EAALLrT0ok6UBJZB0ZB3gvzk9hJaEjGM8ISZAxPR5e3ZAFn4RmBIThoeK0XOdbKv8y2zB3YQ7uaijShZBjVIcZD
WHATSAPP_CLOUD_API_PHONE_NUMBER_ID=111112271552333
WHATSAPP_CLOUD_API_BUSINESS_ACCOUNT_ID=222222508300000
WHATSAPP_CLOUD_API_TEST_RECIPIENT=+XXXX7374665453
```
- now you can navigate to the [examples/bin](./examples/bin) directory and run the examples. But before that make sure you have sent the hello world
template message to the recipient and **replied** and this should be within *24 hrs window*> [!NOTE]
> You will find `BaseClient` and `Client`.
> `Client` provides a stateful approach, reusing the same configuration across multiple requests until manually refreshed, making it ideal for long-running services where consistency and thread safety are required.
> `BaseClient` is stateless, reloading the configuration on each request, making it more flexible for dynamic environments like multi-tenancy, where different configurations may be needed for each request.### usage
Install the library by running```bash
go get github.com/piusalfred/whatsapp
``````go
package mainimport (
"context"
"fmt"
whttp "github.com/piusalfred/whatsapp/pkg/http"
"log"
"net/http""github.com/piusalfred/whatsapp/config"
"github.com/piusalfred/whatsapp/message"
)func main() {
// Create the HTTP client
httpClient := &http.Client{}// Define a configuration reader function
configReader := config.ReaderFunc(func(ctx context.Context) (*config.Config, error) {
return &config.Config{
BaseURL: "https://your-whatsapp-api-url", // Replace with your API URL
AccessToken: "your-access-token", // Replace with your access token
APIVersion: "v14.0", // WhatsApp API version
BusinessAccountID: "your-business-account-id", // Replace with your business account ID
}, nil
})clientOptions := []whttp.CoreClientOption[message.Message]{
whttp.WithCoreClientHTTPClient[message.Message](httpClient),
whttp.WithCoreClientRequestInterceptor[message.Message](
func(ctx context.Context, req *http.Request) error {
fmt.Println("Request Intercepted")
return nil
},
),
whttp.WithCoreClientResponseInterceptor[message.Message](
func(ctx context.Context, resp *http.Response) error {
fmt.Println("Response Intercepted")
return nil
},
),
}coreClient := whttp.NewSender[message.Message](clientOptions...)
client, err := message.NewBaseClient(coreClient, configReader)
if err != nil {
log.Fatalf("failed to create client: %v", err)
}// Define the recipient's WhatsApp phone number (including country code)
recipient := "1234567890"// Create a new text message request
textMessage := message.NewRequest(recipient, &message.Text{
Body: "Hello, this is a test message!",
}, "")// Send the text message
ctx := context.Background()
response, err := client.SendText(ctx, textMessage)
if err != nil {
log.Fatalf("failed to send message: %v", err)
}// Print the response from the API
fmt.Printf("Message sent successfully! Response: %+v\n", response)
}
```### webhooks
```go
package main
import (
"context"
"fmt"
"net/http""github.com/piusalfred/whatsapp/webhooks/flow"
"github.com/piusalfred/whatsapp/webhooks"
"github.com/piusalfred/whatsapp/webhooks/business"
"github.com/piusalfred/whatsapp/webhooks/message"
)func HandleBusinessNotification(ctx context.Context, notification *business.Notification) *webhooks.Response {
fmt.Printf("Business notification received: %+v\n", notification)
return &webhooks.Response{StatusCode: http.StatusOK}
}func HandleMessageNotification(ctx context.Context, notification *message.Notification) *webhooks.Response {
fmt.Printf("Message notification received: %+v\n", notification)
return &webhooks.Response{StatusCode: http.StatusOK}
}func HandleFlowNotification(ctx context.Context, notification *flow.Notification) *webhooks.Response {
fmt.Printf("Message notification received: %+v\n", notification)
return &webhooks.Response{StatusCode: http.StatusOK}
}func main() {
messageWebhooksHandler := webhooks.OnEventNotification(
message.NotificationHandlerFunc(
HandleMessageNotification,
),
)businessWebhooksHandler := webhooks.OnEventNotification(
business.NotificationHandlerFunc(
HandleBusinessNotification,
),
)flowEventsHandler := webhooks.OnEventNotification(
flow.NotificationHandlerFunc(HandleFlowNotification),
)messageVerifyToken := webhooks.VerifyTokenReader(func(ctx context.Context) (string, error) {
return "message-subscription-token", nil
})businessVerifyToken := webhooks.VerifyTokenReader(func(ctx context.Context) (string, error) {
return "business-subscription-token", nil
})validatorWrapper := func(next http.HandlerFunc) http.HandlerFunc {
fn := http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) {
if err := webhooks.ValidateRequestPayloadSignature(request, "validate-secret"); err != nil {
http.Error(writer, err.Error(), http.StatusInternalServerError)return
}
next(writer, request)
})return fn
}businessVerifyHandler1 := http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) {
webhooks.SubscriptionVerificationHandlerFunc("business-subscription-token")(writer, request)
})http.HandleFunc("POST /webhooks/messages", validatorWrapper(messageWebhooksHandler))
http.HandleFunc("POST /webhooks/business", validatorWrapper(businessWebhooksHandler))
http.HandleFunc("POST /webhooks/flows", flowEventsHandler)
http.HandleFunc("POST /webhooks/messages/verify", messageVerifyToken.VerifySubscription)
http.HandleFunc("POST /webhooks/business/verify", businessVerifyToken.VerifySubscription)
http.HandleFunc("POST /webhooks/business/verify/2", businessVerifyHandler1)
http.ListenAndServe(":8080", nil)
}
```See more in [examples](./examples/)
## Testing
There is provision of [**mocks**](./mocks) that may come handy in testing.## Links
- [Get Started Guide](https://developers.facebook.com/docs/whatsapp/cloud-api/get-started)
- [Postman Collection](https://www.postman.com/meta/whatsapp-business-platform/collection/wlk6lh4/whatsapp-cloud-api)
- [Webhooks Get Started](https://developers.facebook.com/docs/graph-api/webhooks/getting-started)
- [Messages Documentation](https://developers.facebook.com/docs/whatsapp/cloud-api/guides/send-messages)
- [Phone Numbers Documentation](https://developers.facebook.com/docs/whatsapp/cloud-api/phone-numbers)
- [Whatsapp Flows](https://developers.facebook.com/docs/whatsapp/flows/)
- [Whatsapp Flows Guide](https://developers.facebook.com/docs/whatsapp/flows/guides)
- [Flows Reference](https://developers.facebook.com/docs/whatsapp/flows/reference/)
- [QR Codes Documentation](https://developers.facebook.com/docs/whatsapp/business-management-api/qr-codes/)
- [Flows Best Practices](https://developers.facebook.com/docs/whatsapp/flows/guides/bestpractices)
- [FlowJSON](https://developers.facebook.com/docs/whatsapp/flows/reference/flowjson)
- [Error Codes](https://developers.facebook.com/docs/whatsapp/cloud-api/support/error-codes/)
- [Application Dashboard](https://developers.facebook.com/apps/)
- [Webhooks for Whatsapp Business Account](https://developers.facebook.com/docs/graph-api/webhooks/getting-started/webhooks-for-whatsapp)
- [Webhooks Notification Payload Reference](https://developers.facebook.com/docs/whatsapp/cloud-api/webhooks/components)
- [System Users (Important in Tokens Management)](https://developers.facebook.com/docs/marketing-api/system-users/overview)
- [Install Apps, Generate, Refresh, and Revoke Tokens](https://developers.facebook.com/docs/marketing-api/system-users/install-apps-and-generate-tokens/#revoke-token)
- [Create, Retrieve and Update a System User](https://developers.facebook.com/docs/marketing-api/system-users/create-retrieve-update)
- [Access Token Debugger](https://developers.facebook.com/tools/accesstoken/)