GenAI Commons
Introduction
The GenAI Commons module combines common GenAI patterns found in a variety of generative AI models on the market. Platform-supported GenAI-connectors use the underlying data structures and their operations. This makes it easier to develop vendor-agnostic AI-enhanced apps with Mendix, for example by using one of the connectors or the Conversational UI module.
If two different connectors both adhere to the GenAI Commons module, they can be easily swapped, which reduces dependency on the model providers. In addition, the initial implementation of AI capabilities using the connectors becomes a drag-and-drop experience, so that developers can quickly get started. The module exposes useful operations which developers can use to build a request to a large language model (LLM) and to handle the response.
Developers who want to connect to another LLM provider or their own service are advised to use the GenAI Commons module as well. This speeds up the development and ensures that common principles are taken into account. Lastly, other developers or consumers of the connector can adapt to it more quickly.
Limitations
The current scope of the module is focused on text and image generation, as well as embeddings and knowledge base use cases.
Dependencies
The GenAI Commons module requires Mendix Studio Pro version 9.24.2 or above.
You must also download the Community Commons module.
Installation
If you are starting from the Blank GenAI app, or the AI Bot Starter App, the GenAI Commons module is already included and does not need to be downloaded manually.
If you start from a blank app, or have an existing project where you want to include a connector for which the GenAI Commons module is required, you must install GenAI Commons manually. First, install the Community Commons module, and then follow the instructions in How to Use Marketplace Content to import the GenAI Commons module into your app.
Implementation
GenAI Commons is the foundation of large language model implementations within the Mx GenAI connector, OpenAI connector, and the Amazon Bedrock connector, but may also be used to build other GenAI service implementations on top of it by reusing the provided domain model and exposed actions.
Although GenAI Commons technically defines additional capabilities typically found in chat completion APIs, such as image processing (vision) and tools (function calling), it depends on the connector module of choice for whether these are actually implemented and supported by the LLM. To learn which additional capabilities a connector supports and for which models these can be used, refer to the documentation of that connector.
The GenAI Commons module is protected, which means that it cannot be changed and the logic of the microflows is not visible. For information about what each exposed operation does, see Microflows, or refer to the documentation inside the module.
Token Usage
GenAI Commons can help store usage data which allows admins to understand the token usage. Usage data is only persisted if the constant StoreUsageMetrics
is set to true
and the GenAI connector of choice has implemented the operation to store token usage. In general, this is only supported for chat completions and embedding operations.
To clean up usage data in a deployed app, you can enable the daily scheduled event ScE_Usage_Cleanup
in the Mendix Cloud Portal. Use the Usage_CleanUpAfterDays
constant to control for how long token usage data should be persisted.
Lastly, the Conversational UI module provides pages, snippets, and logic to display and export token usage information. For this to work, the module roles UsageMonitoring
from both Conversational UI as well as GenAI Commons need to be assigned to the applicable project roles.
Technical Reference
The technical purpose of the GenAI Commons module is to define a common domain model for generative AI use cases in Mendix applications. To help you work with the GenAI Commons module, the following sections list the available entities, enumerations, and microflows to use in your application.
Domain Model
The domain model in Mendix is a data model that describes the information in your application domain in an abstract way. For more general information, see the Domain Model documentation. To learn about where the entities from the domain model are used and relevant during implementation, see the Microflows section below.
DeployedModel
The DeployedModel
represents a GenAI model that can be invoked by the Mendix app. It contains a display name and a technical name/identifier. It also contains the name of the microflow to be executed for the specified model and other information relevant to connect to a model. The creation of Deployed Models is handled by the connectors themselves (see their specializations) where admins can configure those at runtime.
The DeployedModel
entity replaces the capabilities that were covered by the Connection
entity for model invocations in earlier versions of GenAI Commons. For knowledge base interactions, the Connection
entity is still used.
Attribute | Description |
---|---|
DisplayName |
The display name of the deployed model. |
Architecture |
The architecture of the deployed model; e.g. OpenAI or Amazon Bedrock. |
Model |
The model identifier of the LLM provider. |
OutputModality |
The type of information the model returns. |
SupportsSystemPrompt |
An enum to specify if the model supports system prompts. |
SupportsConversationsWithHistory |
An enum to specify if the model supports conversation with history. |
SupportsFunctionCalling |
An enum to specify if the model supports function calling. |
IsActive |
A boolean to specify if the model is active/usable with the current authentication settings and user preference. |
InputModality
Accepted input modality of the associated deployed model.
Attribute | Description |
---|---|
ModelModality |
The type of information the model accepts as input. |
Usage
This entity represents usage statistics of a call to an LLM. It refers to a complete LLM interaction; in case there are several iterations (e.g. recursive processing of function calls), everything should be aggregated into one Usage record.
Following the principles of GenAI Commons, it must be stored based on the response for every successful call to a system of an LLM provider. This is only applicable to text & file operations and embedding operations. It is the responsibility of connector developers implementing the GenAI principles in their GenAI operations to include the right microflows to ensure the storage of Usage details after successful calls.
The data stored in this entity is to be used later on for token consumption monitoring.
Attribute | Description |
---|---|
Architecture |
The architecture of the used deployed model; e.g. OpenAI or Amazon Bedrock. |
DeployedModelDisplayName |
DisplayName of the DeployedModel. |
InputTokens |
The amount of tokens consumed by an LLM call that is related to the input. |
OutputTokens |
The amount of tokens consumed by an LLM call that is related to the output. |
TotalTokens |
The total amount of tokens consumed by an LLM call. |
DurationMilliseconds |
The duration in milliseconds of the technical part of the call to the system of the LLM provider. This excludes custom pre and postprocessing but corresponds to a complete LLM interaction. |
_DeploymentIdentifier |
Internal object used to identify the DeployedModel used. |
Connection
The Connection entity used to be an input parameter for Chat completions, Embeddings, and Image Generation operations but was replaced by DeployedModel
. It is currently only used as a general connection entity for Knowledge Base interactions.
Request
The Request
is an input object for the chat completions operations defined in the platform-supported GenAI-connectors and contains all content-related input needed for an LLM to generate a response for the given chat conversation.
Attribute | Description |
---|---|
SystemPrompt |
A SystemPrompt provides the model with context, instructions, or guidelines. |
MaxTokens |
Maximum number of tokens per request. |
Temperature |
Temperature controls the randomness of the model response. Low values generate a more predictable output, while higher values allow creativity and diversity. It is recommended to steer either the temperature or TopP , but not both. |
TopP |
TopP is an alternative to temperature for controlling the randomness of the model response. TopP defines a probability threshold so that only words with probabilities greater than or equal to the threshold will be included in the response. It is recommended to steer either the temperature or TopP , but not both. |
ToolChoice |
Controls which (if any) tool is called by the model. For more information, see the ENUM_ToolChoice section containing a description of the possible values. |
Message
A message that is part of the request or the response. Each instance contains data (text, file collection) that needs to be taken into account by the model when processing the completion request.
Attribute | Description |
---|---|
Role |
The role of the message’s author. For more information, see the ENUM_Role section. |
Content |
The text content of the message. |
MessageType |
The type of the message can be either text or file, where file means that the associated FileCollection should be taken into account. For more information, see the ENUM_MessageType section. |
ToolCallId |
The id of the tool call proposed by the model that this message is responding to. This attribute is only applicable for messages with the role tool . |
FileCollection
This is an optional collection of files that is part of a Message. It is used for patterns like vision, where image files are sent along with the user message for the model to process. It functions as a wrapper entity for files and has no attributes.
FileContent
This is a file in a collection of files that belongs to a message. Each instance represents a single file. Currently, only files of the type image and document are supported.
Attribute | Description |
---|---|
FileContent |
Depending on the ContentType , this is either a URL or the base64-encoded file data. |
ContentType |
This describes the type of file data. Supported content types are either URL or base64-encoded file data. For more information, see the ENUM_ContentType section. |
FileType |
Currently only images and documents are supported file types. In general, not all file types might be supported by all AI providers or models. For more information, see the ENUM_FileType. |
TextContent |
An optional text content describing the file content or giving it a specific name. This can be used to refer to specific files in the prompt of the message. |
FileExtension |
Extension of the file, e.g. png or pdf. Note that this attribute may only be filled if the ContentType equals Base64 and can be empty. |
ToolCollection
This is an optional collection of tools to be sent along with the Request
. Using tool call capabilities (also known as function calling) might not be supported by certain AI providers or models. This entity functions as a wrapper entity for tools and has no attributes.
Tool
A tool in the tool collection. This is sent along with the request to expose a list of available tools. In the response, the model can suggest calling a certain tool (or multiple tools in parallel) to retrieve additional data or perform certain actions.
Attribute | Description |
---|---|
Name |
The name of the tool to call. This is used by the model in the response to identify which function needs to be called. |
Description |
An optional description of the tool, used by the model in addition to the name attribute to choose when and how to call the tool. |
ToolType |
The type of the tool. Refer to the documentation supplied by your AI provider for information about the supported types. |
Function
A tool of the type function. This is a specialization of Tool and represents a microflow in the same Mendix application. The return value of this microflow when executed as a function is sent to the model in the next iteration and hence must be of type String.
Attribute | Description |
---|---|
Microflow |
The name (string) of the microflow that this function represents. |
StopSequence
For many models, StopSequence
can pass a list of character sequences (for example a word) along with the request. The model will stop generating content when a word of that list occurs next.
Attribute | Description |
---|---|
Sequence |
A sequence of characters that would prevent the model from generating further content. |
Response
The response returned by the model contains usage metrics and a response message.
Attribute | Description |
---|---|
RequestTokens |
Number of tokens in the request. |
ResponseTokens |
Number of tokens in the generated response. |
TotalTokens |
Total number of tokens (request + response). |
DurationMilliseconds |
Duration in milliseconds for the call to the LLM to be finished. |
StopReason |
The reason why the model stopped is to generate further content. See AI provider documentation for possible values. |
ResponseText |
The text content of the response message. |
ToolCall
A tool call object may be generated by the model in certain scenarios, such as a function call pattern. This entity is only applicable for messages with role assistant
.
Attribute | Description |
---|---|
Name |
The name of the tool to call. This refers to the Name attribute of one of the Tools in the Request. |
Arguments |
The arguments with which the tool is to be called, as generated by the model in JSON format. Note that the model does not always generate valid JSON and may hallucinate parameters that are not defined by your tool’s schema. Mendix recommends validating the arguments in the code before calling the tool. |
ToolType |
The type of the tool. View AI provider documentation for supported types. |
ToolCallId |
This is a model-generated ID of the proposed tool call. It is used by the model to map an assistant message containing a tool call with the output of the tool call (tool message). |
Reference
An optional reference for a response message.
Attribute | Description |
---|---|
Title |
The title of the reference. |
Content |
The content of the reference. |
Source |
The source of the reference, e.g. a URL. |
SourceType |
The type of the source. For more information, see ENUM_SourceType. |
Citation
An optional citation. This entity can visualize the link between a part of the generated text and the actual text in the source on which the generated text was based.
Attribute | Description |
---|---|
StartIndex |
An index that marks the beginning of a citation in a larger document. |
EndIndex |
An index that marks the end of a citation in a larger document. |
Text |
The part of the generated text that contains a citation. |
Quote |
Contains the cited text from the reference. |
ChunkCollection
This entity represents a collection of chunks. It is a wrapper entity for Chunk objects or specialization(s) to pass it to operations that execute embedding calculations or knowledge base interaction.
Chunk
A piece of information (InputText) and the corresponding embeddings vector retrieved from an Embeddings API. This is the relevant entity if you need to generate embedding vectors but do not need to store them in a knowledge base.
Attribute | Description |
---|---|
InputText |
The input text to create the embedding for. |
EmbeddingVector |
The corresponding embedding vector of the input text. |
_Index |
Internal attribute. Do not use. |
KnowledgeBaseChunk
This entity represents a discrete piece of knowledge that can be used for embedding and storage operations. As a specialization of Chunk, it is the appropriate entity to use when both generating embedding vectors and storing them in a knowledge base.
Attribute | Description |
---|---|
ChunkID |
This is a system-generated UUID for the chunk in the knowledge base. |
HumanReadableID |
This is a front-end reference to the KnowledgeBaseChunk so that users know what it refers to (e.g. URL, document location, human-readable record ID). |
MxObjectID |
If the KnowledgeBaseChunk was based on a Mendix object during creation, this will contain the GUID of that object at the time of creation. |
MxEntity |
If the KnowledgeBaseChunk was based on a Mendix object during creation, this will contain its full entity name at the time of creation. |
Similarity |
In case the chunk was retrieved from the knowledge base as part of a similarity search (for example, nearest neighbors retrieval) this will contain the cosine similarity to the input vector for the retrieval that was executed. |
MetadataCollection
An optional collection of metadata. This is a wrapper entity for one or more Metadata objects for a KnowledgeBaseChunk.
Metadata
This entity represents additional information to be stored with the KnowledgeBaseChunk in the knowledge base. At the insertion stage, you can link multiple metadata objects to a KnowledgeBaseChunk as needed. These metadata objects consist of key-value pairs used for custom filtering during retrieval. Retrieval operates on an exact string-match basis for each key-value pair, returning records only if they match all metadata records specified in the search criteria.
Attribute | Description |
---|---|
Key |
This is the name of the metadata and typically tells how the value should be interpreted. |
Value |
The value of the metadata that provides additional information about the chunk in the context of the given key. |
EmbeddingsOptions
An optional input object for the embedding operations to set optional request attributes.
Attribute | Description |
---|---|
Dimensions |
The number of dimensions the resulting output embeddings should have. |
EmbeddingsResponse
The response returned by the model contains token usage metrics. Not all connectors or models might support token usage metrics.
Attribute | Description |
---|---|
PromptTokens |
Number of tokens in the prompt. |
TotalTokens |
Total number of tokens used in the request. |
ImageOptions
An optional input object for the image generation operations to set optional request attributes.
Attribute | Description |
---|---|
Height |
This determines the height of the image. |
Width |
This determines the width of the image. |
NumberOfImages |
This determines the number of images to be generated. |
Seed |
This can be used to influence the randomness of the generation. Ensures the reproducibility and consistency of the generated images by controlling the initial state of the random number generator. |
CfgScale |
This can be used to influence the randomness of the generation. Adjusts the balance between adherence to the prompt and creative randomness in the image generation process. |
ImageGenerationType |
This describes the type of image generation. Currently, only text to image is supported. For more information, see ENUM_ImageGenerationType. |
Microflows activities
Use the exposed microflows and Java Actions to map the required information for GenAI operations from your custom app implementation to the GenAI model and vice versa. Two sets of operations are provided: one for text and files, plus a second one for embeddings and knowledge bases.
Text and Files: Operations
Chat completions and image generation operations can be used by passing a DeployedModel object of the desired connector. The action calls the internally assigned microflow of the connector and returns the response. Operations from different connectors can be exchanged very easily without much additional development effort.
It is recommended that you adapt to the same interface when developing custom chat completions or image generation operations, such as integration with different AI providers. The generic interfaces are described below. For more detailed information, refer to the documentation of the connector that you want to use, since it may expect specializations of the generic GenAI common entities as an input.
Chat Completions (without History)
The Chat Completions (without history)
operation supports scenarios where there is no need to send a list of (historic) messages comprising the conversation so far as part of the request.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
UserPrompt |
String | mandatory | A user message is the input from a user. |
DeployedModel |
DeployedModel | mandatory | The DeployedModel entity replaces the Connection entity. It contains the name of the microflow to be executed for the specified model and other information relevant to connecting to a model. The OutputModality of the DeployedModel needs to be Text. |
OptionalRequest |
Request | optional | This is an optional object that contains optional attributes and an optional ToolCollection. If no Request is passed, one will be created. |
OptionalFileCollection |
FileCollection | optional | This is an optional collection of files to be sent along with the request to use vision or document chat. |
Return Value
Name | Type | Description |
---|---|---|
Response |
Response | A Response object that contains the assistant’s response. |
Chat Completions (with History)
The Chat Completions (with history)
operation supports more complex use cases where a list of (historical) messages (for example, comprising the conversation or context so far) is sent as part of the request to the LLM.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
DeployedModel |
DeployedModel | mandatory | The DeployedModel entity replaces the Connection entity. It contains the name of the microflow to be executed for the specified model and other information relevant to connect to a model. The OutputModality of the DeployedModel needs to be Text. |
Request |
Request | mandatory | This is an object that contains messages, optional attribute, and an optional ToolCollection. |
Return Value
Name | Type | Description |
---|---|---|
Response |
Response | A Response object that contains the assistant’s response. |
Text and Files: Generate Image
The Generate Image
operation supports the generation of images based on a UserPrompt
passed as a string. The returned Response
contains a FileContent
via FileCollection
and Message
. See microflows in the Handle Response
folder to get the image (list).
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
DeployedModel |
DeployedModel | mandatory | The DeployedModel entity replaces the Connection entity. It contains the name of the microflow to be executed for the specified model and other information relevant to connect to a model. The OutputModality needs to be Image. |
UserPrompt |
String | mandatory | This is the description the image will be based on. |
ImageOptions |
ImageOptions | optional | This can be used to pass optional request attributes. |
Return Value
Name | Type | Description |
---|---|---|
Response |
Response | A Response object that contains the assistant’s response including a FileContent which needs to be used in Get Generated Image (Single) or Get Generated Images (List). |
Text and Files: Build Request
The following microflows help you construct the input request structures for the operations for text and files defined in GenAI Commons.
Create Request
This microflow can be used to create a request for a chat completion operation. This is the request object that contains the top-level functional input for the language model to generate a response.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
SystemPrompt |
String | optional | A system message can specify the assistant persona or give the model more guidance, context, or instructions. This attribute is optional. |
Temperature |
Decimal | optional | This is the sampling temperature. Higher values will make the output more random, while lower values make it more focused and deterministic. This attribute is optional. |
MaxTokens |
Integer/Long | Depends on AI provider or model | This is the maximum number of tokens to generate in the chat completion. The total length of input tokens and generated tokens is limited by the model’s context length. This attribute is optional. |
TopP |
Decimal | optional | This is an alternative to sampling with temperature, called nucleus sampling, where the model considers the results of the tokens with Top_p probability mass. Mendix generally recommends altering Top_p or Temperature but not both. This attribute is optional. |
Return Value
Name | Type | Description |
---|---|---|
Request |
Request | This is the created request object. |
Add Message to Request
This microflow can add a new Message to the Request object. A message represents the conversation text content and optionally has a collection of files attached that need to be taken into account when generating the response (such as images for vision). Make sure to add messages chronologically so that the most recent message is added last.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Request |
Request | mandatory | This is the request object that contains the functional input for the model to generate a response. |
ENUM_MessageRole |
ENUM_MessageRole | mandatory | The role of the message author. |
FileCollection |
FileCollection | optional | This is an optional collection of files that are part of the message. |
ContentString |
String | mandatory | This is the textual content of the message. |
Return Value
This microflow does not have a return value.
Configure Stop Sequence
This microflow can be used to add an optional StopSequence to the request. It can be used after the request has been created. If available for the connector and model of choice, stop sequences let models know when to stop generating text.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Request |
Request | mandatory | This is the request object that contains the functional input for the model to generate a response. |
StopSequence |
String | mandatory | This is the stop sequence string, which is used to make the model stop generating tokens at a desired point. |
Return Value
This microflow does not have a return value.
Files: Initialize Collection with File
To include files within a message, you must provide them in the form of a file collection. This helper microflow creates the file collection and adds the first file. The File Collection is an optional part of a Message object.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
URL |
String | Either URL or FileDocument is required. | This is the URL of the file. |
FileDocument |
System.FileDocument |
Either URL or FileDocument is required. | The file for which the contents are part of a message. |
ENUM_FileType |
ENUM_FileType | mandatory | This is the type of the file. |
TextContent |
String | optional | An optional text content describing the file content or giving it a specific name. |
Return Value
Name | Type | Description |
---|---|---|
FileCollection |
FileCollection | This is the created file collection with the new file associated with it. |
Files: Add File to Collection
Use this microflow to add a file to an existing FileCollection. The File Collection is an optional part of a Message.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
FileCollection |
FileCollection | mandatory | The wrapper object for Files. The File Collection is an optional part of a Message. |
URL |
String | Either URL or FileDocument is required. | This is the URL of the file. |
FileDocument |
System.FileDocument |
Either URL or FileDocument is required. | The file for which the contents are part of a message. |
ENUM_FileType |
ENUM_FileType | mandatory | This is the type of the file. |
TextContent |
String | mandatory | An optional text content describing the file content or giving it a specific name. |
Return Value
This microflow does not have a return value.
Image Generation: Create ImageOptions
This microflow creates new ImageOptions.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Height |
Integer/Long | optional | To set Width. |
Width |
Integer/Long | optional | To set Height. |
NumberOfImages |
Integer/Long | optional | To set NumberOfImages to create. |
Return Value
Name | Type | Description |
---|---|---|
ImageOptions |
ImageOptions | The newly created ImageOptions object. |
Tools: Add Function to Request
Adds a new Function to a ToolCollection that is part of a Request. Use this microflow when you have microflows in your application that may be called to retrieve the required information as part of a GenAI interaction. If you want the model to be aware of these microflows, you can use this operation to add them as functions to the request. If supported by the LLM connector, the chat completion operation calls the right functions based on the LLM response and continues the process until the assistant’s final response is returned.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Request |
Request | mandatory | The request to add the function to. |
ToolName |
String | mandatory | The name of the tool to use/call. |
ToolDescription |
String | optional | An optional description of what the tool does, used by the model to choose when and how to call the tool. |
FunctionMicroflow |
Microflow | mandatory | The microflow that is called within this function. A function microflow can only have a single string input parameter or no input parameter and returns a string. |
Return Value
Name | Type | Description |
---|---|---|
Function |
Function | This is the function object that was added to ToolCollection which is part of the request. This object can be used optionally as input for controlling the tool choice of the Request, see Tools: Set Tool Choice. |
Tools: Set Tool Choice
Use this microflow to control how the model should determine which function to leverage (typically to gather additional information). The microflow sets the ToolChoice within a Request. This controls which (if any) function is called by the model. If the ENUM_ToolChoice equals tool
, the Tool
input is required which will become the tool choice. This will force the model to call that particular tool.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Request |
Request | mandatory | The request for which to set a tool choice. |
Tool |
Tool | Required if ENUM_ToolChoice equals tool . |
Specifies the tool to be used. Required if the ENUM_ToolChoice equals tool ; ignored for all other enumeration values. |
ENUM_ToolChoice |
ENUM_ToolChoice | mandatory | Determines the tool choice. For more information, see the ENUM_ToolChoice section for a list of the available values. |
Return Value
This microflow does not have a return value.
Text and Files: Handle Response
The following microflows handle the response processing.
Get Response Text
This microflow can get the content from the latest assistant message over association Response_Message
. Use this microflow to get the response text from the latest assistant response message. In many cases, this is the main value needed for further logic after the operation or is displayed to the end user. Note that the content can be directly extracted from the Response’s attribute ResponseText
.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Response |
Response | mandatory | The response object. |
Return Value
Name | Type | Description |
---|---|---|
ResponseText |
String | This is the string Content of the message with role assistant that was generated by the model as a response to a user message. |
Get References
Use this microflow to get the list of references that may be included in the model response. These can be used to display source information, content, and citations on which the model response text was based according to the language model. References are only available if they were specifically requested from the LLM and mapped from the LLM response into the GenAI Commons domain model.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Response |
Response | mandatory | The response object. |
Return Value
Name | Type | Description |
---|---|---|
ReferenceList |
List of Reference | The references with optional citations were part of the response message. |
Get Generated Image (Single)
This operation processes a response that was created by an image generation operation. A return entity can be specified using ResponseImageEntity (needs to be of type System.Image
or its specialization). An image of that type will be created and returned.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
ResponseImageEntity |
Entity | mandatory | This is to specify the entity of the returned image. Must be of type System.Image or its specializations. |
Response |
Response | mandatory | This is the response that was returned by an image generation operation. It points to a message with the FileContent to create the image. |
Return Value
Name | Type | Description |
---|---|---|
GeneratedImage |
Object of type determined by ResponseImageEntity |
The generated image. |
Get Generated Images (List)
This operation processes a response that was created by an image generation operation. A return entity can be specified using ResponseImageEntity (needs to be of type System.Image
or its specialization). A list of images of that type will be created and returned.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
ResponseImageEntity |
Entity | mandatory | This is to specify the entity of the returned image. Must be of type System.Image or its specializations. |
Response |
Response | mandatory | This is the response that was returned by an image generation operation. It points to a message with the FileContent to create the image. |
Return Value
Name | Type | Description |
---|---|---|
GeneratedImageList |
List of type determined by ResponseImageEntity |
The list of generated images. |
Knowledge Bases and Embeddings Operations
Embedding operations can be used by passing a DeployedModel object of the desired connector. The action calls the internally assigned microflow of the connector and returns the response. Operations from different connectors can be exchanged very easily without much additional development effort.
Generate Embeddings (String)
The Generate Embeddings (String)
operation allows the invocation of the embeddings API with a String input and returns an EmbeddingsResponse
object with token usage statistics, if applicable. The EmbeddingsResponse_GetFirstVector
microflow from GenAI Commons can be used to retrieve the corresponding embedding vector in a String representation. This operation supports scenarios where the vector embedding of a single string must be generated, e.g. to perform a nearest neighbor search across an existing knowledge base.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
InputText |
String | mandatory | Input text to create the embedding vector. |
DeployedModel |
DeployedModel | mandatory | The DeployedModel entity replaces the Connection entity. It contains the name of the microflow to be executed for the specified model and other information relevant to connecting to a model. The OutputModality needs to be Embeddings. |
EmbeddingOptions |
EmbeddingsOptions | optional | Can be used to pass optional request attributes. |
Return Value
Name | Type | Description |
---|---|---|
EmbeddingsResponse |
EmbeddingsResponse | A response object that contains the token usage statistics and the corresponding embedding vector as part of a ChunkCollection |
Generate Embeddings (Chunk Collection)
The Generate Embeddings (Chunk Collection)
operation allows the invocation of an embeddings API with a ChunkCollection and returns an EmbeddingsResponse object with token usage statistics, if applicable. The response object is associated with the original ChunkCollection used as an input, and the Chunk (or KnowledgeBaseChunk) objects will be updated with their corresponding embedding vector retrieved from the Embeddings API within this microflow.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
ChunkCollection |
ChunkCollection | mandatory | A ChunkCollection with Chunks for which an embedding vector should be generated. Use operations from GenAI commons to create a ChunkCollection and add Chunks or KnowledgeBaseChunks to it. |
DeployedModel |
DeployedModel | mandatory | The DeployedModel entity replaces the Connection entity. It contains the name of the microflow to be executed for the specified model and other information relevant to connecting to a model. The OutputModality needs to be Embeddings. |
EmbeddingOptions |
EmbeddingsOptions | optional | Can be used to pass optional request attributes. |
Return Value
Name | Type | Description |
---|---|---|
EmbeddingsResponse |
EmbeddingsResponse | An response object that contains the token usage statistics and the corresponding embedding vector as part of a ChunkCollection. |
Knowledge Bases and Embeddings: Build Request
The following microflows and Java actions help you construct the input structures for the operations for knowledge bases and embeddings as defined in GenAI Commons.
Chunks: Initialize ChunkCollection
This microflow creates a new ChunkCollection and returns it.
Input Parameters
This microflow has no input parameters.
Return Value
Name | Type | Description |
---|---|---|
ChunkCollection |
ChunkCollection | The newly created ChunkCollection object. |
Chunk: Add Chunk to ChunkCollection
This microflow adds a new Chunk to the ChunkCollection.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
InputText |
String | mandatory | Input text to generate an embedding vector. |
ChunkCollection |
ChunkCollection | mandatory | ChunkCollection to add the new Chunks to. |
Return Value
Name | Type | Description |
---|---|---|
Chunk |
Chunk | The added Chunk object. |
Chunk: Add KnowledgeBaseChunk to ChunkCollection
This Java action adds a new KnowledgeBaseChunk to the ChunkCollection to create the input for embeddings or knowledge base operations. Optionally, a MetadataCollection can be added for more advanced filtering. Use Initialize MetadataCollection with Metadata to instantiate a MetadataCollection first, if needed.
Input Parameters
Name | Type | Notes | Documentation |
---|---|---|---|
ChunkCollection |
ChunkCollection | mandatory | This is the ChunkCollection to which the KnowledgebaseChunk will be added. This ChunkCollection is the input for other operations. |
InputText |
String | mandatory | Input text to generate an embedding vector. |
HumanReadableID |
String | mandatory | This is a front-end identifier that can be used for showing or retrieving sources in a custom way. If it is not relevant, “empty” must be passed explicitly here. |
MxObject |
Type parameter | optional | This parameter is used to capture the Mendix object to which the chunk refers. This can be used for finding the record in the Mendix database later on after the retrieval step. |
MetadataCollection |
MetadataCollection | optional | This is an optional MetadataCollection that contains extra information about the KnowledgeBaaseChunk. Any key-value pairs can be stored. In the retrieval operations, it is possible to filter on one or multiple metadata key-value pairs. |
Return Value
Name | Type | Description |
---|---|---|
KnowledgeBaseChunk |
KnowledgeBaseChunk | The added KnowledgeBaseChunk object. |
Embeddings: Create EmbeddingsOptions
This microflow creates new EmbeddingsOptions.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Dimensions |
Integer/Long | optional | The number of dimensions the resulting output embedding vectors should have. See connector documentation for supported values and models. |
Return Value
Name | Type | Description |
---|---|---|
EmbeddingsOptions |
EmbeddingsOptions | The newly created EmbeddingsOptions object. |
Knowledge Base: Initialize MetadataCollection with Metadata
This microflow creates a new MetadataCollection and adds a new Metadata. The MetadataCollection will be returned. To add additional Metadata, use Add Metadata to MetadataCollection.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Key |
String | mandatory | This is the name of the metadata and typically tells how the value should be interpreted. |
Value |
String | mandatory | This is the value of the metadata that provides additional information about the chunk in the context of the given key. |
Return Value
Name | Type | Description |
---|---|---|
MetadataCollection |
MetadataCollection | The newly created MetadataCollection object. |
Knowledge Base: Add Metadata to MetadataCollection
This microflow adds a new Metadata object to a given MetadataCollection. Use Initialize MetadataCollection with Metadata to instantiate a MetadataCollection first, if needed.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
Key |
String | mandatory | This is the name of the metadata and typically tells how the value should be interpreted. |
Value |
String | mandatory | This is the value of the metadata that provides additional information about the chunk in the context of the given key. |
MetadataCollection |
MetadataCollection | mandatory | The MetadataCollection to which the new Metadata object will be added. |
Return Value
This microflow does not have a return value.
Knowledge Bases and Embeddings: Handle Response
The following microflows and Java actions help you handle the response object for the operations for embeddings as defined in GenAI Commons.
Embeddings: Get the First Vector from Response
This microflow gets the first embedding vector from the response of an embedding operation.
Input Parameters
Name | Type | Notes | Description |
---|---|---|---|
EmbeddingsResponse |
EmbeddingsResponse | mandatory | Response object that gets returned by the embeddings operations. |
Return Value
Name | Type | Description |
---|---|---|
Vector |
String | The first vector from the response. |
Enumerations
ENUM_MessageRole
ENUM_MessageRole
provides a list of message author roles.
Name | Caption | Description |
---|---|---|
user |
User | A user message is the input from an end-user. |
assistant |
Assistant | An assistant message was generated by the model as a response to a user message. |
system |
System | A system message can be used to specify the assistant persona or give the model more guidance and context. This is typically specified by the developer to steer the model response. |
tool |
Tool | A tool message contains the return value of a tool call as its content. Additionally, a tool message has a ToolCallId that is used to map it to the corresponding previous assistant response which provides the tool call input. |
ENUM_MessageType
ENUM_MessageType
provides a list of ways of interpreting a message object.
Name | Caption | Description |
---|---|---|
Text |
Text | The message represents a normal message and contains text content in the Content attribute. |
File |
File | The message contains file data and the files in the associated FileCollection should be taken into account. |
ENUM_ContentType
ENUM_ContentType
provides a list of possible file content types, which describe how the file data is encoded in the FileContent
attribute on the FileContent object that is part of the Message.
Name | Caption | Description |
---|---|---|
URL |
Url | The content of the file can be found on a (publicly available) URL which is provided in the FileContent attribute. |
Base64 |
Base64 | The content of the file can be found as a base64-encoded string in the FileContent attribute. |
ENUM_FileType
ENUM_FileType
provides a list of file types. Currently, only image and document are supported file types. Not all file types might be supported by all AI providers or models.
Name | Caption | Description |
---|---|---|
image |
Image | The file represents an image (e.g. a .png file). |
document |
Document | The file represents a document (e.g. a .pdf file). |
ENUM_ToolChoice
ENUM_ToolChoice
provides a list of ways to control which (if any) tool is called by the model. Not all tool choices might be supported by all AI providers or models.
Name | Caption | Description |
---|---|---|
auto |
Auto | The model can pick between generating a message or calling a function. |
none |
None | The model does not call a function and instead generates a message. |
any |
Any | Any function will be called. Not available for all providers and might be changed to auto. |
tool |
Tool | A particular tool needs to be called, which is the one specified over association ToolCollection_ToolChoice . |
ENUM_SourceType
ENUM_SourceType
provides a list of source types, which describes how the pointer to the Source
attribute on the Reference object should be interpreted to get the source location. Currently, only Url
is supported.
Name | Caption | Description |
---|---|---|
Url |
Url | The Source attribute contains the URL to the source on the internet. |
ENUM_ImageGenerationType
ENUM_ImageGenerationType
describes how the image generation operation is to be used. Currently, only text to image is supported.
Name | Caption | Description |
---|---|---|
TEXT_TO_IMAGE |
TEXT_TO_IMAGE | The LLM will generate an image (or multiple images) based on a text description. |
Troubleshooting
This section lists possible solutions to known issues.
Internal Errors in Hidden Documents
Adding the GenAI Commons module to an existing project causes internal errors in hidden documents in Studio Pro.
Cause
The Java actions from the CommunityCommons module are not compatible with the current version of the GenAI Commons module.
Solution
Update the CommunityCommons module to the latest version.