Oauth 2.0 and Openid Connect for Single Page Applications

Total Page:16

File Type:pdf, Size:1020Kb

Oauth 2.0 and Openid Connect for Single Page Applications OAUTH 2.0 AND OPENID CONNECT FOR SINGLE PAGE APPLICATIONS DR. PHILIPPE DE RYCK https://Pragmatic Web Security.com A RESTAURANT REVIEW APPLICATION FRONTEND AND MOBILE APPLICATIONS APIS TO EMPOWER PARTNER SITES @PhilippeDeRyck OpenID Connect OAuth 2.0 Authenticate the user for me? Can I access the API please? Help me out here, is this client allowed to do that? OAuth 2.0 Can you handle this for me please? Here's an access token OAuth 2.0 @PhilippeDeRyck TERMINOLOGY This session OAuth 2.0 OpenID Connect User Resource Owner End-User API Resource Server Security Token Service (STS) Authorization Server OpenID Provider Client Client Relying Party @PhilippeDeRyck I am Dr. Philippe De Ryck Founder of Pragmatic Web Security Google Developer Expert Auth0 Ambassador / Expert SecAppDev organizer I help developers with security Academic-level security training Hands-on in-depth online courses Security advisory services https://pragmaticwebsecurity.com THE IMPLICIT FLOW 5 Allow the restograde app access? 3 Who are you? Authenticate please! 4 Authenticate to restograde.com 6 Authorize access Follow redirect to restograde.com 2 7 Redirect to the restograde app with access token 9 Request with 1 Navigate browser to restograde.com access token 8 Reload application with access token 10 Response THE IMPLICIT FLOW 5 Allow the restograde app access? 3 Who are you? Authenticate please! 4 Authenticate to restograde.com 6 Authorize access Follow redirect to restograde.com 2 Access tokens are sent in the insecure frontchannel. Refresh tokens are not 7 Redirect to the restograde app with access token allowed in the Implicit flow. 9 Request with 1 Navigate browser to restograde.com access token 8 Reload application with access token 10 Response THE AUTHORIZATION CODE FLOW WITH PKCE 8 Store code challenge 6 Allow the restograde frontend access? with the authorization code 4 Who are you? Authenticate please! 5 Authenticate to restograde.com 7 Authorize access 12 Check code veriFier against stored code challenge Exchange Follow redirect to restograde.com Identity token, access token with code challenge 3 authorization code 11 13 with code verifier (& reFresh token) 9 Redirect to the restograde frontend with authorization code 14 Use inFormation From identity Generate code verifier and token to "authenticate" the user 1 calculate code challenge 15 Request with 2 Open restograde.com with code challenge access token 10 Follow redirect with authorization code 16 Response The frontend generates and stores the code verifier in the browser. The code challenge illustrates that the frontend knew this secret in step 2, and still knows it in step 11 No tokens are issued through the URL-based redirect mechanism. The authorization code has a limited lifetime, can only be used once, and only in combination with the code verifier The Authorization Code flow also supports refresh tokens 2 3 The redirect URI 1 https://sts.restograde.com/authorize 2 ?response_type=code Indicates the authorization code flow 3 &client_id=lY5g0BKB7Mow4yDlb6rdGPsO2i1g7Osv The client requesting access 4 &scope=read 5 &redirect_uri=https://web.restograde.com/callback Where the STS should send the code 6 &state=s0wzojm2w8c23xzprkk6 7 &code_challenge=JhEN0Amnj7B…Wh5PxWitZYK1woWh5PxWitZY The PKCE code challenge 8 &code_challenge_method=S256 @PhilippeDeRyck 11 The request to exchange the authorization code 1 POST https://sts.restograde.com/oauth/token 2 3 grant_type=authorization_code Indicates the code exchange request 4 &client_id=lY5g0BKB7Mow4yDlb6rdGPsO2i1g7Osv The client exchanging the code 5 &redirect_uri=https://web.restograde.com/callback The redirect URI used before 7 &code=SplxlOBeZQQYbYS6WxSbIA The code received in step 10 8 &code_verifier=lT5q6nbPQRtdj…~IUdkErVDFG.fF4z7CzCxo The code verifier from step 1 @PhilippeDeRyck https://flowsimulator.pragmaticwebsecurity.com Loading the Auth0 service in an Angular application 1 @NgModule({ 2 imports: [ 3 BrowserModule, 4 AuthModule.forRoot({ Configure the SDK with the domain 5 domain: 'sts.restograde.com', of your tenant and the clientID of 6 clientId: 'lY5g0BKB7Mow4yDlb6rdGPsO2i1g7Osv', the SPA application 7 }), 8 ], 9 … 10 }) Service methods for relevant OAuth 2.0 / OIDC features 1 constructor(public auth: AuthService) {} 2 3 login() { The Auth0 AuthService exposes all relevant features to use in 4 this.auth.loginWithRedirect(); components and services 5 } 6 logout() { 7 this.auth.logout({ returnTo: window.location.origin }); 8 } @PhilippeDeRyck Wrapping the Auth0 React SDK around the application 1 ReactDOM.render( 2 <Auth0Provider Configure the SDK with the domain 3 domain="sts.restograde.com" of your tenant and the clientID of 4 clientId="lY5g0BKB7Mow4yDlb6rdGPsO2i1g7Osv" the SPA application 5 redirectUri={window.location.origin} 6 > 7 <App /> 8 </Auth0Provider>, 9 document.getElementById('app') 10 ); Hooks for relevant OAuth 2.0 / OIDC features 1 const { 2 isLoading, 3 isAuthenticated, Feature-specific hooks expose all 4 error, relevant information and 5 user, operations for use in components 6 loginWithRedirect, 7 logout, 8 getAccessTokenSilently, 9 } = useAuth0(); @PhilippeDeRyck Auth0's generic JS SDK, which can be used in any JS-based framework or frontend application @PhilippeDeRyck The Implicit flow is deprecated in favor of the Authorization Code flow with PKCE The Implicit flow has not become more vulnerable, the other flow is just better @PhilippeDeRyck ? What if an access token expires? THE REFRESH TOKEN FLOW Request new access token 2 3 Access token & reFresh token with reFresh token 4 Request with access token Frontend has an access token and reFresh token, and monitors 1 5 Response access token expiration What if an attacker injects malicious code ? to steal the tokens from the SPA? Third-party Remote code dependencies inclusions External content User-provided (e.g., ads) data @PhilippeDeRyck REFRESH TOKEN ROTATION • Refresh token rotation is required for using refresh tokens in the browser • Part of the OAuth 2.0 for Browser-Based Apps proposal & OAuth 2.1 draft • Refresh tokens are used once to obtain a new access token and new refresh token • Previously used refresh tokens become invalid App obtains tokens App refreshes tokens App refreshes tokens App refreshes tokens AT1 and RT1 Use RT1 Use RT2 Use RT3 Receive AT2 and RT2 Receive AT3 and RT3 Receive AT4 and RT4 AT1 expires AT2 expires AT3 expires @PhilippeDeRyck REFRESH TOKEN ROTATION 2 The request to exchange a refresh token 1 POST https://sts.restograde.com/oauth/token 2 3 grant_type=refresh_token 4 &client_id=DtsTliLAWq3JXIwaoPQzl8vXhNI6qGnb 5 &refresh_token=8xLOxBtZp8 The latest refresh token obtained from the STS 3 The response from the Security Token Service 1 { 2 "access_token": "eyJhbGciO...du6TY9w", A new access token 3 "token_type": "Bearer", 4 "expires_in": 3600, 5 "refresh_token": "mTVeKoIZYy", A new refresh token to be used in the next flow 6 } @PhilippeDeRyck DETECTING REFRESH TOKEN ABUSE • When the STS detects the re-use of a refresh token, something is wrong • The refresh token is immediately revoked, preventing abuse • To ensure security, the STS revokes the entire token chain of this refresh token • The abuse of RT2 leads to the revocation of RT3, RT4, … App obtains tokens App refreshes tokens App refreshes tokens AT1 and RT1 Use RT1 Use RT2 Receive AT2 and RT2 AT1 expires Attacker uses RT2 AT2 expires Receive AT3 and RT3 STS notices reuse of RT2 Attacker steals RT2 No tokens are issued @PhilippeDeRyck RT3 is revoked DETECTING REFRESH TOKEN ABUSE • When the STS detects the re-use of a refresh token, something is wrong • The refresh token is immediately revoked, preventing immediate abuse • To ensure security, the STS revokes the entire token chain of this refresh token • The abuse of RT2 leads to the revocation of RT3, RT4, … App obtains tokens App refreshes tokens App refreshes tokens STS notices reuse of RT2 AT1 and RT1 Use RT1 Use RT2 No tokens are issued Receive AT2 and RT2 Receive AT3 and RT3 RT3 is revoked AT1 expires AT2 expires AT3 expires Attacker uses RT2 Attacker steals RT2 @PhilippeDeRyck ? Problem solved, right? SIDESTEPPING REFRESH TOKEN ROTATION https://app.restograde.com 1 Monitor the app for refresh tokens (if available) 2 Keep running the refresh flow when needed 3 Return new access tokens and refresh tokens 4 4 Send tokens to a server controlled by the attacker 5 Wait for the app to become inactive to use RT 1 2 The SDK using refresh tokens to renew access tokens 3 5 STEALING ACCESS TOKENS FROM THE LEGITIMATE SDK https://app.restograde.com 1 Run the refresh token flow to get fresh tokens 2 The tokens returned by the STS 3 Extract accessible tokens from the JS environment 4 4 Send access tokens to an attacker-controlled server 3 1 The SDK using refresh tokens to renew access tokens 2 ? So, we're screwed? ! Yes. THE CONCEPT OF A BACKEND-FOR-FRONTEND The Restograde application Run the Authorization Code flow with client authentication 1 2 Issue access token and reFresh token Proxy API requests with access token Cookie-based session 3 retrieved From session The OAuth 2.0 client application The client can follow best practices for backend applications (client authentication, sender constrained tokens, …) THE DETAILS OF A BACKEND-FOR-FRONTEND 5 Authentication / client authorization Follow redirect to restograde.com 4 1 Login to Restograde Exchange authorization code 8 9 Identity token, access token, & reFresh token with client authentication 6 Redirect to BFF with code Use inFormation From identity 3 Initialize the code flow 10 token to "authenticate" the user 7 Redirect with authorization code Lookup tokens with session 13 14 Request with 2 Login 12 API request access token 11 Logged in 16 API data 15 Response Sensitive Single Page Applications should ! definitely consider using a BFF KEY TAKEAWAYS 1 Use the Authorization Code flow with PKCE over the Implicit flow 2 Use short access tokens lifetimes and refresh tokens with rotation 3 Sensitive SPAs should avoid tokens in the browser in favor of a BFF @PhilippeDeRyck This online course condenses dozens of confusing specs into a crystal-clear academic-level learning experience 25% discount Use coupon code DEV_DAY2020 Offer expires Nov.
Recommended publications
  • Supporting Secure Services on Dynamic Aggregation of Heterogeneous Networks
    Supporting Secure Services on Dynamic Aggregation of Heterogeneous Networks SUBMITTED TO UNIVERSITY OF SOUTHERN QUEENSLAND IN PARTIAL FULFILLMENT OF THE REQUIREMENTS FOR THE DEGREE OF DOCTOR OF PHILOSOPHY David Tai Wai Lai July 2010 Certification of Dissertation I certify that the ideas, experimental work, results, analysis, software, and conclusions reported in this dissertation are entirely my own effort, except where otherwise acknowl- edged. I also certify that the work is original and has not been previously submitted for any other award or degree. Signature of Candidate Date Endorsement Signature of Supervisor Date ii I certify that I have read this dissertation and that, in my opin- ion, it is fully adequate in scope and quality as a dissertation for the degree of Doctor of Philosophy. Dr. Zhongwei Zhang (University of Southern Queensland) I certify that I have read this dissertation and that, in my opin- ion, it is fully adequate in scope and quality as a dissertation for the degree of Doctor of Philosophy. Dr. Shan Suthaharan (University of Northern Carolina at Greensboro) iii iv Abstract Sharing of services over IP networks prove to be an effective approach to satisfy the demand of network users when their home network cannot offer the required services. Authenti- cation, authorization and revocation are some of the important challenges in the service sharing services over IP networks. This research address the problem associated with the authentication because it becomes more and more complicated due to the incompatible au- thentication schemes used by individual autonomous networks, privacy of authentication information, and the overhead in establishing the sharing.
    [Show full text]
  • Etsi Tr 133 995 V13.0.1 (2017-04)
    ETSI TR 133 995 V13.0.1 (2017-04) TECHNICAL REPORT Universal Mobile Telecommunications System (UMTS); LTE; Study on security aspects of integration of Single Sign-On (SSO) frameworks with 3GPP operator-controlled resources and mechanisms (3GPP TR 33.995 version 13.0.1 Release 13) 3GPP TR 33.995 version 13.0.1 Release 13 1 ETSI TR 133 995 V13.0.1 (2017-04) Reference RTR/TSGS-0333995vd01 Keywords LTE,SECURITY,UMTS ETSI 650 Route des Lucioles F-06921 Sophia Antipolis Cedex - FRANCE Tel.: +33 4 92 94 42 00 Fax: +33 4 93 65 47 16 Siret N° 348 623 562 00017 - NAF 742 C Association à but non lucratif enregistrée à la Sous-Préfecture de Grasse (06) N° 7803/88 Important notice The present document can be downloaded from: http://www.etsi.org/standards-search The present document may be made available in electronic versions and/or in print. The content of any electronic and/or print versions of the present document shall not be modified without the prior written authorization of ETSI. In case of any existing or perceived difference in contents between such versions and/or in print, the only prevailing document is the print of the Portable Document Format (PDF) version kept on a specific network drive within ETSI Secretariat. Users of the present document should be aware that the document may be subject to revision or change of status. Information on the current status of this and other ETSI documents is available at https://portal.etsi.org/TB/ETSIDeliverableStatus.aspx If you find errors in the present document, please send your comment to one of the following services: https://portal.etsi.org/People/CommiteeSupportStaff.aspx Copyright Notification No part may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying and microfilm except as authorized by written permission of ETSI.
    [Show full text]
  • State of North Carolina Request for Proposal No
    STATE OF NORTH CAROLINA REQUEST FOR PROPOSAL NO. 41-100358-001 Department of Information Technology Offers will be publicly opened: April 29, 2020 at 2:00pm EST Issue Date: March 2, 2020 Refer ALL inquiries regarding this RFP to: Commodity Number: 920 Leroy Kodak] Description: Identity Access Management System [email protected]] Using Agency: Department of Information [919-754-6665] Technology Requisition No.: None OFFER The State solicits offers for Services and/or goods described in this solicitation. All offers and responses received shall be treated as Offers to contract. EXECUTION In compliance with this Request for Proposal, and subject to all the conditions herein, the undersigned offers and agrees to furnish any or all Services or goods upon which prices are offered, at the price(s) offered herein, within the time specified herein. By executing this offer, I certify that this offer is submitted competitively and without collusion. Failure to execute/sign offer prior to submittal shall render offer invalid. Late offers are not acceptable. OFFEROR: STREET ADDRESS: P.O. BOX: ZIP: CITY, STATE & ZIP: TELEPHONE NUMBER: TOLL FREE TEL. NO PRINT NAME & TITLE OF PERSON SIGNING: FAX NUMBER: AUTHORIZED SIGNATURE: DATE: E-MAIL: Offer valid for one hundred twenty (120) days from date of offer opening unless otherwise stated here: ____ days ACCEPTANCE OF OFFER If any or all parts of this offer are accepted, an authorized representative of the Department of Information Technology shall affix their signature hereto and any subsequent Request for Best and Final Offer, if issued. Acceptance shall create a contract having an order of precedence as follows: Best and Final Offers, if any, Special terms and conditions specific to this RFP, Specifications of the RFP, the Department of Information Technology Terms and Conditions, and the agreed portion of the awarded Vendor’s Offer.
    [Show full text]
  • BIG-IP Access Policy Manager
    DATA SHEET BIG-IP Access Policy Manager WHAT'S INSIDE Simple, Secure, and Seamless Access to 2 Bridging Secure Any Application, Anywhere Application Access Applications are gateways to your critical and sensitive data. Simple, secure access to 17 BIG-IP APM Features your applications is paramount, but application access today is extremely complex. Apps 19 F5 BIG-IP Platforms can be hosted anywhere—in the public cloud, in a private cloud, on-premises, or in a data center. Ensuring users have secure, authenticated access anytime, anywhere, to only the 19 F5 Support Services applications they are authorized to access is now a significant challenge. There are different application access methods to deal with these complexities. There are also various sources for authorized user identity, as well as dealing with applications that require modern or more traditional authentication and authorization methods, single sign-on (SSO), federation, and more, in addition to ensuring a secure, simple user access experience to support and consider. With digital transformation touching every part of an enterprise today, native cloud and Software as a Service (SaaS) applications are now the enterprise application standard. Many organizations, though, find they’re unable or unwilling to migrate all their applications to the cloud. There may be mission-critical classic or custom applications that cannot or should not support migration to the public cloud or be easily replaced by a SaaS solution. Applications are being hosted in a variety of locations, with differing and many times disparate authentication and authorization methods that are unable to communicate with each other or work seamlessly across existing SSO or federated identity.
    [Show full text]
  • Oracle Mobile Security a Technical Overview
    Oracle Mobile Security A Technical Overview ORACLE WHITE PAPER | MAY 2015 Disclaimer The following is intended to outline our general product direction. It is intended for information purposes only, and may not be incorporated into any contract. It is not a commitment to deliver any material, code, or functionality, and should not be relied upon in making purchasing decisions. The development, release, and timing of any features or functionality described for Oracle’s products remains at the sole discretion of Oracle. ORACLE MOBILE SECURITY Table of Contents Disclaimer 1 Executive Overview 1 Oracle Mobile Security – Address Employee and Consumer use cases 2 Oracle Mobile Security Suite – Enterprise Mobility Management Solution 3 Assembling the Blocks – Core Solution Components 4 Oracle Mobile Security Container 5 Oracle Mobile Security App Containerization Tool 6 Oracle Mobile Security Access Server (MSAS) 6 Oracle Mobile Security Manager 7 Oracle Access Management Mobile and Social 7 OAuth Support 8 Extending Enterprise Security to Mobile Apps 9 Oracle Mobile and Social Client SDKs 16 Conclusion 17 Appendix: The New Mobile Computing Paradigm 18 Mobile App Development Models 18 Oracle Platform Security Services 19 REST 19 JSON 19 JSON Web Token 19 OpenID and OpendID Connect 19 OAuth 20 ORACLE MOBILE SECURITY SAML 22 WS-Security and SOAP 22 ORACLE MOBILE SECURITY Executive Overview Mobile computing gradually allows us to make the elusive “anytime, anywhere access” mantra a reality. More and more employees use their own mobile device in the workplace, a phenomenon known as “Bring Your Own Device” (BYOD), resulting in employees using the same device for personal and business purposes.
    [Show full text]
  • AUTHSCAN: Automatic Extraction of Web Authentication Protocols from Implementations∗
    AUTHSCAN: Automatic Extraction of Web Authentication Protocols from Implementations∗ Guangdong Bai?, Jike Lei?, Guozhu Meng?, Sai Sathyanarayan Venkatraman?, Prateek Saxena?, Jun Suny, Yang Liuz, and Jin Song Dong? ∗National University of Singapore ySingapore University of Technology and Design zNanyang Technological University Abstract than 250 million people reportedly use it every month as of 2011 [7]. Ideally, authentication protocols should be for- Ideally, security protocol implementations should be for- mally verified prior to their implementations. However, mally verified before they are deployed. However, this is majority of web sites do not follow this principle. Au- not true in practice. Numerous high-profile vulnerabilities thentication protocols have historically been hard to design have been found in web authentication protocol implemen- correctly and implementations have been found susceptible tations, especially in single-sign on (SSO) protocols imple- to logical flaws [31, 41]. Web authentication protocols are mentations recently. Much of the prior work on authentica- no exception—several of these implementations have been tion protocol verification has focused on theoretical foun- found insecure in post-deployment analysis [16, 29, 39, 42]. dations and building scalable verification tools for checking There are three key challenges in ensuring that appli- manually-crafted specifications [17, 18, 44]. cations authenticate and federate user identities securely. In this paper, we address a complementary prob- First, most prior protocol verification work has focused on lem of automatically extracting specifications from im- checking the high-level protocol specifications, not their plementations. We propose AUTHSCAN, an end-to-end implementations [13,21,44]. In practice, however, checking platform to automatically recover authentication protocol implementations is difficult due to lack of complete infor- specifications from their implementations.
    [Show full text]
  • Single Sign-On the Way It Should Be
    Single sign-on the way it should be 6 ways Citrix Workspace delivers seamless access to all apps while improving security and the user experience Contents Single sign-on (SSO) solutions .......................................................................3 Secure access to everything ...........................................................................5 Granular controls for SaaS apps and the web ...........................................6 Control over your user identity ......................................................................7 Security beyond user names and passwords ............................................8 Seamless integration with your existing environment ..........................9 Resolving issues faster with end-to-end visibility ............................... 10 ↑ Back← Pg. to 2 contents | Pg. 4 → Citrix.com 2 Single sign-on (SSO) solutions were designed to make life easier for employees and IT. They’re meant to reduce the cost of management and provide better security, all while delivering an improved user experience. However, many solutions fall short, covering only one type or a subset of application types. This forces you to implement several access solutions from different vendors to cover your entire application landscape — negating the productivity and user experience benefits you hoped for. The complexity this type of implementation creates also runs counter to the Zero Trust initiatives that many organizations are undertaking Citrix Workspace helps you unify all apps and data across your distributed IT architecture to provide single sign-on to all the applications and data people need to be productive. Working with your existing infrastructure, Citrix Access Control consolidates multiple remote access solutions, like traditional VPNs or SSO solutions, simplifying management for IT and providing unified access for employees. ↑ Back to contents ← Pg. 2 | Pg. 4 → 3 Citrix.com | e-book | Choosing a Single Sign-On Solution ↓ 6 benefits of the Citrix Workspace SSO solution ↑ ← Pg.
    [Show full text]
  • 3GPP Report Skeleton
    ATIS 3GPP SPECIFICATION ATIS.3GPP.33.924.V1010-2012 3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Identity management and 3GPP security interworking; Identity management and Generic Authentication Architecture (GAA) interworking (Release 10) Approved by WTSC Wireless Technologies and Systems Committee 3GPP ATIS is committed to providing leadership for, and the rapid development and promotion of, worldwide technical and operations standards for information, entertainment and communications technologies using a pragmatic, flexible and open approach. < http://www.atis.org/ > The text in this ATIS Specification is identical to 3GPP TR 33.924 V10.1.0 (2011-06). Please note that ATIS.3GPP.33.924.V1010-2012 was developed within the Third Generation Partnership Project (3GPP™) and may be further elaborated for the purposes of 3GPP™. The contents of ATIS.3GPP.33.924.V1010-2012 are subject to continuing work within the 3GPP™ and may change following formal 3GPP™ approval. Should the 3GPP™ modify the contents of ATIS.3GPP.33.924.V1010-2012 it will be re-released by the 3GPP™ with an identifying change of release date and an increase in version number. The user of this Specification is advised to check for the latest version of 3GPP TR 33.924 V10.1.0 (2011-06) at the following address: ftp://ftp.3gpp.org/Specs/ (sorted by release date) The user is further advised to verify the changes over the version listed as the approved basis for this Specification and to utilize discretion after identifying any changes. 3GPP Support Office 650 Route des Lucioles -- Sophia Antipolis Valbonne – France tel: +33 4 92 94 42 00 fax: +33 4 93 65 47 16 web: http://www.3gpp.org "3GPP" is a registered trademark of ETSI in France and other jurisdictions on behalf of the 3rd Generation Partnership Project Organizational Partners (ARIB, ATIS, CCSA, ETSI, TTA, TTC).
    [Show full text]
  • Discovering Concrete Attacks on Website Authorization by Formal Analysis Chetan Bansal, Karthikeyan Bhargavan, Antoine Delignat-Lavaud, Sergio Maffeis
    Discovering concrete attacks on website authorization by formal analysis Chetan Bansal, Karthikeyan Bhargavan, Antoine Delignat-Lavaud, Sergio Maffeis To cite this version: Chetan Bansal, Karthikeyan Bhargavan, Antoine Delignat-Lavaud, Sergio Maffeis. Discovering con- crete attacks on website authorization by formal analysis. Journal of Computer Security, IOS Press, 2014, 22 (4), pp.601-657. 10.3233/JCS-140503. hal-01102202 HAL Id: hal-01102202 https://hal.inria.fr/hal-01102202 Submitted on 15 Apr 2016 HAL is a multi-disciplinary open access L’archive ouverte pluridisciplinaire HAL, est archive for the deposit and dissemination of sci- destinée au dépôt et à la diffusion de documents entific research documents, whether they are pub- scientifiques de niveau recherche, publiés ou non, lished or not. The documents may come from émanant des établissements d’enseignement et de teaching and research institutions in France or recherche français ou étrangers, des laboratoires abroad, or from public or private research centers. publics ou privés. Discovering Concrete Attacks on Website Authorization by Formal Analysis1 Chetan BANSAL a, Karthikeyan BHARGAVAN b;2, Antoine DELIGNAT-LAVAUD b and Sergio MAFFEIS c a BITS Pilani-Goa b Inria Paris-Rocquencourt c Imperial College London Abstract. Social sign-on and social sharing are becoming an ever more popular feature of web applications. This success is largely due to the APIs and support of- fered by prominent social networks, such as Facebook, Twitter, and Google, on the basis of new open standards such as the OAuth 2.0 authorization protocol. A for- mal analysis of these protocols must account for malicious websites and common web application vulnerabilities, such as cross-site request forgery and open redi- rectors.
    [Show full text]
  • Recent Evolutions in the Oauth 2.0 and Openid Connect Landscape
    RECENT EVOLUTIONS IN THE OAUTH 2.0 AND OPENID CONNECT LANDSCAPE DR. PHILIPPE DE RYCK https://Pragmatic Web Security.com DR. PHILIPPE DE RYCK - Deep understanding of the web security landscape - Google Developer Expert (not employed by Google) - Course curator of the SecAppDev course (https://secappdev.org) Pragmatic Web Security High-quality security training for developers and managers Custom courses covering web security, API security, Angular security, … Consulting services on security, Oauth 2.0, OpenID Connect, … @PHILIPPEDERYCK @PhilippeDeRyck HTTPS://PRAGMATICWEBSECURITY.COM2 User authentication Read & write data @PhilippeDeRyck 3 User authentication Read & write data @PhilippeDeRyck 4 User authentication Read & write data @PhilippeDeRyck 5 OpenID Connect User authentication Read & write data OAuth 2.0 @PhilippeDeRyck 6 OpenID Connect User authentication Read & write data Read data OAuth 2.0 OAuth 2.0 @PhilippeDeRyck 7 Results in an identity token and access token User authentication Read & write data Read data Uses an access Uses an access token token @PhilippeDeRyck 8 OAUTH 2.0 AND OPENID CONNECT OpenID Connect provides user authentication OAuth 2.0 allows a client to access resources on behalf of the user Modern applications use a combination of both protocols @PhilippeDeRyck 9 THE OIDC HYBRID FLOW 5 Request client authorization 3 Authenticate yourself 4 Login credentials 6 Authorize client Authorization code 10 11 Access token / refresh token Redirect for with client credentials authentication 2 Redirect with 7 authorization
    [Show full text]
  • B-CRAM: a Byzantine-Fault-Tolerant Challenge-Response
    1 B-CRAM: A Byzantine-Fault-Tolerant Challenge-Response Authentication Mechanism Akshay Agrawal, Robert Gasparyan, Jongho Shin [email protected], [email protected], [email protected] Abstract—B-CRAM is an authentication protocol that the TTP is a single point of failure – if it were to fail, all enables applications to consult a distributed trusted third- authentication would come to a halt. We can alleviate this party (TTP) in order to validate end-user identities. shortcoming by distributing the KDC and maintaining Short for Byzantine-Fault-Tolerant Challenge-Response its state with a replication algorithm; indeed WebAuth, Authentication Mechanism, B-CRAM’s novelty lies in its Stanford’s own authentication system, does just that [16]. resilience to node failures, malicious or otherwise. The TTP layer, which stores end-user credentials, implements While replication increases redundancy, it does little the BFT2F replication algorithm. In particular, given a to guard against byzantine failures. In the context of TTP distributed 3f + 1 ways, our system guarantees both authentication, fault-tolerance to malicious attacks on safety and liveness when no more than f nodes fail; the TTPs is particularly important – a compromised moreover, we bound the space of possible attacks when no system could falsely authenticate imposters. None of the more than 2f nodes fail. B-CRAM prevents adversaries WebAuth, OpenID, or OAuth protocols require that their from obtaining sensitive end-user information, no matter TTPs survive byzantine faults [16], [8], [6]. Even if the how many TTPs they compromise: Unlike many other protocols did replicate their data using PBFT [2], security authentication protocols, B-CRAM ensures that TTPs do vulnerabilities would remain.
    [Show full text]
  • User Account and Authentication Service
    User Account and Authentication Service © 2020 General Electric Company Contents UAA Service Overview 1 About the User Account and Authentication Security Service 1 UAA Deployment Architecture 1 Understanding UAA and OAuth2 Access Token Flows 4 Obtaining Tokens Using Authorization Code Grant 4 Obtaining Tokens Using Implicit Grant 5 Obtaining Tokens Using Resource Owner Password Credentials Grant 7 Obtaining Tokens Using Client Credentials Grant 7 Understanding UAA and ID Tokens 9 Using UAA to Obtain ID Tokens 9 Get Started With the UAA Service 10 UAA Security Service Setup 10 Creating a UAA Service Instance 10 Binding an Application to the UAA Instance 13 Unbinding the UAA Instance From Your Application 15 Deleting a UAA Instance 15 Configuring the UAA Service Instance 16 About UAA Dashboard 16 Managing Clients 17 Managing Users 24 Creating Password Policies 27 Managing Identity Providers 28 OIDC Federated Authentication 37 Managing Tokens 68 Multifactor Authentication 71 Using UAA for Application Login or Logout Window 76 Using UAA to Set Up Application Login or Logout 76 Customizing the UAA Login Window for Your Application 76 Troubleshooting UAA Service 78 Troubleshooting UAA Service 78 UAA Release Notes 81 ii User Account and Authentication Service UAA Release Notes 81 iii Copyright GE Digital © 2020 General Electric Company. GE, the GE Monogram, and Predix are either registered trademarks or trademarks of General Electric Company. All other trademarks are the property of their respective owners. This document may contain Confidential/Proprietary information of General Electric Company and/or its suppliers or vendors. Distribution or reproduction is prohibited without permission. THIS DOCUMENT AND ITS CONTENTS ARE PROVIDED "AS IS," WITH NO REPRESENTATION OR WARRANTIES OF ANY KIND, WHETHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO WARRANTIES OF DESIGN, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
    [Show full text]