redis_stream 0.1.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 ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 49b0969e58e3218a98bca0a7fee77b867319d714939bb2f362d26caefda7276e
4
+ data.tar.gz: ae4dfad5e0111d8d194dd2efb42c760169d6ff1779be54c7f0be880b85543865
5
+ SHA512:
6
+ metadata.gz: 0ccc6e83373da211edac19337381cb91be66cf54348be8014e41241f41ad5fd3499026d4efde8251e79911bf79f1ec450ad58f3b7f914b468407ac9a46093f02
7
+ data.tar.gz: 2716f3534212900fd4b5079f201acd072f9cc193ef75c9daf6eee303a8a358e7bdcc3570c81e20c8df682759572398c4ad87036f9103ade017cca4b28149816b
data/.gitignore ADDED
@@ -0,0 +1,8 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /_yardoc/
4
+ /coverage/
5
+ /doc/
6
+ /pkg/
7
+ /spec/reports/
8
+ /tmp/
data/.travis.yml ADDED
@@ -0,0 +1,9 @@
1
+ ---
2
+ sudo: false
3
+ services:
4
+ - redis-server
5
+ language: ruby
6
+ cache: bundler
7
+ rvm:
8
+ - 2.6.5
9
+ before_install: gem install bundler -v 1.17.3
data/Gemfile ADDED
@@ -0,0 +1,6 @@
1
+ source "https://rubygems.org"
2
+
3
+ git_source(:github) {|repo_name| "https://github.com/#{repo_name}" }
4
+
5
+ # Specify your gem's dependencies in redis_stream.gemspec
6
+ gemspec
data/Gemfile.lock ADDED
@@ -0,0 +1,30 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ redis_stream (0.1.0)
5
+ redis (~> 4.1)
6
+
7
+ GEM
8
+ remote: https://rubygems.org/
9
+ specs:
10
+ coderay (1.1.2)
11
+ method_source (0.9.2)
12
+ minitest (5.13.0)
13
+ pry (0.12.2)
14
+ coderay (~> 1.1.0)
15
+ method_source (~> 0.9.0)
16
+ rake (10.5.0)
17
+ redis (4.1.3)
18
+
19
+ PLATFORMS
20
+ ruby
21
+
22
+ DEPENDENCIES
23
+ bundler (~> 1.17)
24
+ minitest (~> 5.0)
25
+ pry (~> 0.12)
26
+ rake (~> 10.0)
27
+ redis_stream!
28
+
29
+ BUNDLED WITH
30
+ 1.17.3
data/README.md ADDED
@@ -0,0 +1,69 @@
1
+ # RedisStream
2
+
3
+ <p align="center">
4
+ <a href="https://codeclimate.com/github/tomorrowhq/redis-stream/maintainability"><img src="https://api.codeclimate.com/v1/badges/73f0d460cf35b758e624/maintainability" /></a>
5
+ <a href="https://codeclimate.com/github/tomorrowhq/redis-stream/test_coverage"><img src="https://api.codeclimate.com/v1/badges/73f0d460cf35b758e624/test_coverage" /></a>
6
+ </p>
7
+
8
+ ## Status
9
+
10
+ Currently project is under active development.
11
+
12
+ ## Usage
13
+
14
+ ### Setting up
15
+
16
+ Under the hood RedisStream is using redis gem, which means that you can use it
17
+ out of the box if you are using redis. It will be using same `REDIS_URL`
18
+ environment variable to establish connection with Redis.
19
+
20
+ ```ruby
21
+ require 'redis_stream'
22
+
23
+ client = RedisStream.new
24
+ ```
25
+
26
+ When you need to have control over redis connection you can pass redis instance
27
+ in initializer.
28
+
29
+ ```ruby
30
+ require 'redis_stream'
31
+
32
+ redis = Redis.new # set it up as you need
33
+ client = RedisStream.new(redis)
34
+ ```
35
+
36
+ ### Adding messages to the stream
37
+
38
+ ```ruby
39
+ require 'redis_stream'
40
+
41
+ client = RedisStream.new
42
+
43
+ weather_stream = client.stream('weather')
44
+
45
+ weather_stream.add(20.0)
46
+ weather_stream.add(21.0)
47
+ weather_stream.add(22.0)
48
+
49
+ puts weather_stream.len
50
+ #=> 3
51
+ ```
52
+
53
+ ### Consuming messages from the stream
54
+
55
+ ```ruby
56
+ require 'redis_stream'
57
+
58
+ client = RedisStream.new
59
+ messages_stream = client.stream('messages')
60
+
61
+ messages_stream.add('Message 1')
62
+ messages_stream.add('Message 2')
63
+
64
+ messages_stream.each_message do |message|
65
+ puts message
66
+ end
67
+ # => Message 1
68
+ # => Message 2
69
+ ```
data/Rakefile ADDED
@@ -0,0 +1,10 @@
1
+ require "bundler/gem_tasks"
2
+ require "rake/testtask"
3
+
4
+ Rake::TestTask.new(:test) do |t|
5
+ t.libs << "test"
6
+ t.libs << "lib"
7
+ t.test_files = FileList["test/**/*_test.rb"]
8
+ end
9
+
10
+ task :default => :test
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "redis_stream"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start(__FILE__)
data/bin/setup ADDED
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,7 @@
1
+ version: '3'
2
+
3
+ services:
4
+ redis:
5
+ image: redis:5-alpine
6
+ ports:
7
+ - 6379:6379
@@ -0,0 +1,16 @@
1
+ module RedisStream
2
+ class Client
3
+ def initialize(redis)
4
+ @redis = redis
5
+ end
6
+
7
+ def stream(key)
8
+ Stream.new(redis: @redis, key: key)
9
+ end
10
+
11
+ def group(key:, name:)
12
+ new_group = Group.new(redis: @redis, key: key, name: name)
13
+ new_group.create
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,54 @@
1
+ module RedisStream
2
+ class Group
3
+ attr_reader :key, :name
4
+
5
+ def initialize(redis:, key:, name:)
6
+ @redis = redis
7
+ @key = key
8
+ @name = name
9
+ @last_delivered_id = '0'
10
+ end
11
+
12
+ # Creates group and stream if group does not exist.
13
+ # @return [Group]
14
+ def create
15
+ if info.nil?
16
+ @redis.xgroup(:create, key, name, @last_delivered_id, mkstream: true)
17
+ end
18
+
19
+ self
20
+ end
21
+
22
+ # @return [Group]
23
+ def destroy
24
+ @redis.xgroup(:destroy, key, name)
25
+ self
26
+ end
27
+
28
+ def info
29
+ find_me(@redis.xinfo(:groups, key))
30
+ rescue Redis::CommandError
31
+ nil
32
+ end
33
+
34
+ def each_message(consumer: 'c1', ack: true)
35
+ while
36
+ result = @redis.xreadgroup(name, consumer, key, '>')
37
+ break if result.empty?
38
+
39
+ messages = result[key]
40
+ messages.each do |message|
41
+ id, entry = message
42
+ yield(entry['value'])
43
+ @redis.xack(key, name, id) if ack
44
+ end
45
+ end
46
+ end
47
+
48
+ private
49
+
50
+ def find_me(groups)
51
+ groups.find { |group| group['name'] == name }
52
+ end
53
+ end
54
+ end
@@ -0,0 +1,37 @@
1
+ module RedisStream
2
+ class Stream
3
+ attr_reader :key
4
+
5
+ def initialize(key:, redis:)
6
+ @key = key
7
+ @redis = redis
8
+ end
9
+
10
+ def add(entry)
11
+ @redis.xadd(key, value: entry)
12
+ end
13
+
14
+ def len
15
+ @redis.xlen(key)
16
+ end
17
+
18
+ def clear
19
+ @redis.xtrim(key, 0)
20
+ end
21
+
22
+ def each_message
23
+ last_id = '0'
24
+
25
+ while
26
+ result = @redis.xread(key, last_id, count: 1)
27
+ break if result.empty?
28
+
29
+ messages = result[key]
30
+ messages.each do |message|
31
+ last_id, entry = message
32
+ yield(entry['value'])
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
@@ -0,0 +1,3 @@
1
+ module RedisStream
2
+ VERSION = "0.1.0"
3
+ end
@@ -0,0 +1,14 @@
1
+ require 'redis'
2
+ require 'redis_stream/version'
3
+ require 'redis_stream/group'
4
+ require 'redis_stream/stream'
5
+ require 'redis_stream/client'
6
+
7
+ module RedisStream
8
+ class Error < StandardError; end
9
+
10
+ def self.new(redis: nil)
11
+ redis = redis.nil? ? Redis.new : redis
12
+ Client.new(redis)
13
+ end
14
+ end
@@ -0,0 +1,44 @@
1
+
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'redis_stream/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = 'redis_stream'
8
+ spec.version = RedisStream::VERSION
9
+ spec.authors = ['Anton Volkov']
10
+ spec.email = ['choixer@gmail.com']
11
+
12
+ spec.summary = %q{Interface around Redis Streams for Ruby}
13
+ spec.description = %q{..}
14
+ spec.homepage = 'https://github.com/antonvolkoff/redis-stream'
15
+
16
+ # Prevent pushing this gem to RubyGems.org. To allow pushes either set the 'allowed_push_host'
17
+ # to allow pushing to a single host or delete this section to allow pushing to any host.
18
+ if spec.respond_to?(:metadata)
19
+ # spec.metadata["allowed_push_host"] = "TODO: Set to 'http://mygemserver.com'"
20
+
21
+ spec.metadata["homepage_uri"] = spec.homepage
22
+ # spec.metadata["source_code_uri"] = "TODO: Put your gem's public repo URL here."
23
+ # spec.metadata["changelog_uri"] = "TODO: Put your gem's CHANGELOG.md URL here."
24
+ else
25
+ raise "RubyGems 2.0 or newer is required to protect against " \
26
+ "public gem pushes."
27
+ end
28
+
29
+ # Specify which files should be added to the gem when it is released.
30
+ # The `git ls-files -z` loads the files in the RubyGem that have been added into git.
31
+ spec.files = Dir.chdir(File.expand_path('..', __FILE__)) do
32
+ `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
33
+ end
34
+ # spec.bindir = "exe"
35
+ # spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
36
+ spec.require_paths = ['lib']
37
+
38
+ spec.add_dependency 'redis', '~> 4.1'
39
+
40
+ spec.add_development_dependency 'bundler', '~> 1.17'
41
+ spec.add_development_dependency 'rake', '~> 10.0'
42
+ spec.add_development_dependency 'minitest', '~> 5.0'
43
+ spec.add_development_dependency 'pry', '~> 0.12'
44
+ end
metadata ADDED
@@ -0,0 +1,128 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: redis_stream
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Anton Volkov
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2020-01-30 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: redis
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '4.1'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '4.1'
27
+ - !ruby/object:Gem::Dependency
28
+ name: bundler
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '1.17'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '1.17'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rake
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '10.0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '10.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: minitest
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '5.0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '5.0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: pry
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '0.12'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '0.12'
83
+ description: ".."
84
+ email:
85
+ - choixer@gmail.com
86
+ executables: []
87
+ extensions: []
88
+ extra_rdoc_files: []
89
+ files:
90
+ - ".gitignore"
91
+ - ".travis.yml"
92
+ - Gemfile
93
+ - Gemfile.lock
94
+ - README.md
95
+ - Rakefile
96
+ - bin/console
97
+ - bin/setup
98
+ - docker-compose.yml
99
+ - lib/redis_stream.rb
100
+ - lib/redis_stream/client.rb
101
+ - lib/redis_stream/group.rb
102
+ - lib/redis_stream/stream.rb
103
+ - lib/redis_stream/version.rb
104
+ - redis_stream.gemspec
105
+ homepage: https://github.com/antonvolkoff/redis-stream
106
+ licenses: []
107
+ metadata:
108
+ homepage_uri: https://github.com/antonvolkoff/redis-stream
109
+ post_install_message:
110
+ rdoc_options: []
111
+ require_paths:
112
+ - lib
113
+ required_ruby_version: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: '0'
118
+ required_rubygems_version: !ruby/object:Gem::Requirement
119
+ requirements:
120
+ - - ">="
121
+ - !ruby/object:Gem::Version
122
+ version: '0'
123
+ requirements: []
124
+ rubygems_version: 3.0.3
125
+ signing_key:
126
+ specification_version: 4
127
+ summary: Interface around Redis Streams for Ruby
128
+ test_files: []