Skip to content

Latest commit

 

History

History
62 lines (44 loc) · 2.02 KB

README.md

File metadata and controls

62 lines (44 loc) · 2.02 KB

Calling Card

Why use an international calling card when you now can use "Calling Card."

When traveling abroad I typically purchase a local cell phone. Sadly, these phone plans tend to be somewhat limited and very commonly don't include any data. If I want to communicate with folks back home I'm forced to wait until I'm near my computer and have Internet access. This application allows me to call a local number and have my call forwarded elsewhere.

It is a server, written in Python and Flask, that forwards Twilio voice calls to the number of your choosing. It also allows important numbers to be added to a "Speeddial" for quick calling.

This being said, using a traditional calling card might be slightly cheaper, though not as convenient. As an example, claiming a Twilio number in Mexico costs $3 a month, and each call is about 2.15 cents/minute.

TWILIO PREP

  1. Purchase a Twilio number located in the country where you'll be. This will be the number that you will call and will forward you onwards.
  2. Update this Twilio number's voice request URL to point to wherever callingcard is being hosted. It must point to the connect path. For example, http://callingcard.heroku.com/connect

LOCAL INSTALLATION

  1. Create a Python virtualenv.

  2. Install callingcard and it's dependencies.

    pip install -e .
  3. Run the development server by running the command:

    development

REMOTE INSTALLATION

The WSGI application context can be loaded from callingcard.production. Currently, I've included configuration to run the server on Heroku.

CHANGING CONFIGURATION

Currently, two things are hardcoded in callingcard.defaults, the speeddial numbers and the permitted callers.

You can update this in one of two ways.

  1. Update the defaults file directly
  2. Set the environment variable CALLINGCARD_SETTINGS to be the file path of new configuration that will override the defaults.