Code
This component executes plain JavaScript code within a sandbox making it secure and safe. In regards the following limitations apply:
- Access to the console
- Eval function
Calling done
Because JavaScript allows you to write code asynchronously, you need to call the done function when your code is done. When you are not using any asynchronous syntax, the done call should be at the end of your script.
// your code
done();
In cases where you are calling return in the global scope, you need to call done before the return statement.
Configuration
The Code component does not utilize handlebars. To refer to incoming data, you can use value. followed by the data reference.
For example, if the incoming data is the following object:
  {
    "result": {
      "_id": "123",
      "kind": "RECORD"
    }
  }
  
To refer to the "kind" in the Code component, you can do something like:
  const kind = value.result.kind;
  
Note that the Code component is the only place where you need to add
value. before the incoming data reference.Variables
value
Contains the received data.
Settings
Use Content Store / Enable lookup function
Checking this will allow you to use the mapping function lookup and work with mapping values previously loaded into the Content Store using the Load Mapping component.
Connection string
A MongoDB connection string.
Example: mongodb://<username>:<password>@localhost:27017/<databaseName>
Here <databaseName> is the database to store content.
Use TLS
Whether or not to use TLS in case your mongoDB requires TLS.
Allow Invalid Certificates
Checking this will disable certificate validation.
Certificate Authority File
One or more certificate authorities to trust when making a TLS connection.
Example: .\ca.pem
Functions
Use send(value: any); to send data to the output. This function can be executed multiple times.
Use error(message: string, data: any); to execute the error handling behavior. data is the data that caused the error and will be displayed in the log details.
Use setVariable(key: string, value: any); to set a global variable that can be used in any code sandbox within the same flow.
Use getVariable(key: string); to get a global variable.
Use deleteVariable(key: string); to delete a global variable.
Use getFlowVariable(key: string, parseAs: string); Options: 'boolean', 'array', 'number', 'object', 'date', 'string' to get a flow variable. By default parseAs is a set to string.
Note that the variable syntax %variableName% is not supported in the code component and that flow variables are read-only.
Use hexToBase64(key: string); to convert a hexadecimal string to its Base64-encoded representation.
Use parseAs(value: string, parseAs: string) to parse a value as something else. Options: 'boolean', 'array', 'number', 'object', 'date', 'string'. By default parseAs is a set to string.
Use log(type: string, message: any, data: any); to write a log record. Type options: 'info', 'error', 'warn', 'debug'
Use clone(value: object); to clone an object.
Use md5(value: string); to get a md5 hash of the value.
Use sha1(value: string); to get a sha1 hash of the value.
Use sha256(value: string); to get a sha256 hash of the value.
Use sha512(value: string); to get a sha512 hash of the value.
Use lookup(mappingName: string, lookupValues: array); to lookup mapping values previously loaded into the Content Store using the Load Mapping component.
mappingName is the name of the mapping in which to lookup the values. The mapping name refers to the mapping name under which the mapping is stored in the Content Store. It is the combined mapping name, which consists of the workbookName without the extension and the sheetName divided by a -. Note that all names in the mapping name are lowercased. For more information on the mapping name, see the Load Mapping component
lookupValues is an array of values that are used to lookup the mapping. The order of the values in the array should correspond to the order of the keys in the mapping. For example, if the mapping has two keys, name and lastName, the lookupValues array should contain two values, the first value being the value of the name key, and the second value being the value of the lastName key.
Example mapping Excel sheet:
| *name | *lastName | street | number | city | 
|---|---|---|---|---|
| Mark | Mike | Main Street | 12 | Los Angeles | 
| Morgan | Freeman | First Avenue | 24 | Washington DC | 
Example of using lookup:
// Using lookup in code component
async function main() {
  const person = await lookup("mappingexample-sheet1", ["Morgan","Freeman"]);
  send(person);
}
main()
  .then(() => {
    done();
})
.catch((e) => done(e));
Use getMappingKeys(mappingName: string); to get the keys of a mapping.
Use lookupByKey(lookupKey: string); to lookup mapping values by their key.
Use lookupByField(mappingName: string, query: { [key: string] }: string); to lookup a mapping using only one key in case there are multiple.
Example of using getMappingKeys and lookupByKey:
async function main() {
  const keys = getMappingKeys("mappingexample-sheet1");
  for await(const key of keys) {
    const person = lookupByKey(key);
  }
}
main()
  .then(() => {
    done();
})
.catch((e) => done(e));
Use escapeRegexSpecialChars(value: string) to escape special characters in the given value string using a built-in regex pattern, ensuring safe use in regular expressions.
Use xpath(xml: string, expression: string) to extract data from an XML string using the provided XPath expression. The function returns the extracted data as an array of nodes.
The following modules are available within the code component:
- Node.js Path module, use methods basename,dirname,extname,join,parse, orrelative
- Node.js URL module, use URL
- Luxon DateTime, use DateTime
For documentation on the modules, please use the manufacturer's official documentation.
Inputs | Outputs
send() function.