sort(mpath)

Sorts the incoming message according to certain value.
Sorts alphabetically.

inn.sort({'BOTSID':'UNH'},{'BOTSID':'LIN','C212.7140':None}) 
#sort article lines by EAN article number (GTIN).

transform.useoneof(first get, second get, etc)

Use for default values or when data can be in different places in a message.

value = transform.useoneof(inn.get({'BOTSID':'IMD','C960.4294':None}),inn.get({'BOTSID':'IMD','7078':None})) 
#returns the result of the first get() that is succesful.
#remarked was that this is simular to:
value = inn.get({'BOTSID':'IMD','C960.4294':None}) or inn.get({'BOTSID':'IMD','7078':None})
#Usage for default values (if field not there, use default): 
value = inn.get({'BOTSID':'IMD','C960.4294':None}) or 'my value'

transform.datemask(value,frommask,tomask)

Does format conversions based upon pattern matching.
Especially useful for date/time conversion.
Note: only simple pattern matching, without 'intelligence' about date/time.

transform.datemask('09/21/2011','MM/DD/CCYY','YY-MM-DD') 
#returns '11-09-21'

Funny trick with datamask:

print transform.datemask('201512312359','YYYYmmDD0000','YYYYmmDD0000')
print transform.datemask('201512310000','YYYYmmDD0000','YYYYmmDD0000')
print transform.datemask('20151231','YYYYmmDD0000','YYYYmmDD0000')
#returns date always in CCYYmmDDHHMM, if no tiem in original tiem is '0000'

transform.concat(*args)

do a save concatenate of string.
If argument is None, nothing is concatenated.

transform.concat('my',None','string') 
#returns 'mystring'

transform.sendbotsemail(partner,subject,reporttext)

Send a simple email message to any bots partner (in partner-table) from a mapping script.
Mail is sent to all To: and cc: addresses for the partner (but send_mail does not support cc).
Email parameters are in config/settings.py (EMAIL_HOST, etc).

transform.sendbotsemail('buyerID1','error in messsge','There is an error in message blahblah')

transform.unique(domain)

Returns counter/unique number.
For each 'domain' separate counters are used.
Counter start at '1' (at first time you use counter).
The counter can be changed in bots-monitor->SysTasks->view/edit counters

transform.unique('my article line counter') 
#returns a number unique for the domain 'my article line counter'

transform.unique_runcounter(domain))

Returns counter/unique number during the bots-run.
For each 'domain' separate counters are used.
Counter start at '1' (at first time you use counter).
In a next run the counter will start again at '1'.
Useful for eg a message-counter per interchange.

transform.inn2out(inn,out)

Use the incoming message as the outgoing message.
Is useful to translate the message one-on-one to another editype.
Examples:

  • edifact to flat file. This is what a lot of translators do.

  • x12 to xml. x12 data is translated to xml syntax, semantics are of course still x12

  • Another use: read a edi message, adapt, and write (to same editype/messagetype including changes).