This SMART on FHIR application demos the use of online EMR sandboxes along with Zynx API. This is a Java Spring Boot Server / Angular Web App demo application. It uses Node/Yarn/Web Pack for building the application.
Please visit http://developer.zynx.com to request an API Key.
Go to https://sandbox.smarthealthit.org/ to registery your localhost demo application. Login to https://code.cerner.com/developer/smart-on-fhir/apps Click "+ Register Manually" on top
App Registration
App Type : Public Client
App Name : Zynx Api Demo 9000
App Launch URI : http://localhost:9000/#/smart_fhir
App Redirect URIs : http://localhost:9000/#/smart_fhir
Click Save
Configs for Smarthealth
smartFhirTokenServer: 'https://sb-auth.smarthealthit.org/token',
smartFhirAuthServer: 'https://sb-auth.smarthealthit.org/authorize',
smartFhirApiUrl: 'https://sb-fhir-dstu2.smarthealthit.org/smartdstu2/data/',
smartFhirKey: 'client id obtained from registered app',
smartFhirRedirectUri: 'http://localhost:9000/#/smart_fhir'
Go to https://code.cerner.com/developer/smart-on-fhir/ to register your localhost demo application.
Login to https://code.cerner.com/developer/smart-on-fhir/apps Click "+ New App" on top right corner App Registration
App Name : Zynx Api Demo 9000
SMART Launch URI : http://localhost:9000/#/smart_fhir
Redirect URI : http://localhost:9000/#/smart_fhir
App Type : Provider
FHIR Spec (The FHIR version your SMART App will consume) : dstu2
Authorized (Does your SMART App require OAuth2?) : Yes
Scopes : Standard Scopes
launch
profile
openid
online_access
User Scopes Patient Scopes
Condition * read Condition * read
Patient * read Patient * read
Person * read Person * read
When you click Save, the next page provides the client id Configs for Cerner
smartFhirTokenServer: 'https://authorization.sandboxcerner.com/tenants/0b8a0111-e8e6-4c26-a91c-5069cbc6b1ca/protocols/oauth2/profiles/smart-v1/token',
smartFhirAuthServer: 'https://authorization.sandboxcerner.com/tenants/0b8a0111-e8e6-4c26-a91c-5069cbc6b1ca/protocols/oauth2/profiles/smart-v1/personas/provider/authorize',
smartFhirApiUrl: 'https://fhir-ehr.sandboxcerner.com/dstu2/0b8a0111-e8e6-4c26-a91c-5069cbc6b1ca/',
smartFhirKey: 'client id obtained from registered app',
smartFhirRedirectUri: 'http://localhost:9000/#/smart_fhir'
The file "src/main/webapp/app/config.ts" needs to be configured as follows:
export var config = {
smartFhirTokenServer: '< provided by sandbox EMR >',
smartFhirAuthServer: '< provided by sandbox EMR >',
smartFhirApiUrl: '< provided by sandbox EMRi>',
smartFhirKey: '< retreived from the specific sandbox EMR being used',
smartFhirRedirectUri: 'http://localhost:9000/#/smart_fhir'
}
export var zynx_config = {
aPIKey :'< This is the Zynx API Key you request, see http://developer.zynx.com >',
aPIURL :'< See the [getting started documentation](https://github.com/zynxhealth/documentation/blob/master/README.md), specifically the Zynx Health API Service Base URL. >'
}
Before you can build this project, you must install and configure the following dependencies on your machine:
- Node.js: We use Node to run a development web server and build the project. Depending on your system, you can install Node either from source or as a pre-packaged bundle.
- Yarn: We use Yarn to manage Node dependencies. Depending on your system, you can install Yarn either from source or as a pre-packaged bundle.
After installing Node, you should be able to run the following command to install development tools. You will only need to run this command when dependencies change in package.json.
yarn install
We use yarn scripts and Webpack as our build system.
Run the following commands in two separate terminals to create a blissful development experience where your browser auto-refreshes when files change on your hard drive.
./mvnw
yarn start
Yarn is also used to manage CSS and JavaScript dependencies used in this application. You can upgrade dependencies by
specifying a newer version in package.json. You can also run yarn update
and yarn install
to manage dependencies.
Add the help
flag on any command to see how you can use it. For example, yarn help update
.
The yarn run
command will list all of the scripts available to run for this project.
You can also use Angular CLI to generate some custom client code.
For example, the following command:
ng generate component my-component
will generate few files:
create src/main/webapp/app/my-component/my-component.component.html
create src/main/webapp/app/my-component/my-component.component.ts
update src/main/webapp/app/app.module.ts
This application was generated using JHipster 4.6.1, you can find documentation and help at https://jhipster.github.io/documentation-archive/v4.6.1.