This library is all set to go with version 1 of the Elvanto API. This library works for both Python 2.7, and Python 3.4
The Elvanto API supports authentication using either OAuth 2 or an API key.
- Quick summary This is an API wrapper to use in conjunction with an Elvanto account. This wrapper can be used by developers to develop programs for their own churches, or to design integrations to share to other churches using OAuth authentication.
- Version 1.3.3.2
PIP is the preferred installation method.
python get-pip.py
pip install ElvantoAPI
- Download
- Navigate to folder you downloaded the source
python setup.py install
First get your API key from Settings > Account Settings, then in the program:
import ElvantoAPI
connection = ElvantoAPI.Connection(APIKey=string)
First direct users to the required URL.
Use the _AuthorizeURL
function to do this. The arguement WebOrNon
is used to describe if you are developing a
WebApp or a Non Web App (Ie, a program not in a browser) - For the most part OAuth would be used for Webapps
import ElvantoAPI
URL = ElvantoAPI._AuthorizeURL(client_id, redirect_uri, scope, WebOrNon)
After the user has logged in, they will be sent back to the specified redirect_uri, with a code, and any state you specify. For example:
http://mywebapp.com/login/?code=string
The next step is to take this code, and get your access tokens. The code here is the code in the above URL.
tokens = ElvantoAPI._GetTokens(client_id, client_secret, code, redirect_uri)
This will return a dict object of the form:
{
"access_token": "e1e8422f68d8cf3c44b6e3d4beb065722abf",
"expires_in": 1209600,
"refresh_token": "6d59273f6fb7671bf1bb79ac81c63c12bc73633421"
}
You can now create the connection object. The wrapper will be able to refresh the tokens used when needed.
connection = ElvantoAPI.Connection(AccessToken=string, RefreshToken=string)
After the user has logged in, they will be sent back to the specified redirect_uri, with a code. Unlike the WebApp method this code will be behind a hash.
http://mynonwebapp.com/login/#code=string&expiresin=int
Have the users copy this code into your app. This code will expire in the value provided by the integer, in seconds.
You can now create the connection object. You can't have it automatically refresh the tokens though.
connection = ElvantoAPI.Connection(AccessToken=string)
To perform a call, simply use the end point and any arguments required.
connection._Post("people/getAll")
connection._Post("people/create", firstname = "John", lastname = "Smith")
All calls return a dict object, to indicate if it was successful or not.
If an argument is to be a JSON object, enter it as a Dict type object. Arrays can be entered simply as a list.
For example.
search=connection._Post("people/search",search={"firstname":"John", "volunteer":"Yes"}, fields=["birthday","school_grade"])
An example response is as follows:
{
"status": "ok",
"generated_in": "0.035",
"people": {
"on_this_page": 2,
"per_page": 1000,
"total": 2,
"page": 1,
"person": [
{
"username": "john.feeney",
"preferred_name": "",
"timezone": "",
"id": "7a411238-6fbc-11e0-bda8-de12be825216",
"archived": 0,
"family_id": "",
"family_relationship": "Other",
"last_login": "",
"email": "fee-ney-john@syllables.com",
"status": "Active",
"picture": "https://d5w68ic4qi8w5.cloudfront.net/assets/logo.png",
"school_grade": "",
"firstname": "John",
"lastname": "Feeney",
"phone": "",
"birthday": "1984-08-23",
"date_added": "2011-04-26 04:20:08",
"volunteer": 1,
"date_modified": "2015-02-26 05:07:06",
"admin": 0,
"country": "",
"mobile": "0456833923",
"contact": 0,
"category_id": "c37482a8-eb06-11e0-9229-ea942707ad51",
"deceased": 0
},
{
"username": "john.hua",
"preferred_name": "",
"timezone": "",
"id": "7bcc31fa-6fbc-11e0-bda8-de12be825216",
"archived": 0,
"family_id": "",
"family_relationship": "Other",
"last_login": "",
"email": "johnhua@example.com",
"status": "Active",
"picture": "https://d5w68ic4qi8w5.cloudfront.net/assets/logo.png",
"school_grade": "12",
"firstname": "John",
"lastname": "Hua",
"phone": "",
"birthday": "1998-11-23",
"date_added": "2011-04-26 04:20:08",
"volunteer": 1,
"date_modified": "2015-02-26 05:07:06",
"admin": 0,
"country": "",
"mobile": "0451783968",
"contact": 0,
"category_id": "c37482a8-eb06-11e0-9229-ea942707ad51",
"deceased": 0
}
]
}
}
Documentation can be found on the Elvanto API website.
Follow our Twitter to keep up-to-date with changes in the API.
For bugs with the API Python Wrapper please use the Issue Tracker.
For suggestions on the API itself, please post in the forum or contact us via our website.