mirror of
https://github.com/johndoe6345789/metabuilder.git
synced 2026-04-25 06:14:59 +00:00
refactor(workflow): convert all plugins to class/struct + factory pattern
- Python: class extending NodeExecutor + factory.py (80+ plugins) - TypeScript: class implements NodeExecutor + factory.ts (7 groups, 116 classes) - Go: struct with methods + factory.go (36 plugins) - Rust: struct impl NodeExecutor trait + factory.rs (54 plugins) - Mojo: struct + factory.mojo (11 plugins) All package.json files now include: - files array listing source files - metadata.class/struct field - metadata.entrypoint field This enables a unified plugin loading system across all languages with no import side effects (Spring-style DI pattern). Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
This commit is contained in:
7
workflow/plugins/go/string/string_replace/factory.go
Normal file
7
workflow/plugins/go/string/string_replace/factory.go
Normal file
@@ -0,0 +1,7 @@
|
||||
// Package string_replace provides factory for StringReplace plugin.
|
||||
package string_replace
|
||||
|
||||
// Create returns a new StringReplace instance.
|
||||
func Create() *StringReplace {
|
||||
return NewStringReplace()
|
||||
}
|
||||
@@ -6,8 +6,11 @@
|
||||
"license": "MIT",
|
||||
"keywords": ["string", "workflow", "plugin"],
|
||||
"main": "string_replace.go",
|
||||
"files": ["string_replace.go", "factory.go"],
|
||||
"metadata": {
|
||||
"plugin_type": "string.replace",
|
||||
"category": "string"
|
||||
"category": "string",
|
||||
"struct": "StringReplace",
|
||||
"entrypoint": "Execute"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,17 +1,31 @@
|
||||
// Package string_replace provides the replace string plugin.
|
||||
// Package string_replace provides a workflow plugin for replacing strings.
|
||||
package string_replace
|
||||
|
||||
import (
|
||||
"strings"
|
||||
|
||||
plugin "metabuilder/workflow/plugins/go"
|
||||
)
|
||||
|
||||
// Run replaces occurrences in a string.
|
||||
func Run(runtime *plugin.Runtime, inputs map[string]interface{}) (map[string]interface{}, error) {
|
||||
// StringReplace implements the NodeExecutor interface for replacing strings.
|
||||
type StringReplace struct {
|
||||
NodeType string
|
||||
Category string
|
||||
Description string
|
||||
}
|
||||
|
||||
// NewStringReplace creates a new StringReplace instance.
|
||||
func NewStringReplace() *StringReplace {
|
||||
return &StringReplace{
|
||||
NodeType: "string.replace",
|
||||
Category: "string",
|
||||
Description: "Replace occurrences in a string",
|
||||
}
|
||||
}
|
||||
|
||||
// Execute runs the plugin logic.
|
||||
func (p *StringReplace) Execute(inputs map[string]interface{}, runtime interface{}) map[string]interface{} {
|
||||
str, ok := inputs["string"].(string)
|
||||
if !ok {
|
||||
return map[string]interface{}{"result": "", "error": "string is required"}, nil
|
||||
return map[string]interface{}{"result": "", "error": "string is required"}
|
||||
}
|
||||
|
||||
old, _ := inputs["old"].(string)
|
||||
@@ -24,5 +38,5 @@ func Run(runtime *plugin.Runtime, inputs map[string]interface{}) (map[string]int
|
||||
}
|
||||
|
||||
result := strings.Replace(str, old, new, count)
|
||||
return map[string]interface{}{"result": result}, nil
|
||||
return map[string]interface{}{"result": result}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user