簡體   English   中英

mule 3 XPR 到 dataweave 2.0 遷移

[英]mule 3 XPR to dataweave 2.0 migration

就我而言,我正在進行從 Mule 3 到 Mule 4 的遷移。

在 Mule 4 中,不支持 xpr 文件進行 xml 轉換。

所以我將 xpr 文件轉換為 dataweave 2.0。

大部分邏輯已解決,但我不知道如何更新 DTOSteps 值和 DTOCoverage。@FullTermAmt = fullTermAmts。

騾子 3 XPR: https://github.com/Manikandan99/XPR_conversion/blob/master/responseCISGExposure.xpr

我的 Mule 4 應用程序: https://github.com/Manikandan99/XPR_conversion/tree/master/xpr_validation

輸入 xml 請求: https://github.com/Manikandan99/XPR_conversion/blob/master/xml_request.xml

預期 output 883812976388 響應: https://github.com/Manikandan99/XPR_conversion/blob/master/responseCISGExposure.xpr

我已經在 Mule 4 應用程序中定義了所有變量。

Stackoverflow 不允許我發布多行代碼,因此我提供了 github 鏈接。 請go通過它。

請幫我解決。

我根據 xpr 文件邏輯更新了 mule 4 中的數據編織代碼。

對於自動增量,我在 dataweave 2.0 中使用了 AtomicInteger 和內置的 incrementAndGet() function。

我向我的 pom.xml 添加了一個依賴項:

<dependency>
<groupId>org.mule.module</groupId>
<artifactId>mule-java-module</artifactId>
<version>1.2.5</version>
<classifier>mule-plugin</classifier>
</dependency>

我的數據編織 2.0 代碼:

%dw 2.0
import java!java::util::concurrent::atomic::AtomicInteger
var processFlag = 0
var stepOrder = 1
var subStepOrder = 1
var subSubStepOrder = 1
var multiChar = "X"
var coverageCd = "LIAB"
var fullTermAmts = vars.CISGOutput.Premium.FinalLiabPrem.Exposure.LIAB
var startingValue = AtomicInteger::new(0)
var instartingValue = AtomicInteger::new(0)
output application/xml
fun soutincrement() = Java::invoke('java.util.concurrent.atomic.AtomicInteger', 'incrementAndGet()', startingValue, {})
fun sinincrement() = Java::invoke('java.util.concurrent.atomic.AtomicInteger', 'incrementAndGet()', instartingValue, {})
fun transformSteps(x, index)=
    x filterObject ($$ as String != "DTOSteps") ++
    {
                    DTOSteps: transformNewSteps()
                    
    }
fun transformNewSteps()=
    {
        DTOStep @(Order:soutincrement(), Name:"Base Premium", Operation:"=", Factor: vars.CISGOutput.Factors.LIAB.BasePrem, Value: vars.CISGOutput.Factors.LIAB.BasePrem): DTOSteps: transformChildSteps(),
        DTOStep @(Order:soutincrement(), Name:"Large Premium Discount Plan", Operation:multiChar, Factor: vars.CISGOutput.Factors.LIAB.LPDP, Value: vars.CISGOutput.Factors.LIAB.LPDP): null,
        DTOStep @(Order:soutincrement(), Name:"IRPM", Operation:multiChar, Factor: vars.CISGOutput.Factors.LIAB.IRPM, Value: vars.CISGOutput.Factors.LIAB.IRPM): null,
        DTOStep @(Order:soutincrement(), Name:"Term Factor", Operation:multiChar, Factor: vars.CISGOutput.Factors.LIAB.Term, Value: vars.CISGOutput.Factors.LIAB.Term): null
    }
fun transformChildSteps()=
    {
        DTOStep @(Order:sinincrement(), Name:"Exposure", Operation:"=", Factor: vars.CISGOutput.Factors.LIAB.Exposure, Value: vars.CISGOutput.Factors.LIAB.Exposure): null,
        DTOStep @(Order:sinincrement(), Name:"Base Rate", Operation:multiChar, Factor: vars.CISGOutput.Factors.LIAB.BaseRate, Value: vars.CISGOutput.Factors.LIAB.BaseRate): null,
        DTOStep @(Order:sinincrement(), Name:"Territory", Operation:multiChar, Factor: vars.CISGOutput.Factors.LIAB.Terr, Value: vars.CISGOutput.Factors.LIAB.Terr): null,
        DTOStep @(Order:sinincrement(), Name:"ILF", Operation:multiChar, Factor: vars.CISGOutput.Factors.LIAB.Limit, Value: vars.CISGOutput.Factors.LIAB.Limit): null,
        DTOStep @(Order:sinincrement(), Name:"Med Pay", Operation:multiChar, Factor: vars.CISGOutput.Factors.LIAB.MedPay, Value: vars.CISGOutput.Factors.LIAB.BasePrem): null                                   
    }

fun transformCoverage(x, index)=
    x match {
      case is Object -> x mapObject 
        if ($$ as String == "DTOCoverage" and $$.@CoverageCd == "LIAB")
            { 
                DTOCoverage @(( $$.@ - "FullTermAmt" ), FullTermAmt: fullTermAmts): 
                    transformSteps($, index)
            }
        else 
            (($$): transformCoverage($, index+1)) 
      else -> $
    }
---
transformCoverage(payload,1)

它的工作,但沒有優化好。

希望它對如何在 xpr 上遷移到 dataweave 有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM