volt-redis_message_bus 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (36) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +17 -0
  3. data/.rspec +2 -0
  4. data/CODE_OF_CONDUCT.md +13 -0
  5. data/Gemfile +9 -0
  6. data/LICENSE.txt +22 -0
  7. data/README.md +20 -0
  8. data/Rakefile +1 -0
  9. data/app/redis_message_bus/config/dependencies.rb +1 -0
  10. data/app/redis_message_bus/config/initializers/boot.rb +10 -0
  11. data/app/redis_message_bus/config/routes.rb +1 -0
  12. data/app/redis_message_bus/controllers/main_controller.rb +4 -0
  13. data/app/redis_message_bus/views/main/index.html +2 -0
  14. data/lib/volt/message_bus/redis_message_bus.rb +60 -0
  15. data/lib/volt/redis_message_bus/version.rb +5 -0
  16. data/lib/volt/redis_message_bus.rb +20 -0
  17. data/spec/dummy/.gitignore +9 -0
  18. data/spec/dummy/README.md +4 -0
  19. data/spec/dummy/app/main/assets/css/app.css.scss +1 -0
  20. data/spec/dummy/app/main/config/dependencies.rb +11 -0
  21. data/spec/dummy/app/main/config/initializers/boot.rb +10 -0
  22. data/spec/dummy/app/main/config/routes.rb +14 -0
  23. data/spec/dummy/app/main/controllers/main_controller.rb +27 -0
  24. data/spec/dummy/app/main/models/user.rb +12 -0
  25. data/spec/dummy/app/main/views/main/about.html +7 -0
  26. data/spec/dummy/app/main/views/main/index.html +6 -0
  27. data/spec/dummy/app/main/views/main/main.html +29 -0
  28. data/spec/dummy/config/app.rb +147 -0
  29. data/spec/dummy/config/base/index.html +15 -0
  30. data/spec/dummy/config/initializers/boot.rb +4 -0
  31. data/spec/dummy/config.ru +4 -0
  32. data/spec/integration/sample_integration_spec.rb +11 -0
  33. data/spec/sample_spec.rb +7 -0
  34. data/spec/spec_helper.rb +18 -0
  35. data/volt-redis_message_bus.gemspec +40 -0
  36. metadata +292 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: b5b9f14d8e5df224745f115b3787766204384229
4
+ data.tar.gz: a441abf2a28090c0a929e68723786e0b62d4e7a2
5
+ SHA512:
6
+ metadata.gz: d011630ac3168247a00f2d2c857941833a106a592dbb4e472d53f30f82d9837218c85ec6cd021ad91074d5e5345ffdbd4f2a69add39043f87f470cf55e7d1aa4
7
+ data.tar.gz: b3fba49f35c2a0b4aebbfb7bc264e8c0309b4828d0de440497de3f7d2d072b3d697b61242a74b13a0d637288659398f97ad7f2f844822c4f46c9c699bf383d45
data/.gitignore ADDED
@@ -0,0 +1,17 @@
1
+ *.gem
2
+ *.rbc
3
+ .bundle
4
+ .config
5
+ .yardoc
6
+ Gemfile.lock
7
+ InstalledFiles
8
+ _yardoc
9
+ coverage
10
+ doc/
11
+ lib/bundler/man
12
+ pkg
13
+ rdoc
14
+ spec/reports
15
+ test/tmp
16
+ test/version_tmp
17
+ tmp
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --format documentation
2
+ --color
@@ -0,0 +1,13 @@
1
+ # Contributor Code of Conduct
2
+
3
+ As contributors and maintainers of this project, we pledge to respect all people who contribute through reporting issues, posting feature requests, updating documentation, submitting pull requests or patches, and other activities.
4
+
5
+ We are committed to making participation in this project a harassment-free experience for everyone, regardless of level of experience, gender, gender identity and expression, sexual orientation, disability, personal appearance, body size, race, ethnicity, age, or religion.
6
+
7
+ Examples of unacceptable behavior by participants include the use of sexual language or imagery, derogatory comments or personal attacks, trolling, public or private harassment, insults, or other unprofessional conduct.
8
+
9
+ Project maintainers have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct. Project maintainers who do not follow the Code of Conduct may be removed from the project team.
10
+
11
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by opening an issue or contacting one or more of the project maintainers.
12
+
13
+ This Code of Conduct is adapted from the [Contributor Covenant](http://contributor-covenant.org), version 1.0.0, available at [http://contributor-covenant.org/version/1/0/0/](http://contributor-covenant.org/version/1/0/0/)
data/Gemfile ADDED
@@ -0,0 +1,9 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in volt-redis_message_bus.gemspec
4
+ gemspec
5
+
6
+ # Optional Gems for testing/dev
7
+
8
+ # The implementation of ReadWriteLock in Volt uses concurrent ruby and ext helps performance.
9
+ gem 'concurrent-ruby-ext', '~> 0.8.0'
data/LICENSE.txt ADDED
@@ -0,0 +1,22 @@
1
+ Copyright (c) 2015 Ryan Stout
2
+
3
+ MIT License
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ "Software"), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
20
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
21
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
22
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,20 @@
1
+ # Volt::RedisMessageBus
2
+
3
+ This provides a simple Redis based message bus. Volt requires a way to send messages between all nodes in an app. By default volt uses the "Peer to Peer" message bus strategy, which makes socket connections between the app instances, using the database as a way to coordinate ip and port ranges. This strategy requires no setup if the machines can send packets, however sometimes this is not possible. Heroku for example makes this difficult.
4
+
5
+ For smaller to medium deployments, the redis message bus is a simple solution. All app instances connect to a single redis server and messages are broadcast between instances through redis's pubsub feature.
6
+
7
+ ## Usage
8
+
9
+ In your Gemfile add:
10
+
11
+ ```gem 'volt-redis_message_bus'```
12
+
13
+ In your ```config/app.rb```, add:
14
+
15
+ ```ruby
16
+ config.message_bus.bus_name = 'redis'
17
+ config.message_bus.connect_options = {:host => "10.0.1.1", :port => 6380, :db => 15}
18
+ ```
19
+
20
+ The connect_options will be passed to the redis gem's Redis.new as a hash. See the [redis gem](https://github.com/redis/redis-rb#getting-started) for more docs.
data/Rakefile ADDED
@@ -0,0 +1 @@
1
+ require "bundler/gem_tasks"
@@ -0,0 +1 @@
1
+ # Component dependencies
@@ -0,0 +1,10 @@
1
+ # Place any code you want to run when the component is included on the client
2
+ # or server.
3
+
4
+ # To include code only on the client use:
5
+ # if RUBY_PLATFORM == 'opal'
6
+ #
7
+ # To include code only on the server, use:
8
+ # unless RUBY_PLATFORM == 'opal'
9
+ # ^^ this will not send compile in code in the conditional to the client.
10
+ # ^^ this include code required in the conditional.
@@ -0,0 +1 @@
1
+ # Component routes
@@ -0,0 +1,4 @@
1
+ module RedisMessageBus
2
+ class MainController < Volt::ModelController
3
+ end
4
+ end
@@ -0,0 +1,2 @@
1
+ <:Body>
2
+ -- component --
@@ -0,0 +1,60 @@
1
+ require 'redis'
2
+ require 'volt/server/message_bus/base_message_bus'
3
+
4
+ module Volt
5
+ module MessageBus
6
+ class Redis < BaseMessageBus
7
+ class Subscription
8
+ def initialize(redis)
9
+ @redis = redis
10
+ end
11
+
12
+ def remove
13
+ @redis.unsubscribe
14
+ end
15
+ end
16
+
17
+ def initialize(volt_app)
18
+ @redis = new_connection
19
+ end
20
+
21
+ # Subscribe should return an object that you can call .remove on to stop
22
+ # the subscription.
23
+ def subscribe(channel_name, &block)
24
+ sub_redis = new_connection
25
+
26
+ Thread.new do
27
+ # Since the Redis driver does not have a connection pool, we create a
28
+ # new connection each time we subscribe.
29
+ # Note: internally volt does only 1 subscription.
30
+ sub_redis.subscribe(channel_name.to_sym) do |on|
31
+ on.message do |channel_name, message|
32
+ block.call(message)
33
+ end
34
+ end
35
+ end
36
+
37
+ Subscription.new(sub_redis)
38
+ end
39
+
40
+ # publish should push out to all subscribed within the volt cluster.
41
+ def publish(channel_name, message)
42
+ @redis.publish(channel_name.to_sym, message)
43
+ end
44
+
45
+ def new_connection
46
+ msg_bus = Volt.config.message_bus
47
+ if msg_bus && (opts = msg_bus.connect_options)
48
+ ::Redis.new(opts)
49
+ else
50
+ ::Redis.new
51
+ end
52
+ end
53
+
54
+ # waits for all messages to be flushed and closes connections
55
+ def disconnect!
56
+ raise "Not implemented"
57
+ end
58
+ end
59
+ end
60
+ end
@@ -0,0 +1,5 @@
1
+ module Volt
2
+ module RedisMessageBus
3
+ VERSION = "0.1.0"
4
+ end
5
+ end
@@ -0,0 +1,20 @@
1
+ # If you need to require in code in the gem's app folder, keep in mind that
2
+ # the app is not on the load path when the gem is required. Use
3
+ # app/{gemname}/config/initializers/boot.rb to require in client or server
4
+ # code.
5
+ #
6
+ # Also, in volt apps, you typically use the lib folder in the
7
+ # app/{componentname} folder instead of this lib folder. This lib folder is
8
+ # for setting up gem code when Bundler.require is called. (or the gem is
9
+ # required.)
10
+ #
11
+ # If you need to configure volt in some way, you can add a Volt.configure block
12
+ # in this file.
13
+
14
+ require 'volt/message_bus/redis_message_bus'
15
+
16
+ module Volt
17
+ module RedisMessageBus
18
+ # Your code goes here...
19
+ end
20
+ end
@@ -0,0 +1,9 @@
1
+ .bundle
2
+ .config
3
+ .yardoc
4
+ tmp
5
+ .idea
6
+ .yardoc
7
+ .sass-cache
8
+ .DS_Store
9
+ compiled
@@ -0,0 +1,4 @@
1
+ # Place your app's docs here.
2
+
3
+ ## New to Volt?
4
+ Be sure to read the volt docs at http://voltframework.com/docs
@@ -0,0 +1 @@
1
+ // Place your apps css here
@@ -0,0 +1,11 @@
1
+ # Specify which components you wish to include when
2
+ # the "home" component loads.
3
+
4
+ # bootstrap css framework
5
+ component 'bootstrap'
6
+
7
+ # a default theme for the bootstrap framework
8
+ component 'bootstrap_jumbotron_theme'
9
+
10
+ # provides templates for login, signup, and logout
11
+ component 'user_templates'
@@ -0,0 +1,10 @@
1
+ # Place any code you want to run when the component is included on the client
2
+ # or server.
3
+
4
+ # To include code only on the client use:
5
+ # if RUBY_PLATFORM == 'opal'
6
+ #
7
+ # To include code only on the server, use:
8
+ # unless RUBY_PLATFORM == 'opal'
9
+ # ^^ this will not send compile in code in the conditional to the client.
10
+ # ^^ this include code required in the conditional.
@@ -0,0 +1,14 @@
1
+ # See https://github.com/voltrb/volt#routes for more info on routes
2
+
3
+ client '/about', action: 'about'
4
+
5
+ # Routes for login and signup, provided by user_templates component gem
6
+ client '/signup', component: 'user_templates', controller: 'signup'
7
+ client '/login', component: 'user_templates', controller: 'login', action: 'index'
8
+ client '/password_reset', component: 'user_templates', controller: 'password_reset', action: 'index'
9
+ client '/forgot', component: 'user_templates', controller: 'login', action: 'forgot'
10
+ client '/account', component: 'user_templates', controller: 'account', action: 'index'
11
+
12
+ # The main route, this should be last. It will match any params not
13
+ # previously matched.
14
+ client '/', {}
@@ -0,0 +1,27 @@
1
+ # By default Volt generates this controller for your Main component
2
+ module Main
3
+ class MainController < Volt::ModelController
4
+ def index
5
+ # Add code for when the index view is loaded
6
+ end
7
+
8
+ def about
9
+ # Add code for when the about view is loaded
10
+ end
11
+
12
+ private
13
+
14
+ # The main template contains a #template binding that shows another
15
+ # template. This is the path to that template. It may change based
16
+ # on the params._component, params._controller, and params._action values.
17
+ def main_path
18
+ "#{params._component || 'main'}/#{params._controller || 'main'}/#{params._action || 'index'}"
19
+ end
20
+
21
+ # Determine if the current nav component is the active one by looking
22
+ # at the first part of the url against the href attribute.
23
+ def active_tab?
24
+ url.path.split('/')[1] == attrs.href.split('/')[1]
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,12 @@
1
+ # By default Volt generates this User model which inherits from Volt::User,
2
+ # you can rename this if you want.
3
+ class User < Volt::User
4
+ # login_field is set to :email by default and can be changed to :username
5
+ # in config/app.rb
6
+ field login_field
7
+ field :name
8
+
9
+ validate login_field, unique: true, length: 8
10
+ validate :email, email: true
11
+
12
+ end
@@ -0,0 +1,7 @@
1
+ <:Title>
2
+ About
3
+
4
+ <:Body>
5
+ <h1>About</h1>
6
+
7
+ <p>About page...</p>
@@ -0,0 +1,6 @@
1
+ <:Title>
2
+ Home
3
+
4
+ <:Body>
5
+ <h1>Home</h1>
6
+
@@ -0,0 +1,29 @@
1
+ <:Title>
2
+ {{ view main_path, "title", {controller_group: 'main'} }}
3
+
4
+ <:Body>
5
+ <div class="container">
6
+ <div class="header">
7
+ <ul class="nav nav-pills pull-right">
8
+ <:nav href="/">Home</:nav>
9
+ <:nav href="/about">About</:nav>
10
+ <:user_templates:menu />
11
+ </ul>
12
+ <h3 class="text-muted">dummy</h3>
13
+ </div>
14
+
15
+ <:volt:notices />
16
+
17
+ {{ view main_path, 'body', {controller_group: 'main'} }}
18
+
19
+ <div class="footer">
20
+ <p>&copy; Company {{ Time.now.year }}</p>
21
+ </div>
22
+
23
+ </div>
24
+
25
+ <:Nav>
26
+ <li class="{{ if active_tab? }}active{{ end }}">
27
+ <a href="{{ attrs.href }}">{{ yield }}</a>
28
+ </li>
29
+
@@ -0,0 +1,147 @@
1
+ # app.rb is used to configure your app. This code is only run on the server,
2
+ # then any config options in config.public are passed to the client as well.
3
+
4
+ Volt.configure do |config|
5
+ # Setup your global app config here.
6
+
7
+ #######################################
8
+ # Basic App Info (stuff you should set)
9
+ #######################################
10
+ config.domain = 'dummy.com'
11
+ config.app_name = 'Dummy'
12
+ config.mailer.from = 'Dummy <no-reply@dummy.com>'
13
+
14
+ ############
15
+ # App Secret
16
+ ############
17
+ # Your app secret is used for signing things like the user cookie so it can't
18
+ # be tampered with. A random value is generated on new projects that will work
19
+ # without the need to customize. Make sure this value doesn't leave your server.
20
+ #
21
+ # For added security we recommend moving the app secret into an environment. You can
22
+ # setup that like so:
23
+ #
24
+ # config.app_secret = ENV['APP_SECRET']
25
+ #
26
+ config.app_secret = 'Hab7CzbjYw2VkIOHFdGwr95AnDFMZe988Qrp6lVggHb2zPvaRNeUhztZPtazK40So0M'
27
+
28
+ ###############
29
+ # Log Filtering
30
+ ###############
31
+ # Data updates from the client come in via Tasks. The task dispatcher logs all calls to tasks.
32
+ # By default hashes in the arguments can be filtered based on keys. So any hash with a key of
33
+ # password will be filtered. You can add more fields to filter below:
34
+ config.filter_keys = [:password]
35
+
36
+ ##########
37
+ # Database
38
+ ##########
39
+ # Database config all start with db_ and can be set either in the config
40
+ # file or with an environment variable (DB_NAME for example).
41
+
42
+ # config.db_driver = 'mongo'
43
+ # config.db_name = (config.app_name + '_' + Volt.env.to_s)
44
+ # config.db_host = 'localhost'
45
+ # config.db_port = 27017
46
+
47
+ #####################
48
+ # Compression options
49
+ #####################
50
+ # If you are not running behind something like nginx in production, you can
51
+ # have rack deflate all files.
52
+ # config.deflate = true
53
+
54
+ #########################
55
+ # Websocket configuration
56
+ #########################
57
+ # If you need to use a different domain or path for the websocket connection,
58
+ # you can set it here. Volt provides the socket connection url at /socket,
59
+ # but if for example you are using a proxy server that doesn't support
60
+ # websockets, you can point the websocket connection at the app server
61
+ # directly.
62
+ # config.public.websocket_url = '/socket'
63
+
64
+ #######################
65
+ # Public configurations
66
+ #######################
67
+ # Anything under config.public will be sent to the client as well as the server,
68
+ # so be sure no private data ends up under public
69
+
70
+ # Use username instead of email as the login
71
+ # config.public.auth.use_username = true
72
+
73
+ #####################
74
+ # Compression Options
75
+ #####################
76
+ # Disable or enable css/js/image compression. Default is to only run in production.
77
+ # if Volt.env.production?
78
+ # config.compress_javascript = true
79
+ # config.compress_css = true
80
+ # config.compress_images = true
81
+ # end
82
+
83
+ ################
84
+ # Mailer options
85
+ ################
86
+ # The volt-mailer gem uses pony (https://github.com/benprew/pony) to deliver e-mail. Any
87
+ # options you would pass to pony can be setup below.
88
+ # NOTE: The from address is setup at the top
89
+
90
+ # Normally pony uses /usr/sbin/sendmail if one is installed. You can specify smtp below:
91
+ # config.mailer.via = :smtp
92
+ # config.mailer.via_options = {
93
+ # :address => 'smtp.yourserver.com',
94
+ # :port => '25',
95
+ # :user_name => 'user',
96
+ # :password => 'password',
97
+ # :authentication => :plain, # :plain, :login, :cram_md5, no auth by default
98
+ # :domain => "localhost.localdomain" # the HELO domain provided by the client to the server
99
+ # }
100
+
101
+ #############
102
+ # Message Bus
103
+ #############
104
+ # Volt provides a "Message Bus" out of the box. The message bus provides
105
+ # a pub/sub service between any volt instance (server, client, runner, etc..)
106
+ # that share the same database. The message bus can be used by app code. It
107
+ # is also used internally to push data to any listening clients.
108
+ #
109
+ # The default message bus (called "peer_to_peer") uses the database to sync
110
+ # socket ip's/ports.
111
+ config.message_bus.bus_name = 'redis'
112
+ #
113
+ # Encrypt message bus - messages on the message bus are encrypted by default
114
+ # using rbnacl.
115
+
116
+ #
117
+ # For dummy apps, we disable_encryption, to simplify the gem requirements.
118
+ config.message_bus.disable_encryption = true
119
+
120
+ #
121
+ # ## MessageBus Server -- the message bus binds to a port and ip which the
122
+ # other volt instances need to be able to connect to. You can customize
123
+ # the server below:
124
+ #
125
+ # Port range - you can specify a range of ports that an instance can bind the
126
+ # message bus on. You can specify a range, an array of Integers, or an array
127
+ # of ranges.
128
+ # config.message_bus.bind_port_ranges = (58000..61000)
129
+ #
130
+ # Bind Ip - specifies the ip address the message bus server should bind on.
131
+ # config.message_bus.bind_ip = '127.0.0.1'
132
+
133
+ #############
134
+ # Concurrency
135
+ #############
136
+ # Volt provides a thread worker pool for incoming task requests (and all
137
+ # database requests, since those use tasks to do their work.) The following
138
+ # lets you control the size of the worker pool. Threads are only created as
139
+ # needed, and are removed after a certain amount of inactivity.
140
+ # config.min_worker_threads = 1
141
+ # config.max_worker_threads = 10
142
+ #
143
+ # You can also specify the amount of time a Task should run for before it
144
+ # timeout's. Setting this to short can cause unexpected results, currently
145
+ # we recomend it be at least 10 seconds.
146
+ # config.worker_timeout = 60
147
+ end
@@ -0,0 +1,15 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <%# IMPORTANT: Please read before changing! %>
4
+ <%# This file is rendered on the server using ERB, so it does NOT use Volt's %>
5
+ <%# normal template system. You can add to it, but keep in mind the template %>
6
+ <%# language difference. This file handles auto-loading all JS/Opal and CSS. %>
7
+ <head>
8
+ <meta charset="UTF-8" />
9
+ <%= javascript_tags %>
10
+ <%= css_tags %>
11
+ </head>
12
+ <body>
13
+
14
+ </body>
15
+ </html>
@@ -0,0 +1,4 @@
1
+ # Any ./config/initializers/*.rb files will when the app starts up on the server.
2
+ # To load code on the client (or client and server), you can use the
3
+ # config/initializers folder in a component in the app directory. This folder
4
+ # is only for things that are server only. (Usually for things like config)
@@ -0,0 +1,4 @@
1
+ # Run via rack server
2
+ require 'bundler/setup'
3
+ require 'volt/server'
4
+ run Volt::Server.new.app
@@ -0,0 +1,11 @@
1
+ require 'spec_helper'
2
+
3
+ describe 'sample integration test', type: :feature do
4
+ # An example integration spec, this will only be run if ENV['BROWSER'] is
5
+ # specified. Current values for ENV['BROWSER'] are 'firefox' and 'phantom'
6
+ it 'should load the page' do
7
+ visit '/'
8
+
9
+ expect(page).to have_content('Home')
10
+ end
11
+ end
@@ -0,0 +1,7 @@
1
+ require 'spec_helper'
2
+
3
+ describe Volt::RedisMessageBus do
4
+ it 'should do something useful' do
5
+ expect(false).to be true
6
+ end
7
+ end
@@ -0,0 +1,18 @@
1
+ # Volt sets up rspec and capybara for testing.
2
+ require 'volt/spec/setup'
3
+
4
+ # When testing Volt component gems, we boot up a dummy app first to run the
5
+ # test in, so we have access to Volt itself.
6
+ dummy_app_path = File.join(File.dirname(__FILE__), 'dummy')
7
+ Volt.spec_setup(dummy_app_path)
8
+
9
+ RSpec.configure do |config|
10
+ config.run_all_when_everything_filtered = true
11
+ config.filter_run :focus
12
+
13
+ # Run specs in random order to surface order dependencies. If you find an
14
+ # order dependency and want to debug it, you can fix the order by providing
15
+ # the seed, which is printed after each run.
16
+ # --seed 1234
17
+ config.order = 'random'
18
+ end
@@ -0,0 +1,40 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'volt/redis_message_bus/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "volt-redis_message_bus"
8
+ spec.version = Volt::RedisMessageBus::VERSION
9
+ spec.authors = ["Ryan Stout"]
10
+ spec.email = ["ryanstout@gmail.com"]
11
+ spec.summary = %q{A message bus strategy for Volt using redis}
12
+ spec.homepage = ""
13
+ spec.license = "MIT"
14
+
15
+ spec.files = `git ls-files -z`.split("\x0")
16
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
17
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
18
+ spec.require_paths = ["lib"]
19
+
20
+ spec.add_dependency 'redis', '~> 3.2.1'
21
+
22
+ spec.add_development_dependency "volt", "~> 0.9.6"
23
+ spec.add_development_dependency "rake"
24
+
25
+ # Testing gems
26
+ spec.add_development_dependency 'rspec', '~> 3.2.0'
27
+ spec.add_development_dependency 'opal-rspec', '~> 0.4.2'
28
+ spec.add_development_dependency 'capybara', '~> 2.4.4'
29
+ spec.add_development_dependency 'selenium-webdriver', '~> 2.47.0'
30
+ spec.add_development_dependency 'chromedriver-helper', '~> 1.0.0'
31
+ spec.add_development_dependency 'poltergeist', '~> 1.6.0'
32
+
33
+ # Gems to run the dummy app
34
+ spec.add_development_dependency 'volt-mongo', '0.1.1'
35
+ spec.add_development_dependency 'volt-bootstrap', '~> 0.1.0'
36
+ spec.add_development_dependency 'volt-bootstrap_jumbotron_theme', '~> 0.1.0'
37
+ spec.add_development_dependency 'volt-user_templates', '~> 0.4.0'
38
+ spec.add_development_dependency 'thin', '~> 1.6.0'
39
+
40
+ end
metadata ADDED
@@ -0,0 +1,292 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: volt-redis_message_bus
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Ryan Stout
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2015-10-28 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: 3.2.1
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: 3.2.1
27
+ - !ruby/object:Gem::Dependency
28
+ name: volt
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: 0.9.6
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: 0.9.6
41
+ - !ruby/object:Gem::Dependency
42
+ name: rake
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rspec
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: 3.2.0
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: 3.2.0
69
+ - !ruby/object:Gem::Dependency
70
+ name: opal-rspec
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: 0.4.2
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: 0.4.2
83
+ - !ruby/object:Gem::Dependency
84
+ name: capybara
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: 2.4.4
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: 2.4.4
97
+ - !ruby/object:Gem::Dependency
98
+ name: selenium-webdriver
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: 2.47.0
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: 2.47.0
111
+ - !ruby/object:Gem::Dependency
112
+ name: chromedriver-helper
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - "~>"
116
+ - !ruby/object:Gem::Version
117
+ version: 1.0.0
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - "~>"
123
+ - !ruby/object:Gem::Version
124
+ version: 1.0.0
125
+ - !ruby/object:Gem::Dependency
126
+ name: poltergeist
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - "~>"
130
+ - !ruby/object:Gem::Version
131
+ version: 1.6.0
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - "~>"
137
+ - !ruby/object:Gem::Version
138
+ version: 1.6.0
139
+ - !ruby/object:Gem::Dependency
140
+ name: volt-mongo
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - '='
144
+ - !ruby/object:Gem::Version
145
+ version: 0.1.1
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - '='
151
+ - !ruby/object:Gem::Version
152
+ version: 0.1.1
153
+ - !ruby/object:Gem::Dependency
154
+ name: volt-bootstrap
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - "~>"
158
+ - !ruby/object:Gem::Version
159
+ version: 0.1.0
160
+ type: :development
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - "~>"
165
+ - !ruby/object:Gem::Version
166
+ version: 0.1.0
167
+ - !ruby/object:Gem::Dependency
168
+ name: volt-bootstrap_jumbotron_theme
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - "~>"
172
+ - !ruby/object:Gem::Version
173
+ version: 0.1.0
174
+ type: :development
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - "~>"
179
+ - !ruby/object:Gem::Version
180
+ version: 0.1.0
181
+ - !ruby/object:Gem::Dependency
182
+ name: volt-user_templates
183
+ requirement: !ruby/object:Gem::Requirement
184
+ requirements:
185
+ - - "~>"
186
+ - !ruby/object:Gem::Version
187
+ version: 0.4.0
188
+ type: :development
189
+ prerelease: false
190
+ version_requirements: !ruby/object:Gem::Requirement
191
+ requirements:
192
+ - - "~>"
193
+ - !ruby/object:Gem::Version
194
+ version: 0.4.0
195
+ - !ruby/object:Gem::Dependency
196
+ name: thin
197
+ requirement: !ruby/object:Gem::Requirement
198
+ requirements:
199
+ - - "~>"
200
+ - !ruby/object:Gem::Version
201
+ version: 1.6.0
202
+ type: :development
203
+ prerelease: false
204
+ version_requirements: !ruby/object:Gem::Requirement
205
+ requirements:
206
+ - - "~>"
207
+ - !ruby/object:Gem::Version
208
+ version: 1.6.0
209
+ description:
210
+ email:
211
+ - ryanstout@gmail.com
212
+ executables: []
213
+ extensions: []
214
+ extra_rdoc_files: []
215
+ files:
216
+ - ".gitignore"
217
+ - ".rspec"
218
+ - CODE_OF_CONDUCT.md
219
+ - Gemfile
220
+ - LICENSE.txt
221
+ - README.md
222
+ - Rakefile
223
+ - app/redis_message_bus/config/dependencies.rb
224
+ - app/redis_message_bus/config/initializers/boot.rb
225
+ - app/redis_message_bus/config/routes.rb
226
+ - app/redis_message_bus/controllers/main_controller.rb
227
+ - app/redis_message_bus/views/main/index.html
228
+ - lib/volt/message_bus/redis_message_bus.rb
229
+ - lib/volt/redis_message_bus.rb
230
+ - lib/volt/redis_message_bus/version.rb
231
+ - spec/dummy/.gitignore
232
+ - spec/dummy/README.md
233
+ - spec/dummy/app/main/assets/css/app.css.scss
234
+ - spec/dummy/app/main/config/dependencies.rb
235
+ - spec/dummy/app/main/config/initializers/boot.rb
236
+ - spec/dummy/app/main/config/routes.rb
237
+ - spec/dummy/app/main/controllers/main_controller.rb
238
+ - spec/dummy/app/main/models/user.rb
239
+ - spec/dummy/app/main/views/main/about.html
240
+ - spec/dummy/app/main/views/main/index.html
241
+ - spec/dummy/app/main/views/main/main.html
242
+ - spec/dummy/config.ru
243
+ - spec/dummy/config/app.rb
244
+ - spec/dummy/config/base/index.html
245
+ - spec/dummy/config/initializers/boot.rb
246
+ - spec/integration/sample_integration_spec.rb
247
+ - spec/sample_spec.rb
248
+ - spec/spec_helper.rb
249
+ - volt-redis_message_bus.gemspec
250
+ homepage: ''
251
+ licenses:
252
+ - MIT
253
+ metadata: {}
254
+ post_install_message:
255
+ rdoc_options: []
256
+ require_paths:
257
+ - lib
258
+ required_ruby_version: !ruby/object:Gem::Requirement
259
+ requirements:
260
+ - - ">="
261
+ - !ruby/object:Gem::Version
262
+ version: '0'
263
+ required_rubygems_version: !ruby/object:Gem::Requirement
264
+ requirements:
265
+ - - ">="
266
+ - !ruby/object:Gem::Version
267
+ version: '0'
268
+ requirements: []
269
+ rubyforge_project:
270
+ rubygems_version: 2.4.5
271
+ signing_key:
272
+ specification_version: 4
273
+ summary: A message bus strategy for Volt using redis
274
+ test_files:
275
+ - spec/dummy/.gitignore
276
+ - spec/dummy/README.md
277
+ - spec/dummy/app/main/assets/css/app.css.scss
278
+ - spec/dummy/app/main/config/dependencies.rb
279
+ - spec/dummy/app/main/config/initializers/boot.rb
280
+ - spec/dummy/app/main/config/routes.rb
281
+ - spec/dummy/app/main/controllers/main_controller.rb
282
+ - spec/dummy/app/main/models/user.rb
283
+ - spec/dummy/app/main/views/main/about.html
284
+ - spec/dummy/app/main/views/main/index.html
285
+ - spec/dummy/app/main/views/main/main.html
286
+ - spec/dummy/config.ru
287
+ - spec/dummy/config/app.rb
288
+ - spec/dummy/config/base/index.html
289
+ - spec/dummy/config/initializers/boot.rb
290
+ - spec/integration/sample_integration_spec.rb
291
+ - spec/sample_spec.rb
292
+ - spec/spec_helper.rb