Documentation
¶
Overview ¶
Package controllers contains the reconciliation logic for the MCPServer custom resource. It handles the creation, update, and deletion of MCP servers in Kubernetes.
Index ¶
- Constants
- Variables
- func CalculateConfigHash[T any](spec T) string
- func FindReferencingMCPServers(ctx context.Context, c client.Client, namespace string, configName string, ...) ([]mcpv1alpha1.MCPServer, error)
- func GetExternalAuthConfigForMCPServer(ctx context.Context, c client.Client, mcpServer *mcpv1alpha1.MCPServer) (*mcpv1alpha1.MCPExternalAuthConfig, error)
- func GetToolConfigForMCPServer(ctx context.Context, c client.Client, mcpServer *mcpv1alpha1.MCPServer) (*mcpv1alpha1.MCPToolConfig, error)
- type MCPExternalAuthConfigReconciler
- type MCPRegistryReconciler
- type MCPServerPodTemplateSpecBuilder
- func (b *MCPServerPodTemplateSpecBuilder) Build() *corev1.PodTemplateSpec
- func (b *MCPServerPodTemplateSpecBuilder) WithSecrets(secrets []mcpv1alpha1.SecretRef) *MCPServerPodTemplateSpecBuilder
- func (b *MCPServerPodTemplateSpecBuilder) WithServiceAccount(serviceAccount *string) *MCPServerPodTemplateSpecBuilder
- type MCPServerReconciler
- type ToolConfigReconciler
Constants ¶
const ( RestartedAtAnnotationKey = "mcpserver.toolhive.stacklok.dev/restarted-at" RestartStrategyAnnotationKey = "mcpserver.toolhive.stacklok.dev/restart-strategy" LastProcessedRestartAnnotationKey = "mcpserver.toolhive.stacklok.dev/last-processed-restart" )
Restart annotation keys for triggering pod restart
const ( RestartStrategyRolling = "rolling" RestartStrategyImmediate = "immediate" )
Restart strategy constants
const ( // DefaultControllerRetryAfterConstant is the constant default retry interval for controller operations that fail DefaultControllerRetryAfterConstant = time.Minute * 5 )
Default timing constants for the controller
const (
// ExternalAuthConfigFinalizerName is the name of the finalizer for MCPExternalAuthConfig
ExternalAuthConfigFinalizerName = "mcpexternalauthconfig.toolhive.stacklok.dev/finalizer"
)
const (
// ToolConfigFinalizerName is the name of the finalizer for MCPToolConfig
ToolConfigFinalizerName = "toolhive.stacklok.dev/toolconfig-finalizer"
)
Variables ¶
var ( // DefaultControllerRetryAfter is the configurable default retry interval for controller operations that fail // This can be modified in tests to speed up retry behavior DefaultControllerRetryAfter = DefaultControllerRetryAfterConstant )
Configurable timing variables for testing
Functions ¶
func CalculateConfigHash ¶ added in v0.3.9
CalculateConfigHash calculates a hash of any configuration spec using Kubernetes utilities. This function uses k8s.io/apimachinery/pkg/util/dump.ForHash which is designed for generating consistent string representations for hashing in Kubernetes. It then applies FNV-1a hash which is commonly used in Kubernetes for fast hashing. See: https://github.com/kubernetes/kubernetes/blob/master/pkg/controller/controller_utils.go
func FindReferencingMCPServers ¶ added in v0.3.9
func FindReferencingMCPServers( ctx context.Context, c client.Client, namespace string, configName string, refExtractor func(*mcpv1alpha1.MCPServer) *string, ) ([]mcpv1alpha1.MCPServer, error)
FindReferencingMCPServers finds MCPServers in the given namespace that reference a config resource. The refExtractor function should return the config name from an MCPServer if it references the config, or nil if it doesn't reference any config of this type.
Example usage for ToolConfig:
servers, err := FindReferencingMCPServers(ctx, client, namespace, configName,
func(server *mcpv1alpha1.MCPServer) *string {
if server.Spec.ToolConfigRef != nil {
return &server.Spec.ToolConfigRef.Name
}
return nil
})
func GetExternalAuthConfigForMCPServer ¶ added in v0.3.9
func GetExternalAuthConfigForMCPServer( ctx context.Context, c client.Client, mcpServer *mcpv1alpha1.MCPServer, ) (*mcpv1alpha1.MCPExternalAuthConfig, error)
GetExternalAuthConfigForMCPServer retrieves the MCPExternalAuthConfig referenced by an MCPServer. This function is exported for use by the MCPServer controller (Phase 5 integration).
func GetToolConfigForMCPServer ¶ added in v0.3.0
func GetToolConfigForMCPServer( ctx context.Context, c client.Client, mcpServer *mcpv1alpha1.MCPServer, ) (*mcpv1alpha1.MCPToolConfig, error)
GetToolConfigForMCPServer retrieves the MCPToolConfig referenced by an MCPServer
Types ¶
type MCPExternalAuthConfigReconciler ¶ added in v0.3.9
MCPExternalAuthConfigReconciler reconciles a MCPExternalAuthConfig object
func (*MCPExternalAuthConfigReconciler) Reconcile ¶ added in v0.3.9
func (r *MCPExternalAuthConfigReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error)
Reconcile is part of the main kubernetes reconciliation loop which aims to move the current state of the cluster closer to the desired state.
func (*MCPExternalAuthConfigReconciler) SetupWithManager ¶ added in v0.3.9
func (r *MCPExternalAuthConfigReconciler) SetupWithManager(mgr ctrl.Manager) error
SetupWithManager sets up the controller with the Manager.
type MCPRegistryReconciler ¶ added in v0.3.0
type MCPRegistryReconciler struct {
client.Client
Scheme *runtime.Scheme
// contains filtered or unexported fields
}
MCPRegistryReconciler reconciles a MCPRegistry object
func NewMCPRegistryReconciler ¶ added in v0.3.0
func NewMCPRegistryReconciler(k8sClient client.Client, scheme *runtime.Scheme) *MCPRegistryReconciler
NewMCPRegistryReconciler creates a new MCPRegistryReconciler with required dependencies
func (*MCPRegistryReconciler) Reconcile ¶ added in v0.3.0
func (r *MCPRegistryReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error)
Reconcile is part of the main kubernetes reconciliation loop which aims to move the current state of the cluster closer to the desired state.
func (*MCPRegistryReconciler) SetupWithManager ¶ added in v0.3.0
func (r *MCPRegistryReconciler) SetupWithManager(mgr ctrl.Manager) error
SetupWithManager sets up the controller with the Manager.
type MCPServerPodTemplateSpecBuilder ¶ added in v0.2.8
type MCPServerPodTemplateSpecBuilder struct {
// contains filtered or unexported fields
}
MCPServerPodTemplateSpecBuilder provides an interface for building PodTemplateSpec patches for MCP Servers
func NewMCPServerPodTemplateSpecBuilder ¶ added in v0.2.8
func NewMCPServerPodTemplateSpecBuilder(userTemplate *corev1.PodTemplateSpec) *MCPServerPodTemplateSpecBuilder
NewMCPServerPodTemplateSpecBuilder creates a new builder, optionally starting with a user-provided template
func (*MCPServerPodTemplateSpecBuilder) Build ¶ added in v0.2.8
func (b *MCPServerPodTemplateSpecBuilder) Build() *corev1.PodTemplateSpec
Build returns the final PodTemplateSpec, or nil if no customizations were made
func (*MCPServerPodTemplateSpecBuilder) WithSecrets ¶ added in v0.2.8
func (b *MCPServerPodTemplateSpecBuilder) WithSecrets(secrets []mcpv1alpha1.SecretRef) *MCPServerPodTemplateSpecBuilder
WithSecrets adds secret environment variables to the MCP container
func (*MCPServerPodTemplateSpecBuilder) WithServiceAccount ¶ added in v0.2.8
func (b *MCPServerPodTemplateSpecBuilder) WithServiceAccount(serviceAccount *string) *MCPServerPodTemplateSpecBuilder
WithServiceAccount sets the service account name
type MCPServerReconciler ¶
type MCPServerReconciler struct {
client.Client
Scheme *runtime.Scheme
ImageValidation validation.ImageValidation
// contains filtered or unexported fields
}
MCPServerReconciler reconciles a MCPServer object
func (*MCPServerReconciler) Reconcile ¶
Reconcile is part of the main kubernetes reconciliation loop which aims to move the current state of the cluster closer to the desired state.
func (*MCPServerReconciler) SetupWithManager ¶
func (r *MCPServerReconciler) SetupWithManager(mgr ctrl.Manager) error
SetupWithManager sets up the controller with the Manager.
type ToolConfigReconciler ¶ added in v0.3.0
ToolConfigReconciler reconciles a MCPToolConfig object
func (*ToolConfigReconciler) Reconcile ¶ added in v0.3.0
func (r *ToolConfigReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error)
Reconcile is part of the main kubernetes reconciliation loop which aims to move the current state of the cluster closer to the desired state.
func (*ToolConfigReconciler) SetupWithManager ¶ added in v0.3.0
func (r *ToolConfigReconciler) SetupWithManager(mgr ctrl.Manager) error
SetupWithManager sets up the controller with the Manager.