Creative Use of OpenID -
the situation
i have 3 websites used same one. result, use single database user administration , authentication. unfortunately, distinct websites , have grown include drastically different features.
when 3 sites 1 site, used nifty layout switcher keyed on requested url determine stylesheets use. if logged in domain1.com
user domain2.com
, server swap url without problem.
as added features 1 site, needed split 3 different systems keep stepping on ourselves. adding feature domain1
break unrelated system on domain3
, keeping things separate smarter. kept same user database because it's tied in our licensing , subscription systems.
now, want begin using ssl/tls protect sites ... meaning they're transferred on https rather http.
using http, didn't have many problems bouncing users 1 site version another. log in of 3 sites, server detect site supposed on, , kick on there. since we're using state server session management, didn't lose in transfer, either (same user database, same session id, same session).
using https, lose when kick users 1 site another. @ moment, best can display pop-up , explain "you meant log in domain2.com
... please update bookmarks , log in again" before kicking them right domain. works, it's inelegant solution, frustrates end users, , sloppy.
ideal solution
ideally, users automatically logged in site they're being transferred once there. so:
- log in
domain1.com
user accountdomain2.com
- get popup explaining mistake , asking update bookmarks
- be automatically transferred
domain2.com
, logged in if you'd gone there begin with.
original approach
the first idea had accomplish redirect user , append id of kind url , fetch appropriate parameter when new site. while works , can log people in ... it's insecure. you're creating token anyone use authenticate user , passing on wire intercepted , impersonated.
openid approach
what i'm thinking now, , i'm not sure work (hence question), use variation of openid. both domain1.com
, domain2.com
on our servers, under our control, , using our ssl certificates. have full access database and, once know session restore, can restore user's session once logging them in after site redirect.
when i've used openid in past, it's taken format:
- go site want use , click log in
- be redirected login page site b, have account
- log in site b , grant permission site use information
- be redirected authenticated portion of site a
i want our system replicate steps 3-4 of process. basically:
- go
domain1.com
, log in (you have account) - read message fixing bookmarks , click ok redirected right site.
- be redirected authenticated portion of
domain2.com
from i've ready openid far, seems possible. , i've been reading on openid , oauth couple of days figure out. every solution, tutorial, , manual can find describes fully-fleshed-out openid server. don't need people use external openids authenticate our system, , don't want become openid provider either. want create solution works following above description.
so, is possible using openid? parts of protocol need flesh out make work?
you don't need openid log user simultaneously multiple domains. can generate "signed redirect" domain1.com domain2.com "assertion" 1 of parameters on url domain2.com
the assertion should contain userid, timestamp, , signature generated using shared secret between domain1 , domain2. in order prevent replay attacks, domain2 should verify timestamp relatively recent (10 minutes). signature should generated hashing assertion shared secret. signature enables domain2 verify domain1 generated assertion, assuming shared secret known between domain1 , domain2.
at high level, mechanism described equivalent generating "unsolicited assertion" in saml world. unsolicited assertions theoretically supported in openid, i've never seen implemented in practice.
if haven't implemented sort of single sign on (sso) technique before, should careful, incorrect implementations can potentially allow attackers login domain2 user.
Comments
Post a Comment