Single Sign-On (SSO) is a solution which lets users authenticate at one application and then use that same user session at many completely different applications without re-authenticating over and over again.
HTTP Cookies (RFC 6265) are vital component to achieve SSO, as it tracks the user’s session across different applications. Before going in detail on SSO, let's look at the HTTP Cookies.
Note: All servers are hosted in the same domain example.com.
HTTP Cookies (RFC 6265) are vital component to achieve SSO, as it tracks the user’s session across different applications. Before going in detail on SSO, let's look at the HTTP Cookies.
HTTP Cookies
- An HTTP cookie is a name-value pair data sent by a web-server (party-1) to a web-browser (party-2) to maintain a state between those two parties.
- Because of state maintenance mechanism, cookies are used for,
- Tracking user's information and browsing patterns: For example: preserving cart items in a shopping website and displaying advertisements based on browsing history .
- User authentication: To know whether the user is logged in or not, and which account they are logged in with.
- HTTP Cookies (RFC 6265) has defined some attributes associated with cookies: They are:
Attributes
|
Explanation
|
Name/ Value
|
Any US-ASCII characters with some exceptions.
For example: SessionID=123
|
Domain
|
- If
specified, the domain and subdomains of the cookie where this cookie can be
sent to. For eg: if
Domain=example.com; then browser can send cookie to
example.com and host1.example.com as well)
- If not
specified, it will be a handled as a host-based cookie and browser only
send to the exact domain and not to its subdomains. For eg:
from earlier case, the browser can send only to host that which it set the
cookie, i.e., to example.com only.
|
Path
|
A given URL path where the cookie applies to. For eg: /
(i.e., root path)
|
Expires
|
GMT timestamp that says when the cookie expire.
For eg: 2018-08-24T22:30:17.000Z. If not specified, the cookie is valid until the browser closed.
|
Max-Age
|
The amount of time (in seconds) the cookie should be
valid. For eg: 3600. Both Expires and Max-Age are used for session timeout and context remains same. If both (Expires and Max-Age) are set, Max-Age will have precedence.
|
HttpOnly
|
When used, the cookies aren’t accessible via JavaScript,
giving some protection against XSS attacks.
|
Secure
|
When used, the cookie can be only transferred through
HTTPS, regular HTTP requests won’t include this cookie.
|
SameSite
|
Prevents the browser from sending the cookie along with
cross-site requests. Provides some protection against cross-site request
forgery attacks.Possible values are:
- Strict: Cookie won’t be sent to target site in all
cross-domain browsing context.
- Lax: Cookie will be sent along with the GET request
initiated by the third-party website, but not request to POST or request originated from
|
- Creating a cookie with same name (value can be anything), and set the Expires property to a date in the past will make that cookie to be removed or cleared-out from the browser and user will lose his/ her session.
How Cookies are related to SSO?
Cookies are the ones controls and tracks the user session in the web-browser and that helps to achieve the SSO across all applications within the same domain. Refer below sequence diagram and its explanations in detail.
SSO Sequence Diagram |
Note: All servers are hosted in the same domain example.com.
- User request page1.html from host1.example.com (Application-1 & Web Agent-1).
- host1.example.com sees there is no valid Session Cookie.
- Hence redirect the user to sso.example.com (SSO & Authentication Services) for authentication with return URL as page1.html.
- Browser request for authentication to Authentication service.
- Authentication service displays login page for the user to enter their username/ password.
- User submits username/ password.
- Authentication service authenticates the submitted credentials.
- Upon successful authentication, Authentication service sets redirect URL to page1.html (from #3) and SSO service sets the Session Cookie with the following attributes:
- Cookie AttributesValuesExplanationName/ ValueSessionID=123This Session Cookie is named as SessionID and value as 123.Domainexample.comThis Session Cookie is valid for domainexample.com and all its subdomains like sso.example.com, host1.example.com and host2.example.com.Path/This Session Cookie applies to path root.Expires/ Max-Age2018-08-24T22:30:17.000ZThis Session Cookie will expire on July 24, 2018 at 10:30PM, GMT.HttpOnlyHttpOnlyThis Session Cookie is not accessible from JavaScripts.SecureSecureThis Session Cookie can be sent only in HTTP connections.SameSiteStrictThis Session Cookie is not valid for any cross-domain browsing context.
- Browser redirect to page1.html at host1.example.com with the Session Cookie.
- host1.example.com asks SSO service to validate the received Session Cookie.
- SSO service validates and return response to host1.example.com.
- Finally host1.example.com allows user to access page1.html.
- After sometime, in the same browser session, the same user with valid Session Cookie request to access page2.html at host2.example.com (Application-2 & Web Agent-2).
- host2.example.com request SSO service to validate the received Session Cookie.
- SSO service validates and return response to host2.example.com.
- Finally host2.example.com allows user to access page2.html without asking to re-login at sso.example.com.
- This is because the Session Cookie is bound and valid to domain example.com, and hence SSO & Authentication Services did not authenticate the user once again.
Conclusion
- So far we saw SSO works fine across applications when their domain name is same (i.e., sso.example.com, host1.example.com and host2.example.com, all are based on same domain example.com).
- But what happen if applications running on different domains? For example: sso.example.com, host1.example1.com, host2.example2.com. How to achieve SSO for these applications?
- The answer is Cross Domain Single Sign-On (CDSSO).
- Let’s discuss about CDSSO in next blog post. At least this blog gives some basic concepts on SSO and let's look in the next post for complex use-cases on CDSSO.