- Extension Nodes let you:
- Integrate with third-party APIs.
- Run custom logic for lightweight operations.
- Build convenience nodes using NPM modules.
 
- Knowledge Connectors let you:
- Import documents or data as Knowledge Sources.
- Improve AI Agents’ RAG capabilities.
 
Limitations
- Extensions have a default 20-second timeout. You can change the timeout by doing the following:
- For dedicated SaaS installations, contact Cognigy technical support to change the timeout.
- For on-premises installations, change the environment variable as described in the Cognigy.AI Helm Chart.
 
- Extensions can make up to 10 API calls per execution.
Working with Extensions
- GUI
- CLI
- API
In Manage > Extensions, you can install, update, and uninstall Extensions from the Marketplace or custom Extensions. Also, you can mark your custom Extensions as trusted.The Extension Marketplace is also available on Cognigy’s website.
Extension Nodes
You can add Extension Nodes to your Flows in the Flow editor.Knowledge Connectors
You can add Knowledge Sources from external knowledge databases to a Knowledge Store in Build > Knowledge.Custom Extensions
Cognigy allows anyone to extend the capabilities of Cognigy.AI by developing their own Extensions. Custom Extensions are JavaScript or TypeScript modules that you can use to create fully customized Extension Nodes and Knowledge Connectors. After developing a custom Extension, you can install it by uploading it in Manage > Extensions. Extensions are designed for lightweight operations. When developing a custom Extension, avoid CPU-intensive computations, high-memory operations, large loops, and code issues, for example, infinite loops or unresolved promises, in the Extension code. These practices can impact the performance of your AI Agents. Additionally, you can publish your custom Extension on the Marketplace so other Cognigy users can access it.Develop Custom Extensions
Develop Custom Extensions
The following materials provide in-depth information to develop a custom Extension:Best practices for developing custom ExtensionsTo guarantee the performance of a custom Extension, make sure the Extension code:
- Readme of the @cognigy/extension-toolspackage for requirements.
- Cognigy Sessions Episode about Extensions for a technical deep dive.
- An Extension Node example that shows how to build an Extension Node.
- A Knowledge Connector example that shows how to build a Knowledge Connector.
- GitHub repository for more Extension examples.
Cognigy Hammer, created by the Cognigy community, is an Extension development suite designed for Cognigy.AI. Cognigy Hammer offers several tools and features to assist in the development of Cognigy Extensions. Note that Cognigy Hammer isn’t a product of Cognigy and doesn’t qualify for enterprise support.
- Undergoes review by experienced developers.
- Avoids very complex logic and use cases.
- Is tested both independently and in Flows before production rollout.
- Provides error handling across all potential error cases, for example, using try/catch blocks and resolving promises.
Publish Custom Extensions
Publish Custom Extensions
If you want to publish a custom Extension on the Marketplace, follow the approval procedure in the Extensions GitHub repository.
Extension Performance and Security
By default, Cognigy.AI considers Extension code untrusted and runs it in a secure, isolated environment. This additional security layer introduces some overhead during startup. For this reason, Extensions usually run slower than default Nodes in Flows. To reduce startup overhead, keep Extensions small. Include only the custom Nodes and npm packages required for operation to maintain a lightweight bundle. If your Extension contains many Nodes (dozens to hundreds), split them into multiple Extensions scoped to specific use cases, rather than combining all Nodes into a single Extension. Cognigy.AI ensures that Extension code runs in a secure context by:- Executing the Extension code in a separate microservice. This approach ensures that, in a worst-case scenario, a breakout affects only the dedicated microservice, but not the rest of the system.
- Using a dedicated child process that the system spawns for each execution of the Extension code within the separate microservice. This approach ensures that the Extension code can access only a defined set of environment variables and allows Cognigy.AI to terminate this code if it runs for too long.
- Creating a separate JavaScript virtual machine within the child process in which the Extension code is executed. This approach restricts the usability of certain APIs from the underlying Node.js execution context, limiting what the code can do when running on the Cognigy.AI infrastructure.
Make Extensions Trusted
Never trust Extension code without thorough review. Extensions can use external packages from NPM, which may contain malicious code or routines. An Extension can steal sensitive information when executed in the standard environment.
Make Extensions Trusted
Make Extensions Trusted
- Mark an Extension as trusted in Manage > Extensions. Trusted Extensions display the icon. Only admins and users with the extension_trust_adminrole can mark Extensions as trusted and update them.
- For dedicated SaaS or on-premises installations:
- Set the FEATURE_ALLOW_TRUSTED_CODE_CONFIGURATIONenvironment variable totrueby adding the following code to yourconfig-map_patch.yamlin thekubernetesrepository where the deployment manifest files are stored:
 - Use the Cognigy.AI API PATCH request to update the trustedCodeproperty of an Extension.
 
- Set the 
Install Extensions for All Organizations
On-premises customers can install Extensions across all organizations in their installation. To do so, add theFEATURE_ADDITIONAL_SYSTEM_WIDE_EXTENSIONS_PATH environment variable to values.yaml under the cognigyEnv mapping key and enter the path to the Extension.
Cache Extensions in your Local Directory
You can cache Extensions in your local directory to improve loading performance.Maximum cache storage
Maximum cache storage
By default, when Extensions exceed the maximum cache directory size, the last 10 Extensions are removed from the local directory. On-premises and dedicated SaaS customers can change the number of Extensions that are removed when the maximum cache directory size is exceeded using the 
EXCEED_DIR_SIZE_AMOUNT_TO_DROP_FROM_MAP environment variable.On-premises and dedicated SaaS customers can change the maximum directory size by adding the MAX_EXTENSIONS_CACHE_DIR_SIZE_IN_MB environment variable to values.yaml. By default, the maximum directory size is 512 MB.The cache is in the service-execution Kubernetes pod.Dynamic Fields
You can use a dynamic selection field as a field type in Extensions. This feature can be used to dynamically fetch the content of a selection field, for example, through an external API call.Localization for Extensions
Extension builders can include localized UI text, such as default Node labels or Node field descriptions. For more details, read the Localization for Extensions documentation.Error Handling
If an Extension times out or sends too many API calls, the Flow execution doesn’t stop. Instead, an error message is written to theinput.extensionError Input object.