GatewayAPI Provider for smsframework.
Install from pypi:
$ pip install smsframework_gatewayapi
To receive SMS messages, you need to ensure that Flask microframework is also installed, as well as the JWT library:
$ pip install smsframework_gatewayapi[receiver]
from smsframework import Gateway
from smsframework_gatewayapi import GatewayAPIProvider
gateway = Gateway()
gateway.add_provider('gapi', GatewayAPIProvider,
key='AAABBBBCCCCDDDD', secret='XAD*HHH(aaaaa'
)
Source: /smsframework_gatewayapi/provider.py
key
: API keysecret
: API secretjwt_secret
: Secret token for the JWT header (only for REST webhook that receives messages)
from smsframework import Gateway, OutgoingMessage
# Send a regular message
gateway.send(OutgoingMessage('+19991112233', 'Test'))
# Send a premium message
gateway.send(OutgoingMessage('+19991112233', 'Test').options(escalate=True))
validity_period
: Message expiration time in minutessenderId
: Alpha-numeric SenderIdescalate
: Premium message
See https://gatewayapi.com/docs/rest.html#post--rest-mtsms
Source: /smsframework_gatewayapi/receiver.py
GatewayApi uses a single webhook URL to receive both messages and status reports.
Webhook URL: <provider-name>/callback
In order to configure it, go to the API/Webhooks section in the
control panel, and add a new "REST" webhook.
The URL will be something like this: http://.../<prefix>/<provider-name>/callback
In the Authentication section, you can specify a JWT secret token. Pass it to the GatewayAPIProvider
in order to have secure message reception.