Skip to main content
Glama

Genkit MCP

Official
by firebase
auth.go2.53 kB
// Copyright 2025 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. // // SPDX-License-Identifier: Apache-2.0 package firebase import ( "context" "encoding/json" "fmt" "strings" "firebase.google.com/go/v4/auth" "github.com/firebase/genkit/go/core" "github.com/firebase/genkit/go/genkit" ) // AuthContext is the context of an authenticated request. type AuthContext = *auth.Token // AuthPolicy is a function that validates an incoming request. type AuthPolicy = func(context.Context, AuthContext, json.RawMessage) error // AuthClient is a client for the Firebase Auth service. type AuthClient interface { VerifyIDToken(context.Context, string) (*auth.Token, error) } // ContextProvider creates a Firebase context provider for Genkit actions. func ContextProvider(ctx context.Context, g *genkit.Genkit, policy AuthPolicy) (core.ContextProvider, error) { f, ok := genkit.LookupPlugin(g, provider).(*Firebase) if !ok { return nil, core.NewError(core.NOT_FOUND, "firebase plugin not initialized; did you pass the plugin to genkit.Init()") } client, err := f.App.Auth(ctx) if err != nil { return nil, err } return func(ctx context.Context, input core.RequestData) (core.ActionContext, error) { authHeader, ok := input.Headers["authorization"] if !ok { return nil, core.NewPublicError(core.UNAUTHENTICATED, "authorization header is required but not provided", nil) } const bearerPrefix = "bearer " if !strings.HasPrefix(strings.ToLower(authHeader), bearerPrefix) { return nil, core.NewPublicError(core.UNAUTHENTICATED, "invalid authorization header format", nil) } token := authHeader[len(bearerPrefix):] authCtx, err := client.VerifyIDToken(ctx, token) if err != nil { return nil, core.NewPublicError(core.UNAUTHENTICATED, fmt.Sprintf("error verifying ID token: %v", err), nil) } if policy != nil { if err := policy(ctx, authCtx, input.Input); err != nil { return nil, err } } return core.ActionContext{ "auth": authCtx, }, nil }, nil }

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