natswork-server 0.0.1

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.
@@ -0,0 +1,62 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'concurrent'
4
+ require_relative 'simple_worker'
5
+
6
+ module NatsWork
7
+ module Server
8
+ class WorkerManager
9
+ attr_reader :workers, :pool, :running
10
+
11
+ def initialize(concurrency: 5)
12
+ @concurrency = concurrency
13
+ @workers = []
14
+ @running = false
15
+ @pool = Concurrent::FixedThreadPool.new(concurrency)
16
+ @shutdown_mutex = Mutex.new
17
+ end
18
+
19
+ def start
20
+ @shutdown_mutex.synchronize do
21
+ return if @running
22
+
23
+ @running = true
24
+
25
+ @concurrency.times do |i|
26
+ worker = SimpleWorker.new(id: "worker-#{i + 1}", pool: @pool)
27
+ @workers << worker
28
+ worker.start
29
+ end
30
+ end
31
+ end
32
+
33
+ def stop
34
+ @shutdown_mutex.synchronize do
35
+ return unless @running
36
+
37
+ @running = false
38
+
39
+ NatsWork.logger.info 'Stopping workers...'
40
+ @workers.each(&:stop)
41
+ @pool.shutdown
42
+ @pool.wait_for_termination(10)
43
+ @workers.clear
44
+ end
45
+ end
46
+
47
+ def running?
48
+ @running
49
+ end
50
+
51
+ def stats
52
+ {
53
+ running: @running,
54
+ workers: @workers.size,
55
+ pool_size: @pool.length,
56
+ queue_length: @pool.queue_length,
57
+ completed_tasks: @pool.completed_task_count
58
+ }
59
+ end
60
+ end
61
+ end
62
+ end
@@ -0,0 +1,5 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Main entry point for natswork-server gem
4
+ require 'natswork' # Load client first for shared components
5
+ require_relative 'natswork/server'
metadata ADDED
@@ -0,0 +1,151 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: natswork-server
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - NatsWork Contributors
8
+ bindir: exe
9
+ cert_chain: []
10
+ date: 2025-09-30 00:00:00.000000000 Z
11
+ dependencies:
12
+ - !ruby/object:Gem::Dependency
13
+ name: concurrent-ruby
14
+ requirement: !ruby/object:Gem::Requirement
15
+ requirements:
16
+ - - "~>"
17
+ - !ruby/object:Gem::Version
18
+ version: '1.2'
19
+ type: :runtime
20
+ prerelease: false
21
+ version_requirements: !ruby/object:Gem::Requirement
22
+ requirements:
23
+ - - "~>"
24
+ - !ruby/object:Gem::Version
25
+ version: '1.2'
26
+ - !ruby/object:Gem::Dependency
27
+ name: multi_json
28
+ requirement: !ruby/object:Gem::Requirement
29
+ requirements:
30
+ - - "~>"
31
+ - !ruby/object:Gem::Version
32
+ version: '1.15'
33
+ type: :runtime
34
+ prerelease: false
35
+ version_requirements: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - "~>"
38
+ - !ruby/object:Gem::Version
39
+ version: '1.15'
40
+ - !ruby/object:Gem::Dependency
41
+ name: nats-pure
42
+ requirement: !ruby/object:Gem::Requirement
43
+ requirements:
44
+ - - "~>"
45
+ - !ruby/object:Gem::Version
46
+ version: '2.4'
47
+ type: :runtime
48
+ prerelease: false
49
+ version_requirements: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - "~>"
52
+ - !ruby/object:Gem::Version
53
+ version: '2.4'
54
+ - !ruby/object:Gem::Dependency
55
+ name: bundler
56
+ requirement: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - "~>"
59
+ - !ruby/object:Gem::Version
60
+ version: '2.0'
61
+ type: :development
62
+ prerelease: false
63
+ version_requirements: !ruby/object:Gem::Requirement
64
+ requirements:
65
+ - - "~>"
66
+ - !ruby/object:Gem::Version
67
+ version: '2.0'
68
+ - !ruby/object:Gem::Dependency
69
+ name: rake
70
+ requirement: !ruby/object:Gem::Requirement
71
+ requirements:
72
+ - - "~>"
73
+ - !ruby/object:Gem::Version
74
+ version: '13.0'
75
+ type: :development
76
+ prerelease: false
77
+ version_requirements: !ruby/object:Gem::Requirement
78
+ requirements:
79
+ - - "~>"
80
+ - !ruby/object:Gem::Version
81
+ version: '13.0'
82
+ - !ruby/object:Gem::Dependency
83
+ name: rspec
84
+ requirement: !ruby/object:Gem::Requirement
85
+ requirements:
86
+ - - "~>"
87
+ - !ruby/object:Gem::Version
88
+ version: '3.12'
89
+ type: :development
90
+ prerelease: false
91
+ version_requirements: !ruby/object:Gem::Requirement
92
+ requirements:
93
+ - - "~>"
94
+ - !ruby/object:Gem::Version
95
+ version: '3.12'
96
+ description: Process jobs from NATS queues with workers
97
+ email:
98
+ - natswork@tesote.com
99
+ executables: []
100
+ extensions: []
101
+ extra_rdoc_files: []
102
+ files:
103
+ - CHANGELOG.md
104
+ - LICENSE
105
+ - README.md
106
+ - lib/natswork-server.rb
107
+ - lib/natswork/cli.rb
108
+ - lib/natswork/error_tracker.rb
109
+ - lib/natswork/health_check.rb
110
+ - lib/natswork/instrumentation.rb
111
+ - lib/natswork/job_executor.rb
112
+ - lib/natswork/job_hooks.rb
113
+ - lib/natswork/logger.rb
114
+ - lib/natswork/metrics.rb
115
+ - lib/natswork/middleware.rb
116
+ - lib/natswork/middleware_chain.rb
117
+ - lib/natswork/monitoring.rb
118
+ - lib/natswork/protocol.rb
119
+ - lib/natswork/queue_manager.rb
120
+ - lib/natswork/retry_handler.rb
121
+ - lib/natswork/server.rb
122
+ - lib/natswork/server/version.rb
123
+ - lib/natswork/simple_worker.rb
124
+ - lib/natswork/thread_pool.rb
125
+ - lib/natswork/worker.rb
126
+ - lib/natswork/worker_manager.rb
127
+ homepage: https://github.com/tesote/nats-work
128
+ licenses:
129
+ - MIT
130
+ metadata:
131
+ homepage_uri: https://github.com/tesote/nats-work
132
+ source_code_uri: https://github.com/tesote/nats-work
133
+ changelog_uri: https://github.com/tesote/nats-work/blob/main/CHANGELOG.md
134
+ rdoc_options: []
135
+ require_paths:
136
+ - lib
137
+ required_ruby_version: !ruby/object:Gem::Requirement
138
+ requirements:
139
+ - - ">="
140
+ - !ruby/object:Gem::Version
141
+ version: 2.7.0
142
+ required_rubygems_version: !ruby/object:Gem::Requirement
143
+ requirements:
144
+ - - ">="
145
+ - !ruby/object:Gem::Version
146
+ version: '0'
147
+ requirements: []
148
+ rubygems_version: 3.6.2
149
+ specification_version: 4
150
+ summary: Server gem for NatsWork job processing system
151
+ test_files: []