Skip to main content

django generic sms through http gateway

Project description

Easily send SMS messages through a web gateway from django.

This code is quite stable, and has been in use for about 2 years, with thousands of messages sent per week, to a variety of gateways, and a number of different countries.

Installation

  • Install the package into your project’s virtual environment:

    pip install django-sms-gateway

  • Add sms to your project’s settings.INSTALLED_APPS.

  • Run ./manage.py migrate or ./manage.py syncdb

Configuration

There are three django models: sms.Message, sms.Gateway, and sms.Reply.

Before you are able to send any messages, you will need to configure at least one gateway. There is some sample data for some gateway providers. You can adapt one of these for your own purposes.

Usage

Create a message, ready to be sent:

msg = Message.objects.create(
  recipient_number="123456789",
  content="Test message",
  sender=user,
  billee=user
)

Note that you must provide at least these fields. recipient_number must include the international prefix (or your gateway must be configured to add it). content should be ASCII, some gateways reject unicode. sender must be an auth.User, but billee may be any object.

This does not send the message:

>>> msg
<Message: [Unsent] Sent to 123456789 by matt at None [1]>

To send it, you need to provide a gateway:

msg.send(gateway)

Status/Reply Callback

If your gateway supports it, you can have it hit your server whenever there are status updates on any message. You can use the included views, in your urlpatterns:

urlpatterns = patterns('',
  (r'^sms/', include('sms.urls')),
)

This would mean that you would need to enter something like:

http://example.com/sms/status_postback/

In your gateway’s settings.

The same applies for replies, if you have a 2-way gateway, but using /sms/reply_postback/ instead.

Reply callback functions

When you send a message, you can store a reply_callback function in the object. This function will be called, with the reply object passed in as the parameter. The reply object has access to it’s original message (as well as it could be matched).

Billing

Since SMSs are generally billable through web gateways, there is the requirement that a billee is provided, and there is a billed flag on each message. This allows you to bill after-the-fact. If you wanted to only allow sending of messages to people with credits remaining, then

Future

Currently, all sending happens in-process. There is a preliminary celery task, but it has not been extensively tested as yet.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-sms-gateway-1.0.0.tar.gz (10.4 kB view details)

Uploaded Source

File details

Details for the file django-sms-gateway-1.0.0.tar.gz.

File metadata

File hashes

Hashes for django-sms-gateway-1.0.0.tar.gz
Algorithm Hash digest
SHA256 7b86d85a6051feba1f0040644316f6e3555b852fa1538275e87ec33aeb50c557
MD5 cb5d63c794d0594b0a5fea0126aafd77
BLAKE2b-256 afbddc0c2839b3f197b7def4583c7a2e4c7a69c9c247ea53993eaa344f6b33ff

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page