An easy implementation of TOTP to be used in the AWS Lambda and DynamoDB.
It is built with Chalice and PyOTP.
1 - Set up your AWS Credentials
2 - Create a table in DynamoDB
3 - Configure the TABLE_NAME constant in the chalicelib/config.py file with the name of your table.
4 - Create a new virtualenv with Python 3.
5 - Inside of the virtualenv, install the requirements with pip install -r requirements.txt
6 - Execute the command chalice deploy
7 - Save the link returned by the chalice. It's the link to your application
To register a new user send a POST request to the root path of your application with the value user containing some kind of identification of your user, like an e-mail or user_id. The application will return a JSON in the following format:
{
"user_id": "marcelotheodoro@outlook.com",
"qr_code": "",
"qr_code_url": ""
}- user_id: The user id you have registred your user
- qr_code: The code used to create the QRcode image
- qr_code_url: The QRcode image that your user must read in his TOTP app to generate the Time Based One Time Password
The application will return an HTTP Conflict error in case the user is already registered.
Once the user is registered, you can send a GET request passing in the params user and code
useris the user identification you registered your usercodeis the code generated by the TOTP application of your user
To run the test suite, please run the following command
$ pytest -vvx testsContributions are welcome!