Dynamic File Name UDF Example – SAP PI/PO

There are several ways to create dynamic file names at receiver adapter in SAP PI/PO. In this example we will discuss how to create a dynamic file name at receiver file channel using a User Defined Function (UDF).  Filename creation with UDF is a great way when the file name logic is too complicated to be handled by other file name creation methods such as variable substitution etc. Since you are writing a custom code, you can include complex logics for file name easily. You can write a simple UDF to create the file name in the message mapping. File name created in the message mapping can be set at the receiver using Adapter Specific Message Attributes (ASMA).

In this example (iDoc to File scenario) I am setting the iDoc Message type and Material number to the file name in the below format.

File name format: <Message Type>_<Material Number>_TimeStamp.XML

 

Lets look at the how to create file name in above format at receiver communication channel using a UDF.

 

Step 1: Create File Name User Defined Function (UDF).

UDF name: Set_FileName

Configure the parameters of the UDF. Since we require file name to have ‘Message Type’ and the ‘Material Number’ from the input, we need to create two import parameters in the UDF. One for ‘Message Type’ and another one for ‘Material Number’.

Configure dynamic file name UDF import parameters
Configure UDF import parameters

 

Step 2: Code UDF Logic to Set the File Name.

Here we need to set the file name to dynamic configuration key ‘FileName’. You can change the UDF code here as per your file format requirement.

 

UDF java code to set file name
UDF java code to set file name

 

try {

String filename = new String("");

DynamicConfiguration conf1 = (DynamicConfiguration) container.getTransformationParameters().get(StreamTransformationConstants.DYNAMIC_CONFIGURATION);

DynamicConfigurationKey key1 = DynamicConfigurationKey.create("http:/"+"/sap.com/xi/XI/System/File","FileName");

filename = MessageType+"_"+MaterialNumber+"_.xml";

conf1.put(key1,filename);

return "";
}

catch(Exception e)

{
String exception = e.toString();
return exception;

}

 

File name generation UDF comes in handy when your file name logic is complex and it cannot be handled by other dynamic file name generation methods such as variable substitution.

 

Step 3: Configure the Message Mapping program.

Map created UDF in Message Mapping program
Map created UDF in Message Mapping program

Map the created file name generation UDF as above. In the example we import two values from the input structure to the UDF, they are Message type (MESTYP) and Material Number (MATNR).

 

Step 4: Configure the receiver file communication channel .

You can set any text as the ‘File Name Schema’ as it would be replaced by the ASMA.

configure-receiver-file-communication-channel
Configure file communication channel

 

Configure ASMA by checking ‘Use Adapter Specific Message Attributes’ (ASMA) and also ‘File Name’. These two settings should be activated in the receiver communication channel to runtime to override the hardcoded file name in ‘File Name Schema’ with the file name set from the UDF.

Configure receiver adapter Adapter Specific Message Attributes
Configure receiver adapter Adapter Specific Message Attributes

 

Set the time stamp since we need the timestamp at the end of the file name.

Receiver Communication Channel timestamp configuration
Receiver Communication Channel timestamp configuration

 

Test Case for Dynamic File Generation using UDF.

 

File name in Message Monitor log.
File name in Message Monitor log.

 

If you would like to learn configuration steps for dynamic file name generation using variable substitution method, check out the linked article. Additionally, I have written another post to illustrate how to encode and decode Base64 using UDFs. You can follow all posts related to UDFs here.

Please leave a comment if you have any questions of the dynamic file generation steps discussed here.

Encode Message Payload to Base64 on CPI!

How to use Base64 message encoder in SAP Integration Suite.

Subscribe for more

My First Interface on CPI!

Learn how to develop your first iFlow on SAP Integration Suite within 7 minutes!

Subscribe for more

11 thoughts on “Dynamic File Name UDF Example – SAP PI/PO

  1. Akash Chauhan says:

    Hi Isuru,
    Great Blog!!!

    Can you please explain me in step 3 to which target field are we doing the udf mapping and how the target field is getting the file name, that is being used in ASMA.

    Thanks & Regards,
    Akash

    • Isuru Fernando says:

      Hello Akash,

      The target field you map the UDF is mostly irrelevant in this scenario. You can map the UDF output to the root element of the target structure. UDF does the rest to set the dynamic configuration parameter “FileName”.

      Cheers!
      Isuru

  2. Javier Villarreal says:

    Hello Isuru,

    I have a file to mail scenario and i simply what the file name to be kept on the mail’s attachment.
    I undestand that File adapter sets de file name http://sap.com/xi/XI/System/File FileName, right?.
    can can i pass this name to the attachment name using your UDF code?.

    thank you so much

  3. Gareth says:

    We have a a similar scenario, except it is IDOC–>AS2. I tried your UDF, but the AS2Filename or AS2MessageID is not being overridden. Is there a way we can use your UDF for the AS2 receiver channel?

  4. Gareth says:

    We have a scenario which is IDOC to AS2. I tried this method but the AS2Filename or AS2MessageID does not get overridden. The logs just show the regular file name. Can you please explain if something different has to be done for the AS2 Receiver channel?

Leave a Reply

Your email address will not be published. Required fields are marked *