Objectives:
Learn how to deploy a full working APP on top of SOAJS (Pet Store)
Learn how to build UI Modules and deploy them in the /wiki/spaces/BL/pages/61906563 pillar of SOAJS DSBRD
Learn how to deploy a custom UI Frontend Interface for your APP with SOAJS
- Deploy and use oAuth to login
- Deploy and use URAC for member management and 3rd party integration (Facebook, Google+, Twitter)
1- Install SOAJS
Anchor | ||||
---|---|---|---|---|
|
Start by installing and deploying SOAJS as a local Cloud; Click Here and you will be redirected to the SOAJS Installer Space where you can find the installation instructions.
For this demo, we will be using Local Cloud Deployment on top of Docker and we will provide our custom UI modules for the pet store.
Once you reach step Deployment Information in the installer, you need to set the following information under Repositories to add the UI Modules:
Field Name | Field Value | Description |
---|---|---|
Provider | Github | Which Git Provider to integrate with |
Git Domain | github.com | The domain of the Git Provider |
Git Owner | SOAJS-Demos | The owner of the repository |
Git Repository | soajs.petstore.ui | The repository that contains the UI Modules |
Git Branch | master | Which branch to use |
Git Path | /uiModules | The location where the UI Modules are stored in the repository |
Warning |
---|
Use the installer to install SOAJS, but do not login yet, this demo requires you to import some settings then it tell you when it is time to login. |
2- Install Demo
Anchor | ||||
---|---|---|---|---|
|
Once you finished the installation of SOAJS with the custom UI modules, clone the full demo configuration repository to import some sample data before you proceed.
Note | ||
---|---|---|
| ||
Make sure you have Xcode (or at least Xcode cli) installed to be able to use the "git" command from the terminal! |
Code Block | ||||||
---|---|---|---|---|---|---|
| ||||||
# Create a directory to clone the repo > mkdir -p /opt/soajs/node_modules # Go to directory > cd /opt/soajs/node_modules # Clone configuration repo from Github > git clone git@github.com:SOAJS-Demos/soajs.petstore.config # install dependencies for repository > cd soajs.petstore.config > npm install # Import the configuration > cd soajs.petstore.config/import/ # node . -h <mongo service host> -p <mongo port> > node . -h dashboard-soajsdata -p 32017 |
Note | |||||
---|---|---|---|---|---|
| |||||
|
From here on, we will use the SOAJS Dashboard UI to resume all the work. Log in to the SOAJS Dashboard to proceed.
Note |
---|
Go to the Deploy pillar → High Availability then Clouds & Deployments then Load provision and Reload registry of the dashboard container. Then Logout and Log back in, now the dashboard will load your new ACL permissions that includes the imported configuration for the pet store demo. |
3 - Deploy Demo
Anchor | ||||
---|---|---|---|---|
|
3.1 Activate Demo Repo
Head over to the Develop pillar → Repositories to active the demo microservice.
In Repositories, we find the default SOAJS account activated and it contains a list of repositories we can turn on and off.
The Pet Store demo is in another organization (SOAJS Demos); this means we need to create an account for it and activate it.
Field Name | Field Value | Description |
---|---|---|
Account Provider | Github | Which Git Provider to integrate with |
Account Domain | github.com | The domain of the Git Provider |
Account Type | Organization - Public | The type of Account |
Account Label | SOAJS Demos | Enter a name for this account (anything you want) |
Username | SOAJS-Demos | The username of the Account to use; in this case SOAJS-Demos is the username for the SOAJS Demos Organization that contains the demo repositories and code |
The list contains multiple repositories but for the Pet Store Demo we need to activate only 2:
Repository Name | Branch | Description |
---|---|---|
soajs.pestore.petstore | master | Contains petstore microservice ( inventory ). |
soajs.petstore.order | master | Contains orders microservice (Shopping Cart systems). |
3.2 Deploy Environment and Microservice
Our import script already imported the configuration we need to get things going.
Let's deploy the DEV environment which will contain:
Systems | Description |
---|---|
Nginx | Web Server that listens on port 81.
|
Controller | SOAJS microservice that listens on port 4000 and analysis arriving requests to check the security and determine which microservice should handle these requests. Read More |
oAuth | SOAJS microservice that provides an out of the box implementation of oAuth 2.0, used to allow members to login and create access tokens for them. Read More |
URAC | SOAJS microservice that offers user registration and access control to all members along with the ability to login via 3rd parties ( facebook - twiiter - google). Read More |
Pet Store | Custom microservice built using the SOAJS Swagger Editor and contains all the APIs to manage a pet store inventory. |
Orders | Custom microservice built using the SOAJS Swagger Editor and contains all the APIs that enable members to fill, checkout shopping carts & create orders while at the same time offers admin the ability to process these orders. |
Step 1: Deploy Environment
Go to Deploy pillar → High Availabilitypillar → Clouds & Deployments
Select DEV from the drop down menu in the top left corner.
Press Deploy Environment.
Fill in the deploy environment form like the following pictures for both Nginx and Controller sections.
Once deployed, changed the environment to Dashboard in the top left sidebar, locate the controller and from it's Service Operation Menu, select Reload Registry.
This will instruct the dashboard controller that a new controller in a new environment is now present.
Step 2: Deploy Service
Change the environment back to Dev in the top left sidebar and click on Deploy New Service and fill the form like the following pictures:
Deploy the following services using their latest versions: urac - oauth - petstore & orders
Once the environment is deployed, update your hosts file and add the below entry:
Code Block | ||
---|---|---|
| ||
127.0.0.1 petstore.soajs.org 127.0.0.1 petstore-api.soajs.org |
4- Use the Demo
Anchor | ||||
---|---|---|---|---|
|
4.1 Test the services
Swagger Simulator : rich UI simulator that provides REST API documentation and the ability to interact with them.
SOAJS Dashboard UI is equipped with Swagger Engine and Simulator by default.
- Go to the dashboard → Develop → API Catalog:
- Click on Swagger logo that appears if the microservice is created using Swagger Editor and a new tab will open
- Choose your environment where you deployed your microservice
- Use the simulator to make API calls to your microservice
4.2 Explore the widget
In your browser open http://petstore.soajs.org:81 and the pet store frontend UI interface will open; Enjoy the Shopping
4.3 Manage the pet store
Go to the dashboard, Operate pillar, where you will find two UI Modules : Pet Store and Order Management.
4.3.1 Pet Store
In the Pet Store module, you will be able to manage your pets inventory for the store.
4.3.2 Order Management
In the Order Management module, you will be able to list all orders and fulfill or reject them.
5 - Conclusion
To sum things up, this demo is an excellent example on how to deploy a full APP on top of SOAJS.
We showed you how to create environments and deploy microservices in them using catalog recipes and while doing that, we introduced couple of ready made services by SOAJS: Controller - oAuth - URAC.
Ready made services do not require any development effort, simply deploy and use them.
In addition to microservices, we showed you how to deploy and operate on two types of UI components: UI Modules & Frontend UI Interfaces.
Dive in deeper and learn more about how the full demo is constructed in the sub pages where we tackle every section by itself and explain it in depth.