Skip to content

Latest commit

 

History

History
111 lines (72 loc) · 3.25 KB

README.md

File metadata and controls

111 lines (72 loc) · 3.25 KB

gonotify

A web service that lets you send yourself WhatsApp messages serving as notifications

Demo: https://gonotify.xyz

The basic idea is to provide the user with a service that he/she can use to send himself WhatsApp messages programmatically without much hassle. With GoNotify you can create groups of various numbers and send messages to the group with just a simple API call. I have explained the idea in detail in a dev.to post.

Installation

Pre-built binaries

Pre-built binaries are available on the Release page.

Build from source

  • You would need go to build the binary.
  • The WebUI is built using ReactJS, and we use yarn as package manager. So you would need node and yarn too.
  • Run make build in project root. This will build a binary at build/gonotify.
  • Run make build-cli to build the gncli command line client.

Configuration

  • gonotify requires a configuration file to start. You can use the -c flag to pass a path for the config file.
  • By default gonotify uses config/config.yml.
  • A sample config file is provided in config/config.example.yml. Edit the file according to your needs.

Features

  • Add and verify your Phone numbers once.
  • Create multiple groups with your phone numbers.
  • Send notification to all numbers in a group.
  • Use the API to do all of this programmatically.

Usage

Concepts

  • Number: You can add multiple Phone numbers to your account. You need to verify each phone number once.
  • Group: A group is a collection of phone numbers. The notifications are always targeted towards a Group.

CLI usage

The gncli is still work-in-progress. You can login and send messages as of now.

Login

$ gncli login --number +911234123456 --password pass1234
Logged in successfully

Send Message

To the default group

$ gncli send Hola people!
Message sent successfully

Or you can choose a specific group

$ gncli send -g work Hola people!
Message sent successfully

Example API usage

The examples use HTTPie as client.

GoNotify server issues JWT token on successfull authentication. Authorization header is used to supply the token to the backend. The Authorization header's value must be in the form of Bearer <jwt token>.

Login

$ http :8080/api/v1/login phone="9912312345" password="password"

Response:

{
  "message": "login successful",
  "token": "eyJhbGciOiJIUjhggdgnR5cCI6IkpXVCJ9.eyJleHjkgJFgfhvj3ODcsImlkIjoyfQ.TsxdOsxf0cOt5cNNSgOx5CH4oxxtGogPKcA0XPPyhnTaKhc4xpmcsJV_GY56bkghfhgdh0jO1TtSolOw8GT3TGtQyA"
}

Send a message

$ http :8080/api/v1/send authorization:"Bearer eyJhbGciOiJIUjhggdgnR5cCI6IkpXVCJ9.eyJleHjkgJFgfhvj3OgggttmlkIjoyfQ.TsxdOsxf0cOt5cNNSgOx5CH4oxxtGogPKcA0XPPyhnTaKhc4xpmcsJV_GY56bkghfhgdh0jO1TtSolOw8GT3TjghyyA" body="test message" group="default"

Response:

{
  "message": "Message sent successfully"
}

Roadmap

  • A full-featured CLI to easiliy access the API. (In Progress)
  • Expand to services other than WhatsApp (SMS, Telegram, Slack, Email etc.).

Contributing

Any kind of contributions are welcome!