Skip to content

Latest commit

 

History

History
48 lines (28 loc) · 1.96 KB

README.md

File metadata and controls

48 lines (28 loc) · 1.96 KB

Yolo API

This is a Flask-OAuthlib server example for the 'Resource Owner Password Credentials Grant' described in RFC 6749 (Section 1.3.3).

Deployment

Clone this repository and install all dependencies:

$ pip install -r requirements.txt

Once all dependencies are installed, you may run the application using python app.py.

User and Client Management

For the example to work properly, you will need to create a client and user. You can create users and clients through the management interface available at https://localhost:5000.

Testing

After creating a user and client, you may use curl to test the application.

Generating a Bearer Token

$ curl -k -X POST -d "client_id=9qFbZD4udTzFVYo0u5UzkZX9iuzbdcJDRAquTfRk&grant_type=password&username=jonas&password=pass" https://localhost:5000/oauth/token
{"access_token": "NYODXSR8KalTPnWUib47t5E8Pi8mo4", "token_type": "Bearer", "refresh_token": "s6L6OPL2bnKSRSbgQM3g0wbFkJB4ML", "scope": ""}

Accessing a Protected Resource Using Retrieved Bearer Token

$ curl -k -H "Authorization: Bearer NYODXSR8KalTPnWUib47t5E8Pi8mo4" https://localhost:5000/yolo
YOLO! Congraulations, you made it through and accessed the protected resource!

Security

SSL/TLS

When working with OAuth 2.0, all communications must be encrypted with SSL/TLS. This example uses auto-generated SSL certificates, however in a production environment you should use a more formal, widely trusted certificate associated with your domain. In addition, requests should be handled by something like NGINX and proxied to the authentication service.

Note: Add -k to your curl arguments if you are working with an untrusted development server running under SSL/TLS.

Password Hashing

Bcrypt and a randomly generated salt are used to hash each user password before it is added to the database. You should never store passwords in plain text!