mirror of
https://github.com/go-micro/go-micro.git
synced 2026-04-30 19:15:24 +02:00
1bb25d6e7f
* feat: add agent platform showcase and blog post Add a complete platform example (Users, Posts, Comments, Mail) that mirrors micro/blog, demonstrating how existing microservices become AI-accessible through MCP with zero code changes. Includes blog post "Your Microservices Are Already an AI Platform" walking through real agent workflows: signup, content creation, commenting, tagging, and cross-service messaging. https://claude.ai/code/session_01GkduEhcrqcG45rdfYh8dAc * refactor: rename handler types to drop redundant Service suffix UserService → Users, PostService → Posts, CommentService → Comments, MailService → Mail. Matches micro/blog naming convention. https://claude.ai/code/session_01GkduEhcrqcG45rdfYh8dAc * refactor: consolidate top-level directories, reduce framework bloat Move internal/non-public packages behind internal/ or into their parent packages where they belong: - deploy/ → gateway/mcp/deploy/ (Helm charts belong with the gateway) - profile/ → service/profile/ (preset plugin profiles are a service concern) - scripts/ → internal/scripts/ (install script is not public API) - test/ → internal/test/ (test harness is not public API) - util/ → internal/util/ (internal helpers shouldn't be imported externally) Also fixes CLAUDE.md merge conflict markers and updates project structure documentation. All import paths updated. Build and tests pass. https://claude.ai/code/session_01GkduEhcrqcG45rdfYh8dAc * refactor: redesign model package to match framework conventions Rename model.Database interface to model.Model (consistent with client.Client, server.Server, store.Store). Remove generics in favor of interface{}-based API with reflection. Key changes: - model.Model interface: Register once, CRUD infers table from type - DefaultModel + NewModel() + package-level convenience functions - Schema registered via Register(&User{}), no per-call schema passing - Memory implementation as default (in model package, like store) - memory/sqlite/postgres backends updated for new interface - protoc-gen-micro generates RegisterXModel() instead of generic factory - All docs, blog, and README updated https://claude.ai/code/session_01GkduEhcrqcG45rdfYh8dAc --------- Co-authored-by: Claude <noreply@anthropic.com>
87 lines
3.1 KiB
Go
87 lines
3.1 KiB
Go
// Package model is an interface for structured data storage with schema awareness.
|
|
package model
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
)
|
|
|
|
var (
|
|
// ErrNotFound is returned when a record doesn't exist.
|
|
ErrNotFound = errors.New("not found")
|
|
// ErrDuplicateKey is returned when a record with the same key already exists.
|
|
ErrDuplicateKey = errors.New("duplicate key")
|
|
// ErrNotRegistered is returned when a table has not been registered.
|
|
ErrNotRegistered = errors.New("table not registered")
|
|
// DefaultModel is the default model.
|
|
DefaultModel Model = NewModel()
|
|
)
|
|
|
|
// Model is a structured data storage interface.
|
|
type Model interface {
|
|
// Init initializes the model.
|
|
Init(...Option) error
|
|
// Register registers a struct type as a table.
|
|
Register(v interface{}, opts ...RegisterOption) error
|
|
// Create inserts a new record. Returns ErrDuplicateKey if key exists.
|
|
Create(ctx context.Context, v interface{}) error
|
|
// Read retrieves a record by key into v. Returns ErrNotFound if missing.
|
|
Read(ctx context.Context, key string, v interface{}) error
|
|
// Update modifies an existing record. Returns ErrNotFound if missing.
|
|
Update(ctx context.Context, v interface{}) error
|
|
// Delete removes a record by key. v is a pointer to the struct type.
|
|
Delete(ctx context.Context, key string, v interface{}) error
|
|
// List retrieves records matching the query. result must be a pointer to a slice of struct pointers.
|
|
List(ctx context.Context, result interface{}, opts ...QueryOption) error
|
|
// Count returns the number of matching records. v is a pointer to the struct type.
|
|
Count(ctx context.Context, v interface{}, opts ...QueryOption) (int64, error)
|
|
// Close closes the model.
|
|
Close() error
|
|
// String returns the name of the implementation.
|
|
String() string
|
|
}
|
|
|
|
type Option func(*Options)
|
|
|
|
type RegisterOption func(*Schema)
|
|
|
|
// NewModel returns the default in-memory model.
|
|
func NewModel(opts ...Option) Model {
|
|
return newMemoryModel(opts...)
|
|
}
|
|
|
|
// Register registers a struct type with the default model.
|
|
func Register(v interface{}, opts ...RegisterOption) error {
|
|
return DefaultModel.Register(v, opts...)
|
|
}
|
|
|
|
// Create inserts a new record using the default model.
|
|
func Create(ctx context.Context, v interface{}) error {
|
|
return DefaultModel.Create(ctx, v)
|
|
}
|
|
|
|
// Read retrieves a record by key using the default model.
|
|
func Read(ctx context.Context, key string, v interface{}) error {
|
|
return DefaultModel.Read(ctx, key, v)
|
|
}
|
|
|
|
// Update modifies an existing record using the default model.
|
|
func Update(ctx context.Context, v interface{}) error {
|
|
return DefaultModel.Update(ctx, v)
|
|
}
|
|
|
|
// Delete removes a record by key using the default model.
|
|
func Delete(ctx context.Context, key string, v interface{}) error {
|
|
return DefaultModel.Delete(ctx, key, v)
|
|
}
|
|
|
|
// List retrieves records matching the query using the default model.
|
|
func List(ctx context.Context, result interface{}, opts ...QueryOption) error {
|
|
return DefaultModel.List(ctx, result, opts...)
|
|
}
|
|
|
|
// Count returns the number of matching records using the default model.
|
|
func Count(ctx context.Context, v interface{}, opts ...QueryOption) (int64, error) {
|
|
return DefaultModel.Count(ctx, v, opts...)
|
|
}
|