forked from Trondheim-kommune/python-saml-idporten
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflask-sample.py
95 lines (74 loc) · 3.01 KB
/
flask-sample.py
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
import os
import ConfigParser
from flask import Flask, render_template, request, redirect
from idporten.saml import AuthRequest, LogoutRequest, Response, LogoutResponse
app = Flask(__name__)
def read_config(config_file, config_path="."):
config = ConfigParser.RawConfigParser()
config_path = os.path.expanduser(config_file)
config_path = os.path.abspath(config_path)
with open(config_path) as f:
config.readfp(f)
return config
app.cfg = read_config("example.cfg")
settings = {
'assertion_consumer_service_url' : app.cfg.get('saml', 'assertion_consumer_service_url'),
'issuer' : app.cfg.get('saml', 'issuer'),
'name_identifier_format' : app.cfg.get('saml', 'name_identifier_format'),
'idp_sso_target_url' : app.cfg.get('saml', 'idp_sso_target_url'),
'idp_cert_file' : app.cfg.get('saml', 'idp_cert_file'),
'private_key_file' : app.cfg.get('saml', 'private_key_file'),
'logout_target_url' : app.cfg.get('saml', 'logout_target_url'),
}
user_info = {}
### Routes ###
@app.route('/')
def home():
"""Render home page."""
auth_request = AuthRequest(**settings)
url = auth_request.get_signed_url(settings["private_key_file"])
print "OUTGOING URL:", url
return redirect(url)
@app.route('/logged_in', methods=['POST', "GET"])
def logged_in():
print "USER LOGGED IN VIA IDPORTEN"
print request.values
SAMLResponse = request.values['SAMLResponse']
res = Response(
SAMLResponse,
"TODO: remove signature parameter"
)
valid = res.is_valid(settings["idp_cert_file"], settings["private_key_file"])
uid = res.get_decrypted_assertion_attribute_value("uid")
name_id = res.name_id
print "UID", uid
print "NAME ID: ", name_id
print "Session index: ", res.get_session_index()
user_info["uid"] = uid
user_info["name_id"] = name_id
user_info["session_index"] = res.get_session_index()
return render_template('home.html', decrypted = res.decrypted, uid = uid)
@app.route('/log_me_out')
def logout():
print "Logout requested"
logout_request = LogoutRequest(name_id=user_info["name_id"],
session_index=user_info["session_index"],
**settings)
print "Logout xml", logout_request.raw_xml
url = logout_request.get_signed_url(settings["private_key_file"])
print "OUTGOING LOGOUT URL: ", url
return redirect(url)
@app.route('/logoutResponse')
def handle_logout_response():
SAMLResponse = request.values['SAMLResponse']
print "SAMLResponse", SAMLResponse
logout_response = LogoutResponse(SAMLResponse)
if logout_response.is_success():
print "User was successfully logged out."
user_info = None
else:
print "Logout failed."
return render_template('home.html')
if __name__ == '__main__':
port = int(os.environ.get('PORT', 9999))
app.run(host='0.0.0.0', port=port, debug=True)