A demo app implemented in Firebase (with real-time database) and Vanilla JS on FE showcasing Appmixer embedding. The demo app is based on the original Firebase Database demo from https://github.com/firebase/quickstart-js/tree/master/database with only a few modifications that embed Appmixer Integrations marketplace and Flow Manager (together with Designer). Also, a REST API was implemented using Firebase Cloud Functions to be able to build Appmixer connector for the demo app to be used in Appmixer automations and integrations.
The app shows the 2 most common use cases for Appmixer embedding:
Embed a marketplace of prebuilt integration templates. End user can select a template, fill in the required fields and run an integration.
Embed the full featured workflow designer UI allowing the end user to build custom workflow automations.
index.html
: Application HTML.scripts/main.js
: Application front-end JavaScript, containging the entire application FE code.functions/index.js
: REST API. Necessary for Appmixer connector.appmixer-components/
: Appmixer components working against the demo app REST API (defined infunctions/index.js
). See Appmixer Component Basic Structure and Example Component for more details.
- Create your project on the Firebase Console. Make sure you have at least the Blaze (pay-as-you-go) plan (free but credit card required), otherwise the Firebase Cloud Functions could not be deployed.
- Enable the Google sign-in provider in the Authentication > SIGN-IN METHOD tab.
- You must have the Firebase CLI installed. If you don't have it install it with
npm install -g firebase-tools
and then configure it withfirebase login
. - On the command line run
firebase use --add
and select the Firebase project you have created. - Replace the URLs to the Appmixer APIs with your own Appmixer tenant URLs. Replace
https://my.qa.appmixer.com/appmixer/appmixer.js
withhttps://my.[YOUR_TENANT].appmixer.cloud/appmixer/appmixer.js
inindex.html
andhttps://api.qa.appmixer.com
withhttps://api.[YOUR_TENANT].appmixer.cloud
inscripts/main.js
file. - On the command line run
firebase deploy
using the Firebase CLI tool to deploy your Firebase app to the cloud. - You must have the Appmixer CLI installed. If you don't have it install it with
npm install -g appmixer
. Then set your Appmixer engine base URL withappmixer url https://api.[YOUR_TENANT].appmixer.cloud
and login withappmixer login YOUR_ADMIN_USERNAME
. - Publish Appmixer components with
appmixer pack appmixer-components/
followed byappmixer publish appmixer.demofirebase.zip
. - Configure the
baseUrl
(of this demo REST API endpoint) in your Appmixer Backoffice (https://backoffice.[YOUR_TENANT].appmixer.cloud
). Go to Services > Add and add a new service with IDappmixer:demofirebase
. Then create a keybaseUrl
and set it to the Firebase Cloud Functions endpoint (usuallyhttps://us-central1-[FIREBASE_PROJECT].cloudfunctions.net
). This base URL is used throughout the Appmixer components (appmixer-components/
) to locate the API endpoints of this demo app in your own deployment.
- Appmixer components are published in a module called "Firebase demo". You can find it under "Applications" in the Connectors section of the designer when designing integration templates:
- The Appmixer virtual users in this app are created with the
appmixer-demo-firebase-vanilla.com
domain. The full format of the Appmixer virtual user usernames is[FIREBASE_UUID]@appmixer-demo-firebase-vanilla.com
. You can see it in your Backoffice interface under Users:
- You can change the Appmixer virtual user's domain by changing the
APPMIXER_USER_DOMAIN
variable inscripts/main.js
file. - You can find an example of an integration template that sends a Slack message for new posts created (that you can create in the Appmixer Studio) below. Note that before you can start using Slack connector in your Appmixer tenant, you first need to configure OAuth 2 app with Slack. Follow the tutorial from the Appmixer docs: https://docs.appmixer.com/appmixer/app-registration/slack.
Don't forget to define the Wizard and publish your integration template in the Wizard builder:
Define all the sections for the final Wizard, starting with the Slack account that the user needs to connect:
Continue with adding a field that lets the user select their Slack channel:
And finally add a filed to let the user customize the Slack message (note that you can define the default value in the Designer):
Once you Publish this integration template, your end users should see a new tile in the "All Integrations" section of their embedded integration marketplace. Once they click to configure their integration, they should see the Wizard that you just defined for them, with all the fields as configured in the Wizard builder:
Original Firebase database demo (https://github.com/firebase/quickstart-js/tree/master/database) Copyright:
© Google, 2016. Licensed under an Apache-2 license.
Modifications copyright (C) 2023 client IO s.r.o.