How to dynamically route message in WSO2 ESB based

2020-03-30 15:40发布

I am trying to route a message based on information in a XML snippet stored as a local entry (key=mapping_id_ep_v1.xml). The id used to look-up the correct endpoint and it is part of the message body.

This is the XML snippet used to map id's to endpoints:

<mappings>
    <mapping id="ep_1">http://localhost:8280/services/ep_1</mapping>
    <mapping id="ep_2">http://localhost:8280/services/ep_2</mapping>
    <mapping id="ep_3">http://localhost:8280/services/ep_3</mapping>
<mappings>

I retrieve the id from the body to look-up the endpoint using the following statement:

<property name="LOOK-UP" expression="//controleFile/id" />

I can load the XML file into a property file using the following entry in a sequence:

<property name="MAPPING" expression="get-property('mapping_id_ep_v1.xml')" />

I log the property using the following statement:

<log level="custom">
    <property name="Look-up" expression="get-property('LOOK-UP')" />
    <property name="Mapping" expression="get-property('MAPPING')" />
</log>

So far so good. I haven't been able to figure out how to retrieve the correct endpoint from the MAPPING property. Can anyone help out?

标签: wso2 wso2esb esb
3条回答
够拽才男人
2楼-- · 2020-03-30 16:08

I have got a similar situation. The problem seems to be that you cannot perform xpath expressions over a property content.

You can easily do what you need by using a Javascript script after loading the xml into a property. Javascript+e4x offers an easy way to access to XML content of variables by xpath expressions.

Hope this helps you.

查看更多
太酷不给撩
3楼-- · 2020-03-30 16:11

Yes this is a limitation. Actually, this should be a functionality of the enrich mediator. Will create a feature request to get this fixed for the next ESB release.

For now you can do this with:

  • Preserve current soap payload : using enrich
  • Replace current body with the content of the property - enrich
  • Evaluate xpath against the current body and extract the required content. (Use that as the EP)- property
  • Restore the message body with preserved payload - enrich

I know... it's a hack :)

查看更多
别忘想泡老子
4楼-- · 2020-03-30 16:28

I solved my question using a different approach. It is in line with the answer given bij fipries.

In the proxy I added the following:

 <property name="MAPPING" expression="get-property('mapping_id_ep_v1')" />
 <property name="LOOK_UP" expression="//controlFile/id" />
 <log level="custom">
    <property name="MAPPING" expression="get-property('MAPPING')" />
    <property name="LOOK_UP" expression="get-property('LOOK_UP')" />
 </log>
 <script language="js" key="testScript_2" function="getEndpointByID" />
 <log level="custom">
    <property name="EP" expression="get-property('EP')" />
 </log>

This is the contents of mapping_id_ep_v1:

<mappings>
    <mapping id="ep_1">http://localhost:8280/services/ep_1</mapping>
    <mapping id="ep_2">http://localhost:8280/services/ep_2</mapping>
    <mapping id="ep_3">http://localhost:8280/services/ep_3</mapping>
<mappings>

This is the code in TestScript_2:

<x>

  function getEndpointByID(mc) {
     var xml = new XML(mc.getProperty('MAPPING'));
     var look_up = new XML(mc.getProperty('LOOK_UP'));
     var ep = xml..mapping.(@id == look_up);
     mc.setProperty('EP', ep + '');
  }

</x>

The proxy loads the mapping xml into a property. This property is converted to XML in the javascript code and then using LOOK_UP the correct endpoint is retrieved.

Hope this helps someone else.

Regards, nidkil

查看更多
登录 后发表回答