This repository has been archived by the owner on Feb 15, 2020. It is now read-only.
forked from BooBSD/flask-odesk
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathREADME
132 lines (89 loc) · 4.15 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
===========
Flask-oDesk
===========
Requirements
============
* `flask`
* `python-odesk`
* `python-oauth2`
Authorization
==============
Quick start
-----------
Before you may use oDesk APIs, you will need to obtain your pair of API keys.
Visit the `oDesk API Center documentation <http://developers.odesk.com/Authentication#authentication>`_
for full details. Please note, that Flask-oDesk uses authorization via OAuth and it needs keys with auth type "OAuth".
Please make sure, that `SECRET_KEY` which is necessary for sessions, based on the secure cookies, is indicated in `settings.py`::
SECRET_KEY = '(your random secret key)'
You need to store your pair of oDesk API keys in `settings.py`::
ODESK_KEY = '(your oDesk public key)'
ODESK_SECRET = '(your oDesk secret key)'
You can also set the list of teams in `settings.py`, which will be able to authorize.
If you do not specify this option or leave the list empty, then all oDesk users will be able to authorize::
ODESK_AUTH_TEAMS = ('odesk:odeskpsbootcamp',)
Please make sure, that you have registered odesk module in your `app.py` correctly.
Please keep in mind, that `url_prefix` can be whatever you like::
from flask import Flask
from flaskext.odesk import odesk
app = Flask(__name__)
app.config.from_pyfile('settings.py')
app.register_module(odesk, url_prefix='/odesk')
Using authorization
-------------------
Please use the decorator `login_required` to close the access for anonymous users to the certain parts of your website::
@app.route('/only/for/odesk/users')
@odesk.login_required
def admin():
return "Welcome, oDesk user!"
If you want to indicate login or logout links in the template, than you can use `url_for` function and `odesk_is_authorized` variable::
{% if odesk_is_authorized %}
<a href="{{ url_for('odesk.logout') }}">Log out</a>
{% else %}
<a href="{{ url_for('odesk.login') }}">oDesk log in</a>
{% endif %}
To check the authorization of the current user you can use `is_authorized` method::
@app.route('/test')
def test():
if odesk.is_authorized():
return "You are authorized."
else:
return "You are not authorized yet."
If you need, you can start the authorization process manually from your code::
if not odesk.is_authorized():
return odesk.login()
You can also use `next` parameter to indicate URL, where will be redirect after the authorization process ends::
if not odesk.is_authorized():
return odesk.login(next='/blah/blah')
You can use `logout` method for user's logging out.
Please pay attention, that unlike `login` this method do not return the bulk of redirects.
It simply deletes the OAuth session. You should return response manually::
if odesk.is_authorized():
odesk.logout()
return redirect('/')
If you want to expand autorization process, you can use `after_login` decorator,
that indicates your function, which will be called after successfully authorization::
@odesk.after_login
def save_session():
# Getting current user's data. Please, see below how to use the Client.
session['user'] = odesk.get_client().hr.get_user('me')
If you have used `after_login` and saved something to the session, please,
do not forget to delete this session after logging out, using decorator `after_logout`::
@odesk.after_logout
def delete_session():
if 'user' in session:
del session['user']
Using client
============
You can use `get_access_token` method to get the current access token and access token secret,
that can be stored in DB and used for access to the client later, if necessary::
if odesk.is_authorized():
access_token, access_token_secret = odesk.get_access_token()
You can use `get_client` method to get the client::
if odesk.is_authorized():
c = odesk.get_client()
c.team.get_teamrooms()
Or you can use the client even if the current user is not authorized,
but you have the access token and access token secret::
if not odesk.is_authorized():
c = odesk.get_client(access_token, access_token_secret)
c.team.get_teamrooms()