swarm_sdk 2.1.3 → 2.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. checksums.yaml +4 -4
  2. data/lib/swarm_sdk/agent/builder.rb +91 -0
  3. data/lib/swarm_sdk/agent/chat.rb +540 -925
  4. data/lib/swarm_sdk/agent/{chat → chat_helpers}/context_tracker.rb +33 -79
  5. data/lib/swarm_sdk/agent/chat_helpers/event_emitter.rb +204 -0
  6. data/lib/swarm_sdk/agent/{chat → chat_helpers}/hook_integration.rb +147 -39
  7. data/lib/swarm_sdk/agent/chat_helpers/instrumentation.rb +78 -0
  8. data/lib/swarm_sdk/agent/chat_helpers/llm_configuration.rb +233 -0
  9. data/lib/swarm_sdk/agent/{chat → chat_helpers}/logging_helpers.rb +1 -1
  10. data/lib/swarm_sdk/agent/chat_helpers/serialization.rb +83 -0
  11. data/lib/swarm_sdk/agent/{chat → chat_helpers}/system_reminder_injector.rb +22 -38
  12. data/lib/swarm_sdk/agent/chat_helpers/system_reminders.rb +79 -0
  13. data/lib/swarm_sdk/agent/chat_helpers/token_tracking.rb +98 -0
  14. data/lib/swarm_sdk/agent/context.rb +8 -4
  15. data/lib/swarm_sdk/agent/context_manager.rb +6 -0
  16. data/lib/swarm_sdk/agent/definition.rb +79 -155
  17. data/lib/swarm_sdk/agent/llm_instrumentation_middleware.rb +182 -0
  18. data/lib/swarm_sdk/agent/system_prompt_builder.rb +161 -0
  19. data/lib/swarm_sdk/builders/base_builder.rb +409 -0
  20. data/lib/swarm_sdk/concerns/cleanupable.rb +39 -0
  21. data/lib/swarm_sdk/concerns/snapshotable.rb +67 -0
  22. data/lib/swarm_sdk/concerns/validatable.rb +55 -0
  23. data/lib/swarm_sdk/configuration/parser.rb +353 -0
  24. data/lib/swarm_sdk/configuration/translator.rb +255 -0
  25. data/lib/swarm_sdk/configuration.rb +72 -257
  26. data/lib/swarm_sdk/context_compactor/token_counter.rb +3 -3
  27. data/lib/swarm_sdk/context_compactor.rb +6 -11
  28. data/lib/swarm_sdk/context_management/builder.rb +128 -0
  29. data/lib/swarm_sdk/context_management/context.rb +328 -0
  30. data/lib/swarm_sdk/defaults.rb +196 -0
  31. data/lib/swarm_sdk/events_to_messages.rb +199 -0
  32. data/lib/swarm_sdk/hooks/shell_executor.rb +2 -1
  33. data/lib/swarm_sdk/log_collector.rb +192 -16
  34. data/lib/swarm_sdk/log_stream.rb +66 -8
  35. data/lib/swarm_sdk/model_aliases.json +4 -1
  36. data/lib/swarm_sdk/node_context.rb +1 -1
  37. data/lib/swarm_sdk/observer/builder.rb +81 -0
  38. data/lib/swarm_sdk/observer/config.rb +45 -0
  39. data/lib/swarm_sdk/observer/manager.rb +236 -0
  40. data/lib/swarm_sdk/patterns/agent_observer.rb +160 -0
  41. data/lib/swarm_sdk/plugin.rb +93 -3
  42. data/lib/swarm_sdk/proc_helpers.rb +53 -0
  43. data/lib/swarm_sdk/restore_result.rb +65 -0
  44. data/lib/swarm_sdk/snapshot.rb +156 -0
  45. data/lib/swarm_sdk/snapshot_from_events.rb +397 -0
  46. data/lib/swarm_sdk/state_restorer.rb +476 -0
  47. data/lib/swarm_sdk/state_snapshot.rb +334 -0
  48. data/lib/swarm_sdk/swarm/agent_initializer.rb +428 -79
  49. data/lib/swarm_sdk/swarm/all_agents_builder.rb +28 -1
  50. data/lib/swarm_sdk/swarm/builder.rb +69 -407
  51. data/lib/swarm_sdk/swarm/executor.rb +213 -0
  52. data/lib/swarm_sdk/swarm/hook_triggers.rb +150 -0
  53. data/lib/swarm_sdk/swarm/logging_callbacks.rb +340 -0
  54. data/lib/swarm_sdk/swarm/mcp_configurator.rb +7 -4
  55. data/lib/swarm_sdk/swarm/swarm_registry_builder.rb +67 -0
  56. data/lib/swarm_sdk/swarm/tool_configurator.rb +88 -149
  57. data/lib/swarm_sdk/swarm.rb +337 -584
  58. data/lib/swarm_sdk/swarm_loader.rb +145 -0
  59. data/lib/swarm_sdk/swarm_registry.rb +136 -0
  60. data/lib/swarm_sdk/tools/bash.rb +11 -3
  61. data/lib/swarm_sdk/tools/delegate.rb +127 -24
  62. data/lib/swarm_sdk/tools/edit.rb +8 -13
  63. data/lib/swarm_sdk/tools/glob.rb +9 -1
  64. data/lib/swarm_sdk/tools/grep.rb +7 -0
  65. data/lib/swarm_sdk/tools/multi_edit.rb +15 -11
  66. data/lib/swarm_sdk/tools/path_resolver.rb +51 -2
  67. data/lib/swarm_sdk/tools/read.rb +28 -18
  68. data/lib/swarm_sdk/tools/registry.rb +122 -10
  69. data/lib/swarm_sdk/tools/stores/read_tracker.rb +47 -12
  70. data/lib/swarm_sdk/tools/stores/scratchpad_storage.rb +53 -5
  71. data/lib/swarm_sdk/tools/stores/storage.rb +0 -6
  72. data/lib/swarm_sdk/tools/todo_write.rb +7 -0
  73. data/lib/swarm_sdk/tools/web_fetch.rb +3 -2
  74. data/lib/swarm_sdk/tools/write.rb +8 -13
  75. data/lib/swarm_sdk/utils.rb +18 -0
  76. data/lib/swarm_sdk/validation_result.rb +33 -0
  77. data/lib/swarm_sdk/version.rb +1 -1
  78. data/lib/swarm_sdk/{node → workflow}/agent_config.rb +34 -9
  79. data/lib/swarm_sdk/workflow/builder.rb +143 -0
  80. data/lib/swarm_sdk/workflow/executor.rb +497 -0
  81. data/lib/swarm_sdk/{node/builder.rb → workflow/node_builder.rb} +42 -21
  82. data/lib/swarm_sdk/{node → workflow}/transformer_executor.rb +3 -2
  83. data/lib/swarm_sdk/workflow.rb +554 -0
  84. data/lib/swarm_sdk.rb +73 -11
  85. metadata +79 -16
  86. data/lib/swarm_sdk/mcp.rb +0 -16
  87. data/lib/swarm_sdk/node_orchestrator.rb +0 -591
  88. data/lib/swarm_sdk/providers/openai_with_responses.rb +0 -582
@@ -0,0 +1,33 @@
1
+ # frozen_string_literal: true
2
+
3
+ module SwarmSDK
4
+ # Internal result object for validation phase during snapshot restore
5
+ #
6
+ # Used during restore to track which agents can be restored and which
7
+ # need to be skipped due to configuration mismatches.
8
+ #
9
+ # @api private
10
+ class ValidationResult
11
+ attr_reader :warnings,
12
+ :skipped_agents,
13
+ :restorable_agents,
14
+ :skipped_delegations,
15
+ :restorable_delegations
16
+
17
+ # Initialize validation result
18
+ #
19
+ # @param warnings [Array<Hash>] Warning messages with details
20
+ # @param skipped_agents [Array<Symbol>] Names of agents that can't be restored
21
+ # @param restorable_agents [Array<Symbol>] Names of agents that can be restored
22
+ # @param skipped_delegations [Array<String>] Names of delegations that can't be restored
23
+ # @param restorable_delegations [Array<String>] Names of delegations that can be restored
24
+ def initialize(warnings:, skipped_agents:, restorable_agents:,
25
+ skipped_delegations:, restorable_delegations:)
26
+ @warnings = warnings
27
+ @skipped_agents = skipped_agents
28
+ @restorable_agents = restorable_agents
29
+ @skipped_delegations = skipped_delegations
30
+ @restorable_delegations = restorable_delegations
31
+ end
32
+ end
33
+ end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module SwarmSDK
4
- VERSION = "2.1.3"
4
+ VERSION = "2.3.0"
5
5
  end
@@ -1,12 +1,13 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module SwarmSDK
4
- module Node
4
+ class Workflow
5
5
  # AgentConfig provides fluent API for configuring agents within a node
6
6
  #
7
7
  # This class enables the chainable syntax:
8
8
  # agent(:backend).delegates_to(:tester, :database)
9
9
  # agent(:backend, reset_context: false) # Preserve context across nodes
10
+ # agent(:backend).tools(:Read, :Edit) # Override tools for this node
10
11
  #
11
12
  # @example Basic delegation
12
13
  # agent(:backend).delegates_to(:tester)
@@ -16,6 +17,12 @@ module SwarmSDK
16
17
  #
17
18
  # @example Preserve agent context
18
19
  # agent(:architect, reset_context: false)
20
+ #
21
+ # @example Override tools for this node
22
+ # agent(:backend).tools(:Read, :Think)
23
+ #
24
+ # @example Combine delegation and tool override
25
+ # agent(:backend).delegates_to(:tester).tools(:Read, :Edit, :Write)
19
26
  class AgentConfig
20
27
  attr_reader :agent_name
21
28
 
@@ -24,6 +31,7 @@ module SwarmSDK
24
31
  @node_builder = node_builder
25
32
  @delegates_to = []
26
33
  @reset_context = reset_context
34
+ @tools = nil # nil means use global agent definition tools
27
35
  @finalized = false
28
36
  end
29
37
 
@@ -33,21 +41,38 @@ module SwarmSDK
33
41
  # @return [self] For method chaining
34
42
  def delegates_to(*agent_names)
35
43
  @delegates_to = agent_names.map(&:to_sym)
36
- finalize
44
+ update_registration
37
45
  self
38
46
  end
39
47
 
40
- # Finalize agent configuration (called automatically)
48
+ # Override tools for this agent in this node
49
+ #
50
+ # @param tool_names [Array<Symbol>] Tool names to use (overrides global agent definition)
51
+ # @return [self] For method chaining
41
52
  #
42
- # Registers this agent configuration with the parent node builder.
43
- # If delegates_to was never called, registers with empty delegation.
53
+ # @example
54
+ # agent(:backend).tools(:Read, :Edit)
55
+ def tools(*tool_names)
56
+ @tools = tool_names.map(&:to_sym)
57
+ update_registration
58
+ self
59
+ end
60
+
61
+ # Update agent registration (called after each fluent method)
62
+ #
63
+ # Always updates the registration with current state.
64
+ # This allows chaining: .delegates_to(...).tools(...)
44
65
  #
45
66
  # @return [void]
46
- def finalize
47
- return if @finalized
67
+ def update_registration
68
+ @node_builder.register_agent(@agent_name, @delegates_to, @reset_context, @tools)
69
+ end
48
70
 
49
- @node_builder.register_agent(@agent_name, @delegates_to, @reset_context)
50
- @finalized = true
71
+ # Finalize agent configuration (backward compatibility)
72
+ #
73
+ # @return [void]
74
+ def finalize
75
+ update_registration
51
76
  end
52
77
  end
53
78
  end
@@ -0,0 +1,143 @@
1
+ # frozen_string_literal: true
2
+
3
+ module SwarmSDK
4
+ class Workflow
5
+ # Builder provides DSL for building multi-node workflows
6
+ # This is the top-level builder accessed via SwarmSDK.workflow
7
+ #
8
+ # The DSL enables:
9
+ # - Node-based workflow configuration
10
+ # - Agent delegation per node
11
+ # - Input/output transformers for data flow
12
+ # - Context preservation across nodes
13
+ #
14
+ # @example Multi-stage workflow
15
+ # workflow = SwarmSDK.workflow do
16
+ # name "Build Pipeline"
17
+ # start_node :planning
18
+ #
19
+ # agent :architect do
20
+ # model "gpt-5"
21
+ # prompt "You design systems"
22
+ # end
23
+ #
24
+ # agent :coder do
25
+ # model "gpt-4"
26
+ # prompt "You implement code"
27
+ # end
28
+ #
29
+ # node :planning do
30
+ # agent(:architect)
31
+ # end
32
+ #
33
+ # node :implementation do
34
+ # agent(:coder)
35
+ # depends_on :planning
36
+ # end
37
+ # end
38
+ #
39
+ # workflow.execute("Build auth system")
40
+ class Builder < Builders::BaseBuilder
41
+ # Main entry point for DSL
42
+ #
43
+ # @example
44
+ # workflow = SwarmSDK.workflow do
45
+ # name "Pipeline"
46
+ # start_node :planning
47
+ # node(:planning) { agent(:architect) }
48
+ # end
49
+ class << self
50
+ def build(allow_filesystem_tools: nil, &block)
51
+ builder = new(allow_filesystem_tools: allow_filesystem_tools)
52
+ builder.instance_eval(&block)
53
+ builder.build_swarm
54
+ end
55
+ end
56
+
57
+ def initialize(allow_filesystem_tools: nil)
58
+ super
59
+ @nodes = {}
60
+ @start_node = nil
61
+ end
62
+
63
+ # Define a node (mini-swarm execution stage)
64
+ #
65
+ # Nodes enable multi-stage workflows where different agent teams
66
+ # collaborate in sequence. Each node is an independent swarm execution.
67
+ #
68
+ # @param name [Symbol] Node name
69
+ # @yield Block for node configuration
70
+ # @return [void]
71
+ #
72
+ # @example Solo agent node
73
+ # node :planning do
74
+ # agent(:architect)
75
+ # end
76
+ #
77
+ # @example Multi-agent node with delegation
78
+ # node :implementation do
79
+ # agent(:backend).delegates_to(:tester, :database)
80
+ # agent(:tester).delegates_to(:database)
81
+ # agent(:database)
82
+ # depends_on :planning
83
+ # end
84
+ def node(name, &block)
85
+ builder = Workflow::NodeBuilder.new(name)
86
+ builder.instance_eval(&block)
87
+ @nodes[name] = builder
88
+ end
89
+
90
+ # Set the starting node for workflow execution
91
+ #
92
+ # Required when nodes are defined. Specifies which node to execute first.
93
+ #
94
+ # @param name [Symbol] Name of starting node
95
+ # @return [void]
96
+ #
97
+ # @example
98
+ # start_node :planning
99
+ def start_node(name)
100
+ @start_node = name.to_sym
101
+ end
102
+
103
+ # Build the actual Workflow instance
104
+ def build_swarm # Returns Workflow despite method name
105
+ raise ConfigurationError, "Workflow name not set. Use: name 'My Workflow'" unless @swarm_name
106
+ raise ConfigurationError, "No nodes defined. Use: node :name { ... }" if @nodes.empty?
107
+ raise ConfigurationError, "start_node not set. Use: start_node :name" unless @start_node
108
+
109
+ # Validate filesystem tools BEFORE building
110
+ validate_all_agents_filesystem_tools if @all_agents_config
111
+ validate_agent_filesystem_tools
112
+
113
+ build_workflow
114
+ end
115
+
116
+ private
117
+
118
+ # Build a node-based workflow
119
+ #
120
+ # @return [Workflow] Configured workflow instance
121
+ def build_workflow
122
+ # Build agent definitions
123
+ agent_definitions = build_agent_definitions
124
+
125
+ # Create workflow
126
+ workflow = Workflow.new(
127
+ swarm_name: @swarm_name,
128
+ swarm_id: @swarm_id,
129
+ agent_definitions: agent_definitions,
130
+ nodes: @nodes,
131
+ start_node: @start_node,
132
+ scratchpad: @scratchpad,
133
+ allow_filesystem_tools: @allow_filesystem_tools,
134
+ )
135
+
136
+ # Pass swarm registry config to workflow if external swarms registered
137
+ workflow.swarm_registry_config = @swarm_registry_config if @swarm_registry_config.any?
138
+
139
+ workflow
140
+ end
141
+ end
142
+ end
143
+ end