Forum Discussion
Christian's code to check a manual input before save and/or calculate is a good example of using the Save Data Event Handler. The Save Data Event Handler is an Event Handler that runs in order to track all save events in an application. The Save Data Event Handler does not necessarily have Api's ( BRApi's can be used ) but does use Args object references to various objects such as data cells. Since the Save Data Event Handler runs against any of the save events, it is important to understand what happens with the Save Data Event Handler when put under the bright lights of a production environment. Implementations come in all shapes and sizes and one size does not fit all. This is true for the Save Data Event Handler as well. Here are some things to consider when deciding to leverage Christian's code to begin your Save Data Event Handler journey.
1. Using a Single Account - In this example, Christian is using a single account to demonstrate the concept of checking the amount of a data cell to determine whether the save should happen or not. This absolutely works and works well. Here is something to think about: When you think about this single account, this single account is not the only dimension in the data cell. There are 19 Dimensions that make up a single data cell. For an example, you may have a Cube Model that contains 100 UD1's, 200 UD2's, and 10,000 UD3's which make up a valid data cell intersection combination with that single account. This is 200 million possible data cell combinations for this single account. If a Form was built with UD1, UD2, and UD3 as rows, and the single account in the Cube View POV (all available for manual input) each one of these data cell amounts would need to be evaluated to determine if they should be saved. This is one user that is cycling through 200 million data cells before completing a save command. Now imagine that you have 100 users simultaneously working within a variety of different Forms doing the same thing. Suggestion - Be aware on how the Forms are built and how many data cells that the Save Event Handler will have to process before it saves. Testing this process in a production type environment as others are interacting is important to understand the overall impact on the system. Again, no 1 implementation and environment is alike so parallel testing is important.
2. Limiting Rule Execution By Forms - In this example, Christian is showing how to execute the logic based on the Forms Origin. The logic will only execute on the data cells with Forms Origin
If args.NewDataCell.DataCellPK.OriginId = DimConstants.Forms
This allows a level of assurance that this logic will only run when a user is processing a Form using the Forms Origin. So when the user clicks on Save in a Form, it will execute the logic and evaluate the data cells to determine to save the data or not. This will happen for any Form in the application that is processed and the user clicks Save whether the Form was intended to use this logic or not. Therefore, it would be prudent to limit the Forms that you would like the Save Event Handler to execute on. Dim objBRApiForms As BRApiForms = BRApi.Forms.Metadata.GetForm.Form.Name.Equals("NameOfForm"). This is something to consider when introducing the Save Data Event Handler. Should it apply to all Forms or is it specific to a Form?
3. More Than 1 Account for Manual Input and Looping on More Than 1 Account - This certainly can be done. However, consider what was explained under item 1 above. There will be a multiplication factor depending on how many accounts for manual input and data cells evaluated. Another point to consider when building out Forms and how many data cells are available within the Form.
4. Using BRApi's to Cross Engines - BRApi's are very useful to cross OneStream Processing Engines. As common practice, it is best to use Api's that are provided within each Engine. As mentioned before, the Save Data Event Handler does not have Api's but does contain Args object references and BRApi's. In Christian's example, since there is no Api to use, we are using the BRApi to cross into the Finance Engine to get the Account Id. This is certainly needed in order to process this logic. The consideration here is how often is an user saving a Form and executing the logic to cross into the Finance Engine. Is it 1 person or 100 people simultaneously executing a Save and impacting the General servers? Something to monitor when testing.
Hope these considerations help when using this Business Rule. And remember TEST, TEST, TEST functionality and user interactions under production type environment to ensure a pleasant user experience. Christian is providing you with the power. It is up to you on how to use it. Consider these 4 items when implementing in a production environment.
Hi Tony,
Would you also use it to run "Calc on save"? Relevant for Planning forms.
I guess you could trigger BRApi.Utilities.ExecuteDataMgmtSequence
Thanks
Liliya
Hello LiliyaBarabash
I'm not exactly sure what you are asking so if I misinterpret with my response, let me know.
Since Planning Forms often are developed as Forms as Dashboard, the Button Dashboard Component is used to execute a Calculate for the Form. The Button Dashboard Component also has a Save Action object that can put controls on the data saving process prior to committing data to the Data Record tables. I would prefer to use this method when possible vs. using the SaveDataEventHandler.
Hi Toni,
You interpret my question correctly. I understand that you give the preference to the Dashboard Button. The only disadvantage of it, is that it forces to use Dashboards in cases where is could be just a cube view. Any performance concerns if using the save SaveDataEventHandler? If crafted carefully, one can ensure that the relevant calculation runs on the relevant cube view.
Thanks
Liliya
Related Content
- 11 months ago
- 4 months ago
- 7 months ago
- 10 months ago