oauth/client.py
author durandn
Mon, 14 Mar 2016 14:17:29 +0100
changeset 32 eb9e83610c99
parent 10 50b532f5e6cb
child 63 6bfac7c633a0
permissions -rw-r--r--
added logging and logs config
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3
3f52a017e6f5 Added link to open a new Renkan from mock GED client
durandn
parents: 1
diff changeset
     1
from flask import Flask, url_for, session, request, jsonify, render_template, redirect
1
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
     2
from flask_oauthlib.client import OAuth
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
     3
from settings.client_settings import ClientSettings
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
     4
import base64
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
     5
import requests
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
     6
import json
1
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
     7
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
     8
app = Flask(__name__)
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
     9
app.debug = True
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    10
app.secret_key = 'secret'
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    11
app.config.from_object(ClientSettings)
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    12
oauth = OAuth(app)
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    13
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    14
remote = oauth.remote_app(
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    15
    'remote',
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    16
    consumer_key=app.config.get("CLIENT_ID", ""),
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    17
    consumer_secret=app.config.get("CLIENT_SECRET", ""),
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    18
    request_token_params=app.config.get("REQUEST_TOKEN_PARAMS", ""),
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    19
    base_url=app.config.get("BASE_URL", ""),
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    20
    request_token_url=app.config.get("REQUEST_TOKEN_URL", ""),
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    21
    access_token_url=app.config.get("ACCESS_TOKEN_URL", ""),
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    22
    authorize_url=app.config.get("AUTHORIZE_URL", "")
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    23
)
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    24
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    25
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    26
@app.route('/')
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    27
def index():
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    28
    if 'remote_oauth_authorizationcode' not in session:
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    29
        next_url = request.args.get('next') or request.referrer or None
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    30
        return remote.authorize(
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    31
            callback=url_for('authorized', next=next_url, _external=True)
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    32
        )
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    33
    if 'me' not in session:
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    34
        resp = remote.get('user/InfoComplete')
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    35
        print("authcode resp data: "+str(resp.data))
10
50b532f5e6cb Adjusted oauth test server and client to better reflect GED interface
durandn
parents: 5
diff changeset
    36
        me = resp.data.get("displayName", "")
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    37
        session["me"] = me
10
50b532f5e6cb Adjusted oauth test server and client to better reflect GED interface
durandn
parents: 5
diff changeset
    38
        id = resp.data.get("id", "")
50b532f5e6cb Adjusted oauth test server and client to better reflect GED interface
durandn
parents: 5
diff changeset
    39
        session["me_id"] = id
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    40
    if 'remote_oauth_clientcredentials' not in session:
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    41
        auth_string = bytes(app.config["CLIENT_ID"]+':'+app.config['CLIENT_SECRET'], "utf-8")
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    42
        auth_code = base64.b64encode(auth_string).decode("utf-8")
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    43
        resp = requests.post(app.config["ACCESS_TOKEN_URL"]+"?grant_type=client_credentials&scope=basic", data={}, headers={
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    44
            'Authorization': 'Basic %s' % auth_code,
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    45
        })
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    46
        if resp is None:
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    47
            return 'Access denied: reason=%s error=%s' % (
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    48
                request.args['error_reason'],
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    49
                request.args['error_description']
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    50
            )
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    51
        session['remote_oauth_clientcredentials'] = (json.loads(resp.text)['access_token'], '')
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    52
        resp = remote.get('user/InfoComplete')
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    53
        print("clientcredentials resp data: "+str(resp.data))
32
eb9e83610c99 added logging and logs config
durandn
parents: 10
diff changeset
    54
        server = resp.data.get("displayName", "")
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    55
        session["server"] = server
10
50b532f5e6cb Adjusted oauth test server and client to better reflect GED interface
durandn
parents: 5
diff changeset
    56
    return render_template('client/index.html', current_user_id=session["me_id"], current_username=session["me"], oauth_username=session["server"])
1
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    57
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    58
@app.route('/renkan-request')
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    59
def renkan_request():
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    60
    if 'remote_oauth_clientcredentials' in session:
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    61
        resp = requests.post(
10
50b532f5e6cb Adjusted oauth test server and client to better reflect GED interface
durandn
parents: 5
diff changeset
    62
            app.config["CREATE_RENKAN_ENDPOINT"]+"?act_as="+str(session.get("me_id", "anonymous")), 
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    63
            {"title": "RENKAN_FROM_GED"},
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    64
            headers={
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    65
                'Authorization': 'Bearer %s' % session['remote_oauth_clientcredentials'][0],
10
50b532f5e6cb Adjusted oauth test server and client to better reflect GED interface
durandn
parents: 5
diff changeset
    66
                'renkan-act-as': session.get("me_id", "anonymous")
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    67
            }
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    68
        )
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    69
        print(resp.text)
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    70
    return redirect('/')
1
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    71
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    72
@app.route('/authorized')
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    73
def authorized():
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    74
    resp = remote.authorized_response()
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    75
    if resp is None:
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    76
        return 'Access denied: reason=%s error=%s' % (
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    77
            request.args['error_reason'],
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    78
            request.args['error_description']
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    79
        )
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    80
    session['remote_oauth_authorizationcode'] = (resp['access_token'], '')
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    81
    
3
3f52a017e6f5 Added link to open a new Renkan from mock GED client
durandn
parents: 1
diff changeset
    82
    return redirect('/')
1
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    83
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    84
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    85
@remote.tokengetter
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    86
def get_oauth_token():
5
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    87
    print("referrer : "+request.referrer)
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    88
    if 'remote_oauth_clientcredentials' in session and 'server' not in session:
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    89
        return session['remote_oauth_clientcredentials']
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    90
    else:
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    91
        return session.get('remote_oauth_authorizationcode', '')
4407b131a70e adjustments on Oauth server and mock ged client + Readme
durandn
parents: 3
diff changeset
    92
1
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    93
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    94
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    95
if __name__ == '__main__':
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    96
    import os
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    97
    os.environ['DEBUG'] = 'true'
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    98
    os.environ['OAUTHLIB_INSECURE_TRANSPORT'] = 'true'
5f50937893ac Commit work on metaeducation
durandn
parents:
diff changeset
    99
    app.run(host='localhost', port=8000)