Skip to main content
Glama

Genkit MCP

Official
by firebase
formatter.go3.83 kB
// Copyright 2024 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package ai import ( "fmt" "github.com/firebase/genkit/go/core/api" ) const ( OutputFormatText string = "text" OutputFormatJSON string = "json" OutputFormatJSONL string = "jsonl" OutputFormatMedia string = "media" OutputFormatArray string = "array" OutputFormatEnum string = "enum" ) // Default formats get automatically registered on registry init var DEFAULT_FORMATS = []Formatter{ jsonFormatter{}, jsonlFormatter{}, textFormatter{}, arrayFormatter{}, enumFormatter{}, } // Formatter represents the Formatter interface. type Formatter interface { // Name returns the name of the formatter. Name() string // Handler returns the handler for the formatter. Handler(schema map[string]any) (FormatHandler, error) } // FormatHandler represents the handler part of the Formatter interface. type FormatHandler interface { // ParseMessage parses the message and returns a new formatted message. ParseMessage(message *Message) (*Message, error) // Instructions returns the formatter instructions to embed in the prompt. Instructions() string // Config returns the output config for the model request. Config() ModelOutputConfig } // ConfigureFormats registers default formats in the registry func ConfigureFormats(reg api.Registry) { for _, format := range DEFAULT_FORMATS { DefineFormat(reg, "/format/"+format.Name(), format) } } // DefineFormat defines and registers a new [Formatter]. func DefineFormat(r api.Registry, name string, formatter Formatter) { r.RegisterValue(name, formatter) } // resolveFormat returns a [Formatter], either a default one or one from the registry. func resolveFormat(reg api.Registry, schema map[string]any, format string) (Formatter, error) { var formatter any // If schema is set but no explicit format is set we default to json. if schema != nil && format == "" { formatter = reg.LookupValue("/format/" + OutputFormatJSON) } // If format is not set we default to text if format == "" { formatter = reg.LookupValue("/format/" + OutputFormatText) } // Lookup format in registry if format != "" { formatter = reg.LookupValue("/format/" + format) } if f, ok := formatter.(Formatter); ok { return f, nil } return nil, fmt.Errorf("output format %q is invalid", format) } // injectInstructions looks through the messages and injects formatting directives func injectInstructions(messages []*Message, instructions string) []*Message { if instructions == "" { return messages } // bail out if an output part is already present for _, m := range messages { for _, p := range m.Content { if p.Metadata != nil && p.Metadata["purpose"] == "output" { return messages } } } part := NewTextPart(instructions) part.Metadata = map[string]any{"purpose": "output"} targetIndex := -1 // First try to find a system message for i, m := range messages { if m.Role == RoleSystem { targetIndex = i break } } // If no system message, find the last user message if targetIndex == -1 { for i := len(messages) - 1; i >= 0; i-- { if messages[i].Role == RoleUser { targetIndex = i break } } } if targetIndex != -1 { messages[targetIndex].Content = append(messages[targetIndex].Content, part) } return messages }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/firebase/genkit'

If you have feedback or need assistance with the MCP directory API, please join our Discord server