UX source model auto updater
Author: Abhishek Roy is a Certified Solution Architect , Sr. Platform Architect at Equinix and a member of their Anaplan CoE team.
This article primarily covers a less explored API functionality that the Anaplan UX is based on and adds an element of automation and easy configuration to the otherwise manual time-taking and error-prone activity of updating source models for UX Apps.
Problem statement
We are already aware of the fact that Anaplan UX pages are pointed to models that help them display the data / visualizations set up by the page builders.
In scenarios where a UX application needs to be duplicated and pointed to another model
(generally, a deployed variant / copy of the standard model) there are typically only two ways to achieve the same.
- Navigate to the Page settings and change the source model definition.
- Open Manage Models from the App default landing page and configure on page-by-page basis.
With both of the options comes the possibility of missing out repointing a couple or more pages and additionally it becomes very cumbersome for apps that have evolved over time and have close to 50+ pages pointed to a variety of models (e.g. Datahub, Spoke 1, Spoke 2 etc).
This solution has been created to address the automation and reduce the error possibility of this activity that most teams face as of today.
Solution overview
Anaplan Springboard API will be leveraged as part of automating the page updates for UX.
This is an API functionality that enables us to directly update parameters of the UX pages like the modelID & the workspaceID it is pointed to.
Sample API cURL’s for Springboard API
Here are few of the sample API cURL that involve using springboard functionality.
- API GET request to get a list of all the Pages and their details associated to an App
curl --location 'https://us1a.app.anaplan.com/a/springboard-definition-service/apps/{AppID}
The AppID can be easily retrieved from the URL while we are on the default landing page of any UX App. Response: The Page Identifier PageID can be retrieved from this request. - API GET request to get the Model details of any page using the PageID.
curl --location 'https://us1a.app.anaplan.com/a/springboard-definition-service/pagemodels/PageID
\--header 'Authorization: ••••••' \
The PageID can be obtained via API request as mentioned in step 1 or can also be taken from the URL when on the desired page. Response: - API PUT request to point the Pages to any intended Model
curl --location --request PUT 'https://us1a.app.anaplan.com/a/springboard-definition-service/pagemodels/{PageID}'\
--header 'Content-Type: application/json'\
--header 'Authorization: ••••••'
--data '{
"pageModels": [
{
"modelId": "ModelID",
"workspaceId": "WorkspaceID"
}],
"isAlmEnabled": true
}'
Response:
As showcased in the steps mentioned above — while it’s possible to get the redirection done via the API calls — this is on a page-by-page basis and will need the parameters like PageID, ModelID, WorkspaceID, etc. to be dynamic as these are identifiers that change whenever we are copying the models or Applications. Additionally, the details of the target model need to be supplied to the API for completing the execution of this request.
This solution takes the dynamic nature into consideration and has the API calls being generated with variables declared on the fly and bundles a looping and referential nature to ensure the same process is carried over for all the pages in the mentioned App that needs to be redirected to the target model.
Due to the size of this guide, we've created a demo video and a downloadable PDF with step-by-step instructions.
Please download the guide here:
And the video can be seen here:
Questions? Leave a comment!
…..Acknowledgements
I would like to take this opportunity to thank few key contributors who have been instrumental in ideating, implementing, and documenting this solution:
- Equinix Center of Excellence members: Sandeep Veeturi (@veeturi.sandeep), Manu Mathur (@manu.mathur), and Brett Harn (@brettharn1115).
- Anaplan: Rob Marshall (@rob_marshall) and Jon Ferneau (@JonFerneau) for their valuable time and insightful feedback throughout the solutioning. And Ginger Anderson (@GingerAnderson) for her constant support and helping us get this article to the finish line!
Comments
-
I had a feeling @rob_marshall and @JonFerneau might be involved. Great work @abroy - I suspect after about 20-30 pages this solution is a more reliable process. So tedious to this manually.
3 -
Thanks @kevin.cho for introducing me to the springboard API Capability - here is the link to the new UX Idea thread that kind of made us curios to explore and work towards automating it with our available tech stack.
New UX Idea - Apply one more model source to all pages of the app at once — Anaplan Community
0 -
Interesting Read!!
1 -
Thanks @abroy. This is great idea.
0 -
@abroy @rob_marshall @JonFerneau As awesome functionality the UX API gives it is quite difficult to work with due to it being undocumented. Is there any plans on the UX API to be documented?
0 -
@pyrypeura not that I know of.
0 -
Thanks @abroy, this is great work!
Does your solution allow the addition of multiple source models to a page?
1 -
Thanks @alexander.wolman
- you just need to ensure you pass the ModelID & WorkspaceID details for both the models in the JSON Payload. That way - the existing connection to the source will be retained and the Page will auto convert to a multimodel setup with the target Model showing as one of the source models too.
You can check the sample JSON body in this Anaplan community thread that we had initially run into and explored.
This idea can be easily updated to cater to multi-model setup as well. Our V1 was built to cater Separate Env - Separate App setup & that is why you see just single model migration being done but there are a couple of ideas that are already in pipeline for V2 🙂0 -
@alexander.wolman as an example your payload would look more like, where you have two model objects in the pageModels key.
{ …, pageModels: [{'modelId': 'abc', 'workspaceId': 'def'}, {'modelId': 'xyz', 'workspaceId': 'def'}], … }
isAlmEnabled also needs to be set to True for this.
0 -
Thanks very much @abroy and @kevin.cho! This seems like an easy adjustment. Appreciate all the work you have done here.
0