Reputation: 491
I don't understand how google achieve the following mechanism of single sign on:
How can this second site detect that I've already been logged in. They are different domains. Youtube can't read the cookie of Gmail.
All the solutions I've read about Single sign on don't allow this. The client always ask permission to a central login app. In my example YouTube doesn't know I am the same user logged in Gmail (actually it does know, but I don't understand how)
Note that I type the url of "youtube" by hand. I don't clic the youtube icon from the upper toolbar of gmail (In that case gmail may pass some auth params through the url for example).
Upvotes: 40
Views: 25531
Reputation: 1182
The cookies are set on specific domains. Ex:
setcookie(name,value,expire,path,domain)
When you log in on gmail, before "mail.google.com", you have been redirected to "accounts.google.com" then to "mail.google.com" so the cookies are on "accounts.google.com" too.
In this case, the domain is "accounts.google.com" and the path is "/" (the home path).
When you request "www.youtube.com" then you click on "connection" it requests "accounts.google.com" fast so you can't see this redirection and checks if you have cookies on "accounts.google.com". If so, it checks if the cookies are valid and not expired, or user not banned... Then it redirects you to "www.youtube.com/signin?loginthisSession=Sessionid". This request contains the value of the of sessionid cookie catched from the cookies of "accounts.google.com".
In the last step, "www.youtube.com" logs you and set its own cookie on the domain "www.youtube.com" and saves them.
So the trick is on the 302 HTTP redirect.
Update
i do not know why people keep mentioning iframe
take a look at the date whene this questions was posted on 2016
google was not using then iframe
as i mentioned the capture of web traffic as you can see SetSID
wich means set the cookie of SESSION_ID from accounts.google.dz(com)
then redirects to youtube.com
it can not be used trought iframe
differant domains
security measure
you can not be redirected from domain to domain trought iframe neither
please read this before posting
Upvotes: 23
Reputation: 4786
While evaluating this cross domain SSO topic, I have come up with possible a new SSO synchronization flow using cookie with timestamp. Although it is not a flow used by Google, I think this flow is possible to implement for system with limited number of domains.
This flow do not use 3rd party cookie
This is going to be a long post :)
To make an example, let say we have these domains for our example pet forums:
dog.domain2.com
, user have not sign in yet.dog.domain2.com
account.domain1.com
for login
redirect_uri
as in the URL to go back after login success.domains2.com
domain (More on the cookie value later).domains3.com
domain.domains1.com
domainNow, right after login flow we have cookies over all 3 domains. Any of our service (e.g. https://cat.domain1.com / https://dog.domain2.com / https://rabbit.domain2.com ) can access this cookie under their own domain.
have_user_login
= true / false have sync issueUser A
login, visit https://cat.domain1.com, User A
Logout, and User B
loginUser A
instead of User B
, hence the sync issue.user_id
on those cookie, and let all the domain to see them and set the user accordingly.
user_id
, pasting it to their own browser cookie).User A
Login, visit https://cat.domains1.com Then User B
LoginUser A
and User B
will have a different login expired time, storing and compare that timestamp will tell the user to sync with SSO againE.g. On https://cat.domains1.com, you can add this to the top of your page load
<?php
$sso_expired_time = $_COOKIE["sso_expired_time "] ?? 0;
$website_expired_time = $_COOKIE["website_expired_time "] ?? 0;
if( (int) $sso_expired_time < time() || $sso_expired_time !== $website_expired_time ) {
// User not sync, perform sync
setcookie("website_expired_time", $website_expired_time,0,"/", $_SERVER['SERVER_NAME'], true, true);
// Redirect to https://account.domain1.com for Login
// Or, Initiate the login sequence for your selected login protocol
header("Location: https://account.domain1.com/.....")
exit;
}
// User is sync
// Page load success, continue other operation
Login is very similar to Login, basically:
Upvotes: 1
Reputation: 39271
Cookies and localStorage can be shared between domains using an intermediate domain. On the home page is embedded an "iframe ', which accesses cookies and sends messages to the main.
mail.google.com
and youtube.com
can share the cookies using accounts.google.es
. Open Chrome->Inspect->Resources->Local storag
e and you will see in accounts.google.com
the authentication token in JWT format.
I have detailed the technical steps in this answer: https://stackoverflow.com/a/37565692/6371459. Also take a look at https://github.com/Aralink/ssojwt to see an implementation of a Single Sign On using JWT in a central domain
Upvotes: 5
Reputation: 181
Check this out.. http://www.codeproject.com/Articles/106439/Single-Sign-On-SSO-for-cross-domain-ASP-NET-applic. The article consist explanation and sample of SSO cross domain.
Upvotes: 2
Reputation: 976
As far as I remember, if I am not wrong, cookies contains a specified field that contains the domain that can read and get such cookie. That is made in order to prevent certain web sites to read all your cookie list and make your own business. You should be able to see which kind of sites can 'see' your gmail cookie.
Correct me if I am wrong, this should compile the answer given regarding the SID and gmail-YouTube example..
Upvotes: 0