MultimodalCompletion
MultimodalCompletion
yaml
type: "io.kestra.plugin.gemini.MultimodalCompletion"Examples
yaml
id: gemini_multimodal_completion
namespace: company.team
inputs:
- id: image
type: FILE
tasks:
- id: multimodal_completion
type: io.kestra.plugin.gemini.MultimodalCompletion
apiKey: "{{ secret('GEMINI_API_KEY') }}"
model: "gemini-2.5-flash"
contents:
- content: Can you describe this image?
- mimeType: image/jpeg
content: "{{ inputs.image }}"
yaml
id: gemini_multimodal_generate_edit_analyze
namespace: company.team
inputs:
- id: gen_prompt
type: STRING
defaults: "a giant library floating in the clouds with glowing bookshelves"
- id: edit_prompt
type: STRING
defaults: "transform the background into a cyberpunk cityscape at night"
tasks:
- id: generate
type: io.kestra.plugin.gemini.MultimodalCompletion
contents:
- content: "{{ inputs.gen_prompt }}"
- id: edit
type: io.kestra.plugin.gemini.MultimodalCompletion
contents:
- content: "{{ inputs.edit_prompt }}"
- mimeType: "{{ outputs.generate.images[0].mimeType }}"
content: "{{ outputs.generate.images[0].uri }}"
- id: analyze
type: io.kestra.plugin.gemini.MultimodalCompletion
contents:
- content: "Describe the mood and style of this image."
- mimeType: "{{ outputs.edit.images[0].mimeType }}"
content: "{{ outputs.edit.images[0].uri }}"
pluginDefaults:
- type: io.kestra.plugin.gemini.MultimodalCompletion
values:
apiKey: "{{ secret('GEMINI_API_KEY') }}"
model: "gemini-2.5-flash-image-preview"
Properties
apiKey *Requiredstring
contents *Requiredarray
Definitions
io.kestra.plugin.gemini.MultimodalCompletion-Content
content*Requiredstring
mimeTypestring
rolestring
Default
usermodel *Requiredstring
Outputs
blocked boolean
Default
falsefinishReason string
images array
Definitions
io.kestra.plugin.gemini.MultimodalCompletion-GeneratedImage
mimeTypestring
uristring
Format
urisafetyRatings array
Definitions
io.kestra.plugin.gemini.MultimodalCompletion-SafetyRating
blockedboolean
categorystring
probabilitystring