Purpose:
The purpose of this blog post is to demonstrate how can we filter voucher transactions by cost center financial dimension for each user and the technical challenges behind it.Product:
Dynamics 365 Finance and OperationsProblem:
Business requirement is that users should only view voucher transactions for their cost centers. Although we can define the owner for a cost center financial dimension but we cannot assign cost centers for each user in the application. Further, another business requirement is a user can be linked to as many as 500 cost centers!Solution:
I designed a solution to achieve this business requirement by adding new table MAUserOperatingUnitTable to store user-cost center relationship.data:image/s3,"s3://crabby-images/85491/854916c9b352d3ec92acfb772b0d83291ce51d52" alt=""
Stack trace: Binding operation failed to allocate buffer space Object server azure
The second option is go for an exists join query. The challenge with an exists join query is that if you see DimensionAttributeValueCombination table in AOT, it stores financial dimensions for voucher transactions in DisplayValue field which is a combination of financial dimensions and the main account as per the account structure and advanced rule structure configurations in the general ledger.data:image/s3,"s3://crabby-images/2a66b/2a66b2f30e76959ddaeaa322cbc5ee0aa866086c" alt=""
data:image/s3,"s3://crabby-images/db34f/db34f90994b9c283d861d1355b5742daa1ec6ea1" alt=""
data:image/s3,"s3://crabby-images/6f172/6f17256a94d32847cb4a6a8aad45bf0af5ad1892" alt=""
/// <summary> /// This method adds a range to the form datasource to /// filter voucher transactions per user cost center. /// Developed by Muhammad Anas Khan. /// </summary> /// <param name="sender">Form datasource</param> /// <param name="e">Form datasource event args</param> /// <remarks> /// Developed by Muhammad Anas Khan. /// </remarks> [FormDataSourceEventHandler(formDataSourceStr(LedgerTransVoucher, GeneralJournalEntry), FormDataSourceEventType::QueryExecuting)] public static void GeneralJournalEntry_OnQueryExecuting(FormDataSource sender, FormDataSourceEventArgs e) { const Name dimensionCostCenter = "COSTCENTER"; FieldId costCenterValueFieldId; FormRun formRun = sender.formRun(); FormDataSource dimensionAttributeValueCombination_ds = formRun.dataSource(formDataSourceStr(LedgerTransVoucher, DimensionAttributeValueCombination)); QueryBuildRange qbr; QueryBuildDataSource qbds; str qbrValue; costCenterValueFieldId = DimensionAttributeValueCombination::getDimensionValueFieldId(dimensionCostCenter); qbds = sender.query().dataSourceName(dimensionAttributeValueCombination_ds.name()).addDataSource(tableNum(MAUserOperatingUnitTable)); qbds.joinMode(JoinMode::ExistsJoin); qbds.addLink(fieldNum(MAUserOperatingUnitTable, OMOperatingUnitNumber), costCenterValueFieldId); qbr = qbds.addRange(fieldNum(MAUserOperatingUnitTable, User)); qbr.value(curUserId()); }
Comments
Post a Comment