IntroductionIntroduction
Excerpt |
---|
This sample will |
demonstrate how to request authorization for an app, using the SMART on FHIR JavaScript Client. |
SMART on FHIR Authorization
Request Authorization
In order to receive the current user, you must request the openid and profile scopes.The fhir-client.js JavaScript library from SMART contains methods to help you handle the SMART on FHIR Authorization workflow with in your app. Include fhir-client.js in a file which will be loaded when your app is launched. In this snippet, we are showing an example of initiating SMART on FHIR authorization within HTML code. To request authorization, call the FHIR.oauth2.authorize method:
Code Block | ||||
---|---|---|---|---|
| ||||
<html> <head> <script src="fhir-client.js"></script> </head> <body> <script type="text/javascript"> FHIR.oauth2.authorize({ client_id: "my_client_id", redirect_uri: "https://mydomain.com/app/index.html", scope: "patient/*.read" openid profile" }); </script> ... </body> </html> |
Authorization Success
After successful authorization, retrieve the resulting SMART FHIR Client. The current user's fully qualified FHIR URL is on the FHIR client at userId.
Ex: https://sandbox.hspconsortium.org/dstu2/open-hspc-reference-api/data/Practitioner/COREPRACTITIONER1
...
language | js |
---|---|
title | Authorization Success |
...
Include fhir-client.js and jquery in a file which will be redirected to after successful authorization. This snippet is in an HTML file. Call the FHIR.oauth2.ready method to complete the authorization process and retrieve an access token for interacting with the FHIR server. The resulting SMART FHIR Client (named fhirClient in this example) contains the access token and uses it during interactions with the FHIR server.
Code Block | ||||
---|---|---|---|---|
| ||||
<html> <head> <script src="fhir-client.js"></script> <script src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js"></script> </head> <body> <script type="text/javascript"> FHIR.oauth2.ready(function(fhirClient){ currentUserFhirUrl = fhirClient.userId;...use fhirClient to interact with the FHIR server... }); </script> </body> </html> |