summaryrefslogtreecommitdiffabout
path: root/lib
Unidiff
Diffstat (limited to 'lib') (more/less context) (ignore whitespace changes)
-rw-r--r--lib/basic_rp.cc21
1 files changed, 2 insertions, 19 deletions
diff --git a/lib/basic_rp.cc b/lib/basic_rp.cc
index 2da8416..a884583 100644
--- a/lib/basic_rp.cc
+++ b/lib/basic_rp.cc
@@ -278,28 +278,11 @@ namespace opkele {
278 if(ext) ext->id_res_hook(om,signeds); 278 if(ext) ext->id_res_hook(om,signeds);
279 } 279 }
280 280
281 class check_auth_message_proxy : public basic_openid_message {
282 public:
283 const basic_openid_message& x;
284
285 check_auth_message_proxy(const basic_openid_message& xx) : x(xx) { }
286
287 bool has_field(const string& n) const { return x.has_field(n); }
288 const string& get_field(const string& n) const {
289 static const string checkauthmode="check_authentication";
290 return (n=="mode")?checkauthmode:x.get_field(n); }
291 bool has_ns(const string& uri) const {return x.has_ns(uri); }
292 string get_ns(const string& uri) const { return x.get_ns(uri); }
293 fields_iterator fields_begin() const {
294 return x.fields_begin(); }
295 fields_iterator fields_end() const {
296 return x.fields_end(); }
297 };
298
299 void basic_RP::check_authentication(const string& OP, 281 void basic_RP::check_authentication(const string& OP,
300 const basic_openid_message& om){ 282 const basic_openid_message& om){
301 openid_message_t res; 283 openid_message_t res;
302 direct_request(res,check_auth_message_proxy(om),OP); 284 static const string checkauthmode = "check_authentication";
285 direct_request(res,util::change_mode_message_proxy(om,checkauthmode),OP);
303 if(res.has_field("is_valid")) { 286 if(res.has_field("is_valid")) {
304 if(res.get_field("is_valid")=="true") { 287 if(res.get_field("is_valid")=="true") {
305 if(res.has_field("invalidate_handle")) 288 if(res.has_field("invalidate_handle"))