kafka_event_hub 0.1.1 → 1.0.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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 66d9e6a2a53b7f272ac80c20df1ff9e2df765fdc9e42f5204224fe7c18c85025
4
- data.tar.gz: 2af12a3ee6d2bbef2f6f1ea8dc0810e912f82b29583f48896aa14087592d21c1
3
+ metadata.gz: 8e482b41980cd0dfe27e3a501fab289ee5ebd7d81e58aa9d1d88c9fe485d95c9
4
+ data.tar.gz: 1e3f4ae0f1c8442684365277b2d94ad1ec33812a6111af891ee6af1c3be6c31e
5
5
  SHA512:
6
- metadata.gz: c1438e6035c152e0d41a0cdd0eb4e0c192610a35192a3028cc8a696c94ecdba7d1ca449a8531410e0e35fecdbb31ee4ea3d3e9071be73d6fdcc5673c6e7ffee5
7
- data.tar.gz: 779eeef6dcbbfcd4059769b6a812af78f2921e6a784dd5b5f30acc89a020f83f8734bc2727989f7f5109f25ca9b1f5f10440c3c85f00e8ed07c9c0126f75d063
6
+ metadata.gz: 22f2611efe7633c8c17b07c49deaec98e55361b6ee3c77739fdb584b05b8ec3b5f38e834e675cbd65ae89e565582a21fe87a3f41e857a3aafc0cec15a3ecc98d
7
+ data.tar.gz: dba58745fe1c8d7bcda9cddd50943d5ab67d4f48c5b71f67e21a0ec8e290d3a456b65c2ff798509e3a5d978b2bb13a2d383e7f2bcefec1d9069edc9e09ff3cc8
@@ -36,4 +36,5 @@ Gem::Specification.new do |spec|
36
36
  spec.add_development_dependency "bundler", "~> 1.17"
37
37
  spec.add_development_dependency "rake", "~> 10.0"
38
38
  spec.add_development_dependency "rspec", "~> 3.0"
39
+ spec.add_dependency 'uri', '~> 1.0.3'
39
40
  end
@@ -0,0 +1,35 @@
1
+ # lib/kafka_event_hub/consumer.rb
2
+ module KafkaEventHub
3
+ class Consumer < Config
4
+ def initialize(topic = nil)
5
+ super('consumer' => true, 'topic' => topic)
6
+ end
7
+
8
+ # Generic message consuming loop - pass a block to process messages
9
+ def each_message
10
+ consumer = @kafka.consumer
11
+ consumer.subscribe(@topic)
12
+
13
+ consumer.each do |message|
14
+ yield message
15
+ end
16
+ ensure
17
+ consumer&.close
18
+ end
19
+
20
+ # Optional: poll with timeout
21
+ def poll_messages(timeout = POLL_TIMEOUT)
22
+ consumer = @kafka.consumer
23
+ consumer.subscribe(@topic)
24
+
25
+ loop do
26
+ message = consumer.poll(timeout)
27
+ break unless message
28
+
29
+ yield message
30
+ end
31
+ ensure
32
+ consumer&.close
33
+ end
34
+ end
35
+ end
@@ -0,0 +1,25 @@
1
+ # lib/kafka_event_hub/producer.rb
2
+
3
+ module KafkaEventHub
4
+ class Producer < Config
5
+ def initialize(topic = nil)
6
+ super('producer' => true, 'topic' => topic)
7
+ end
8
+
9
+ # Produce any message to Kafka
10
+ def produce(topic: nil, key:, payload:, partition: nil)
11
+ real_topic = topic || @topic
12
+ producer = @kafka.producer
13
+ json = payload.is_a?(String) ? payload : payload.to_json
14
+
15
+ producer.produce(
16
+ topic: real_topic,
17
+ key: key,
18
+ payload: json,
19
+ partition: partition
20
+ ).wait
21
+ ensure
22
+ producer&.close
23
+ end
24
+ end
25
+ end
@@ -1,3 +1,3 @@
1
1
  module KafkaEventHub
2
- VERSION = "0.1.1"
2
+ VERSION = "1.0.0"
3
3
  end
@@ -2,6 +2,8 @@ require "kafka_event_hub/version"
2
2
  # lib/kafka_event_hub.rb
3
3
  require_relative "kafka_event_hub/version"
4
4
  require_relative "kafka_event_hub/config"
5
+ require_relative "kafka_event_hub/producer"
6
+ require_relative "kafka_event_hub/consumer"
5
7
 
6
8
 
7
9
  module KafkaEventHub
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: kafka_event_hub
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 1.0.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Marryam Shahzad
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2025-05-02 00:00:00.000000000 Z
11
+ date: 2025-05-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rdkafka
@@ -66,6 +66,20 @@ dependencies:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
68
  version: '3.0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: uri
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: 1.0.3
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: 1.0.3
69
83
  description: 'Centralizes ENV-based Rd-kafka setup into a single gem.
70
84
 
71
85
  '
@@ -92,6 +106,8 @@ files:
92
106
  - kafka_event_hub.gemspec
93
107
  - lib/kafka_event_hub.rb
94
108
  - lib/kafka_event_hub/config.rb
109
+ - lib/kafka_event_hub/consumer.rb
110
+ - lib/kafka_event_hub/producer.rb
95
111
  - lib/kafka_event_hub/version.rb
96
112
  homepage: https://rubygems.org/gems/kafka_event_hub
97
113
  licenses: