The Voxbone VoxSMS module enables you to send/receive SMS and delivery reports from Voxbone numbers.
npm install voxbone-voxsms
npm install
- In routes/sms.js add the dependency to your application
var Voxbone = require('voxbone-voxsms');
- routes/sms.js, add your credentials
var api_login = 'login';
var api_password = 'password';
- Create a new Voxbone object
var voxbone = new Voxbone({
apiLogin: api_login,
apiPassword: api_password
});
/routes/sms.js is where your application resides, you can send/receive an SMS and delivery reports with it. /node_modules/voxbone-voxsms is the voxbone voxsms module
- Add your parameters to send a message
var from = "+3228080438"; //a Voxbone number enabled for VoxSMS (format: +3200000)
var to = "3222222222"; //the destination number (format: 3200000)
var msg = "your message";
var dr = "all"; //Delivery reports - Accepted values: success, failure, all, none
- Generate a fragmentation reference for your sms
This will be used in case your message is too long.
var fragref = voxbone.createFragRef();
- Send SMS with the parameters configured in step 1
voxbone.sendSMS(to, from, msg, fragref, dr);
````
4. Launch the application with:
````
npm start
````
When the application starts (within the terminal), it will send an sms with the configurations you gave it and listen for incoming messages and delivery reports (until you shutdown the application).
### Receive Messages and Delivery Reports
In order to be able to receive incoming messages and delivery reports while testing you will have to use a tunnelling service.
An exmaple is [ngrok](https://ngrok.com/). Once you've got your ngrok public URL set up, add it to your configured callback URL in the portal.
This library uses the command ./ngrok http 8080
## Docs
Available functions:
````
// Sends an SMS with the parameters configured
voxbone.sendSMS(to, from, msg, fragref, dr);
//Generates a random fragmentation reference used for long messages
voxbone.createFragRef();
//Generates a transaction ID to be sent back with your 200OK response when receiving a message.
voxbone.createTransId();
//Sends a delivery report to Voxbone when your application receives a message
voxbone.sendDeliveryReport();