queso-daemon-kit 0.1.7.10

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 (167) hide show
  1. data/Configuration.txt +110 -0
  2. data/Deployment.txt +113 -0
  3. data/History.txt +97 -0
  4. data/Logging.txt +92 -0
  5. data/Manifest.txt +166 -0
  6. data/PostInstall.txt +6 -0
  7. data/README.rdoc +130 -0
  8. data/Rakefile +37 -0
  9. data/RuoteParticipants.txt +113 -0
  10. data/TODO.txt +37 -0
  11. data/app_generators/daemon_kit/USAGE +7 -0
  12. data/app_generators/daemon_kit/daemon_kit_generator.rb +161 -0
  13. data/app_generators/daemon_kit/templates/README +48 -0
  14. data/app_generators/daemon_kit/templates/Rakefile +6 -0
  15. data/app_generators/daemon_kit/templates/bin/daemon.erb +7 -0
  16. data/app_generators/daemon_kit/templates/config/arguments.rb +12 -0
  17. data/app_generators/daemon_kit/templates/config/boot.rb +68 -0
  18. data/app_generators/daemon_kit/templates/config/environment.rb +23 -0
  19. data/app_generators/daemon_kit/templates/config/environments/development.rb +2 -0
  20. data/app_generators/daemon_kit/templates/config/environments/production.rb +2 -0
  21. data/app_generators/daemon_kit/templates/config/environments/test.rb +2 -0
  22. data/app_generators/daemon_kit/templates/config/post-daemonize/readme +5 -0
  23. data/app_generators/daemon_kit/templates/config/pre-daemonize/readme +12 -0
  24. data/app_generators/daemon_kit/templates/lib/daemon.rb +2 -0
  25. data/app_generators/daemon_kit/templates/libexec/daemon.erb +18 -0
  26. data/app_generators/daemon_kit/templates/script/console +3 -0
  27. data/app_generators/daemon_kit/templates/script/destroy +14 -0
  28. data/app_generators/daemon_kit/templates/script/generate +14 -0
  29. data/bin/daemon_kit +18 -0
  30. data/daemon_generators/amqp/USAGE +5 -0
  31. data/daemon_generators/amqp/amqp_generator.rb +65 -0
  32. data/daemon_generators/amqp/templates/config/amqp.yml +28 -0
  33. data/daemon_generators/amqp/templates/config/initializers/amqp.rb +7 -0
  34. data/daemon_generators/amqp/templates/libexec/daemon.rb +37 -0
  35. data/daemon_generators/cron/USAGE +5 -0
  36. data/daemon_generators/cron/cron_generator.rb +64 -0
  37. data/daemon_generators/cron/templates/config/initializers/cron.rb +11 -0
  38. data/daemon_generators/cron/templates/libexec/daemon.rb +43 -0
  39. data/daemon_generators/cucumber/USAGE +11 -0
  40. data/daemon_generators/cucumber/cucumber_generator.rb +38 -0
  41. data/daemon_generators/cucumber/templates/cucumber +8 -0
  42. data/daemon_generators/cucumber/templates/cucumber.rake +13 -0
  43. data/daemon_generators/cucumber/templates/cucumber_environment.rb +2 -0
  44. data/daemon_generators/cucumber/templates/env.rb +7 -0
  45. data/daemon_generators/deploy_capistrano/deploy_capistrano_generator.rb +35 -0
  46. data/daemon_generators/deploy_capistrano/templates/Capfile +10 -0
  47. data/daemon_generators/deploy_capistrano/templates/USAGE +10 -0
  48. data/daemon_generators/deploy_capistrano/templates/config/deploy.rb +53 -0
  49. data/daemon_generators/deploy_capistrano/templates/config/deploy/production.rb +6 -0
  50. data/daemon_generators/deploy_capistrano/templates/config/deploy/staging.rb +6 -0
  51. data/daemon_generators/deploy_capistrano/templates/config/environments/staging.rb +0 -0
  52. data/daemon_generators/jabber/USAGE +5 -0
  53. data/daemon_generators/jabber/jabber_generator.rb +65 -0
  54. data/daemon_generators/jabber/templates/config/initializers/jabber.rb +7 -0
  55. data/daemon_generators/jabber/templates/config/jabber.yml +26 -0
  56. data/daemon_generators/jabber/templates/libexec/daemon.rb +27 -0
  57. data/daemon_generators/nanite_agent/USAGE +5 -0
  58. data/daemon_generators/nanite_agent/nanite_agent_generator.rb +68 -0
  59. data/daemon_generators/nanite_agent/templates/config/initializers/nanite_agent.rb +6 -0
  60. data/daemon_generators/nanite_agent/templates/config/nanite.yml +35 -0
  61. data/daemon_generators/nanite_agent/templates/lib/actors/sample.rb +11 -0
  62. data/daemon_generators/nanite_agent/templates/libexec/daemon.rb +31 -0
  63. data/daemon_generators/rspec/USAGE +5 -0
  64. data/daemon_generators/rspec/rspec_generator.rb +55 -0
  65. data/daemon_generators/rspec/templates/spec.rb +11 -0
  66. data/daemon_generators/rspec/templates/spec/spec.opts +1 -0
  67. data/daemon_generators/rspec/templates/spec/spec_helper.rb +21 -0
  68. data/daemon_generators/rspec/templates/tasks/rspec.rake +21 -0
  69. data/daemon_generators/ruote/USAGE +5 -0
  70. data/daemon_generators/ruote/ruote_generator.rb +67 -0
  71. data/daemon_generators/ruote/templates/config/amqp.yml +30 -0
  72. data/daemon_generators/ruote/templates/config/initializers/ruote.rb +13 -0
  73. data/daemon_generators/ruote/templates/config/ruote.yml +23 -0
  74. data/daemon_generators/ruote/templates/lib/daemon.rb +4 -0
  75. data/daemon_generators/ruote/templates/lib/sample.rb +26 -0
  76. data/daemon_generators/ruote/templates/libexec/daemon.rb +33 -0
  77. data/lib/daemon_kit.rb +62 -0
  78. data/lib/daemon_kit/abstract_logger.rb +235 -0
  79. data/lib/daemon_kit/amqp.rb +38 -0
  80. data/lib/daemon_kit/application.rb +187 -0
  81. data/lib/daemon_kit/arguments.rb +165 -0
  82. data/lib/daemon_kit/commands/console.rb +38 -0
  83. data/lib/daemon_kit/config.rb +108 -0
  84. data/lib/daemon_kit/console_daemon.rb +2 -0
  85. data/lib/daemon_kit/core_ext.rb +1 -0
  86. data/lib/daemon_kit/core_ext/configurable.rb +96 -0
  87. data/lib/daemon_kit/core_ext/string.rb +22 -0
  88. data/lib/daemon_kit/cron.rb +48 -0
  89. data/lib/daemon_kit/cucumber/world.rb +38 -0
  90. data/lib/daemon_kit/deployment/capistrano.rb +482 -0
  91. data/lib/daemon_kit/em.rb +43 -0
  92. data/lib/daemon_kit/error_handlers/base.rb +32 -0
  93. data/lib/daemon_kit/error_handlers/hoptoad.rb +60 -0
  94. data/lib/daemon_kit/error_handlers/mail.rb +85 -0
  95. data/lib/daemon_kit/exceptions.rb +15 -0
  96. data/lib/daemon_kit/initializer.rb +438 -0
  97. data/lib/daemon_kit/jabber.rb +170 -0
  98. data/lib/daemon_kit/nanite.rb +7 -0
  99. data/lib/daemon_kit/nanite/agent.rb +56 -0
  100. data/lib/daemon_kit/pid_file.rb +61 -0
  101. data/lib/daemon_kit/ruote_participants.rb +119 -0
  102. data/lib/daemon_kit/ruote_pseudo_participant.rb +68 -0
  103. data/lib/daemon_kit/ruote_workitem.rb +169 -0
  104. data/lib/daemon_kit/safety.rb +85 -0
  105. data/lib/daemon_kit/tasks.rb +2 -0
  106. data/lib/daemon_kit/tasks/environment.rake +10 -0
  107. data/lib/daemon_kit/tasks/framework.rake +120 -0
  108. data/lib/daemon_kit/tasks/god.rake +62 -0
  109. data/lib/daemon_kit/tasks/log.rake +8 -0
  110. data/lib/daemon_kit/tasks/monit.rake +29 -0
  111. data/script/console +10 -0
  112. data/script/destroy +14 -0
  113. data/script/generate +14 -0
  114. data/script/txt2html +71 -0
  115. data/spec/abstract_logger_spec.rb +126 -0
  116. data/spec/argument_spec.rb +70 -0
  117. data/spec/config_spec.rb +79 -0
  118. data/spec/configurable_spec.rb +56 -0
  119. data/spec/daemon_kit_spec.rb +7 -0
  120. data/spec/error_handlers_spec.rb +23 -0
  121. data/spec/fixtures/env.yml +15 -0
  122. data/spec/fixtures/noenv.yml +4 -0
  123. data/spec/initializer_spec.rb +26 -0
  124. data/spec/spec.opts +1 -0
  125. data/spec/spec_helper.rb +27 -0
  126. data/tasks/rspec.rake +21 -0
  127. data/templates/god/god.erb +69 -0
  128. data/templates/monit/monit.erb +14 -0
  129. data/test/test_amqp_generator.rb +48 -0
  130. data/test/test_cron_generator.rb +45 -0
  131. data/test/test_daemon-kit_generator.rb +84 -0
  132. data/test/test_daemon_kit_config.rb +28 -0
  133. data/test/test_deploy_capistrano_generator.rb +48 -0
  134. data/test/test_generator_helper.rb +29 -0
  135. data/test/test_helper.rb +7 -0
  136. data/test/test_jabber_generator.rb +49 -0
  137. data/test/test_nanite_agent_generator.rb +49 -0
  138. data/test/test_ruote_generator.rb +45 -0
  139. data/vendor/tmail-1.2.3/tmail.rb +5 -0
  140. data/vendor/tmail-1.2.3/tmail/address.rb +426 -0
  141. data/vendor/tmail-1.2.3/tmail/attachments.rb +46 -0
  142. data/vendor/tmail-1.2.3/tmail/base64.rb +46 -0
  143. data/vendor/tmail-1.2.3/tmail/compat.rb +41 -0
  144. data/vendor/tmail-1.2.3/tmail/config.rb +67 -0
  145. data/vendor/tmail-1.2.3/tmail/core_extensions.rb +63 -0
  146. data/vendor/tmail-1.2.3/tmail/encode.rb +581 -0
  147. data/vendor/tmail-1.2.3/tmail/header.rb +960 -0
  148. data/vendor/tmail-1.2.3/tmail/index.rb +9 -0
  149. data/vendor/tmail-1.2.3/tmail/interface.rb +1130 -0
  150. data/vendor/tmail-1.2.3/tmail/loader.rb +3 -0
  151. data/vendor/tmail-1.2.3/tmail/mail.rb +578 -0
  152. data/vendor/tmail-1.2.3/tmail/mailbox.rb +495 -0
  153. data/vendor/tmail-1.2.3/tmail/main.rb +6 -0
  154. data/vendor/tmail-1.2.3/tmail/mbox.rb +3 -0
  155. data/vendor/tmail-1.2.3/tmail/net.rb +248 -0
  156. data/vendor/tmail-1.2.3/tmail/obsolete.rb +132 -0
  157. data/vendor/tmail-1.2.3/tmail/parser.rb +1476 -0
  158. data/vendor/tmail-1.2.3/tmail/port.rb +379 -0
  159. data/vendor/tmail-1.2.3/tmail/quoting.rb +118 -0
  160. data/vendor/tmail-1.2.3/tmail/require_arch.rb +58 -0
  161. data/vendor/tmail-1.2.3/tmail/scanner.rb +49 -0
  162. data/vendor/tmail-1.2.3/tmail/scanner_r.rb +261 -0
  163. data/vendor/tmail-1.2.3/tmail/stringio.rb +280 -0
  164. data/vendor/tmail-1.2.3/tmail/utils.rb +337 -0
  165. data/vendor/tmail-1.2.3/tmail/version.rb +39 -0
  166. data/vendor/tmail.rb +13 -0
  167. metadata +281 -0
@@ -0,0 +1,165 @@
1
+ require 'optparse'
2
+
3
+ module DaemonKit
4
+
5
+ # A wrapper around OptParse for setting up arguments to the daemon
6
+ # process.
7
+ #
8
+ # TODO: Set rules for basic options that go for all daemons
9
+ # TODO: Load options from config/arguments.rb
10
+ class Arguments
11
+
12
+ # Default command
13
+ @default_command = 'run'
14
+
15
+ # Valid commands
16
+ @commands = [
17
+ 'start',
18
+ 'stop',
19
+ 'run'
20
+ ]
21
+
22
+ class << self
23
+
24
+ attr_reader :default_command, :commands
25
+
26
+ # Parse the argument values and return an array with the command
27
+ # name, config values and argument values
28
+ def parse( argv )
29
+ cmd, argv = self.command( argv )
30
+
31
+ return cmd, *self.configuration( argv )
32
+ end
33
+
34
+ # Parse the provided argument array for a given command, or
35
+ # return the default command and the remaining arguments
36
+ def command( argv )
37
+ # extract command or set default
38
+ cmd = self.commands.include?( argv[0] ) ? argv.shift : self.default_command
39
+
40
+ return cmd.to_sym, argv
41
+ end
42
+
43
+ # Extracts any values for arguments matching '--config' as well
44
+ # as some implication arguments like '-e'. Returns an array with
45
+ # the configs as the first value and the remaing args as the
46
+ # last value.
47
+ #
48
+ # To set a value on the default #Configuration instance, use the
49
+ # following notation:
50
+ #
51
+ # --config attribute=value
52
+ #
53
+ # The above notation can be used several times to set different
54
+ # values.
55
+ #
56
+ # Special, or 'normal' arguments that are mapped to the default
57
+ # #Configuration instance are listed below:
58
+ #
59
+ # -e value or --env value => environment
60
+ # --pid pidfile => pid_file
61
+ # -l path or --log path => /path/to/log/file
62
+ #
63
+ def configuration( argv )
64
+ configs = []
65
+
66
+ i = 0
67
+ while i < argv.size
68
+ if argv[i] == "--config"
69
+ argv.delete_at( i )
70
+ configs << argv.delete_at(i)
71
+ next
72
+ end
73
+
74
+ if argv[i] == "-e" || argv[i] == "--env"
75
+ argv.delete_at( i )
76
+ configs << "environment=#{argv.delete_at(i)}"
77
+ next
78
+ end
79
+
80
+ if argv[i] == "-l" || argv[i] == "--log"
81
+ argv.delete_at( i )
82
+ configs << "log_path=#{argv.delete_at(i)}"
83
+ next
84
+ end
85
+
86
+ if argv[i] == "--pid"
87
+ argv.delete_at( i )
88
+ configs << "pid_file=#{argv.delete_at(i)}"
89
+ next
90
+ end
91
+
92
+ i += 1
93
+ end
94
+
95
+ return configs, argv
96
+ end
97
+
98
+ # Return the arguments remaining after running through #configuration
99
+ def arguments( argv )
100
+ self.configuration( argv ).last
101
+ end
102
+ end
103
+
104
+ attr_reader :options
105
+
106
+ def initialize
107
+ @options = {}
108
+
109
+ @parser = OptionParser.new do |opts|
110
+ opts.banner = "Usage: #{File.basename($0)} [command] [options]"
111
+
112
+ opts.separator ""
113
+
114
+ opts.separator "Command is one of the following:"
115
+ opts.separator " run - Run the daemon without forking (default)"
116
+ opts.separator " start - Run the daemon"
117
+ opts.separator " stop - Stop the running daemon"
118
+
119
+ opts.separator ""
120
+
121
+ opts.separator "Options can be:"
122
+
123
+ arg_file = File.join( DaemonKit.root, 'config', 'arguments.rb' )
124
+ eval(IO.read(arg_file), binding, arg_file) if File.exists?( arg_file )
125
+
126
+ opts.on("-e", "--env ENVIRONMENT", "Environment for the process", "Defaults to development") do
127
+ # Nothing, just here for show
128
+ end
129
+
130
+ opts.on("--pidfile PATH", "Path to the pidfile", "Defaults to log/#{DaemonKit.configuration.daemon_name}.pid") do
131
+ # Nothing, just here for show
132
+ end
133
+
134
+ opts.on("-l", "--log /path/to/logfile", "Path to the log file", "Defaults to log/[environment].log") do
135
+ # Nothing, just here for show
136
+ end
137
+
138
+ opts.separator ""
139
+ opts.separator "Advanced configurations:"
140
+ opts.on("--config ATTRIBUTE=VALUE",
141
+ "Change values of the daemon-kit Configuration instance",
142
+ "Example: log_dir=/path/to/log-directory") do
143
+ # Nothing, just here for show
144
+ end
145
+
146
+ opts.separator ""
147
+
148
+ opts.separator "Common options:"
149
+ opts.on("-v", "--version", "Show version information and exit") do
150
+ puts "daemon-kit #{DaemonKit::VERSION} (http://github.com/kennethkalmer/daemon-kit)"
151
+ exit
152
+ end
153
+
154
+ opts.on_tail("-h", "--help", "Show this message") do
155
+ puts opts
156
+ exit
157
+ end
158
+ end
159
+ end
160
+
161
+ def parse( argv )
162
+ @parser.parse!( argv )
163
+ end
164
+ end
165
+ end
@@ -0,0 +1,38 @@
1
+ irb = RUBY_PLATFORM =~ /(:?mswin|mingw)/ ? 'irb.bat' : 'irb'
2
+
3
+ require 'optparse'
4
+
5
+ options = { :irb => irb }
6
+ OptionParser.new do |opt|
7
+ opt.banner = "Usage: console [environment] [options]"
8
+ opt.on("--irb=[#{irb}]", 'Invoke a different irb.') { |v| options[:irb] = v }
9
+ opt.on("--debugger", 'Enable ruby-debugging for the console.') { |v| options[:debugger] = v }
10
+ opt.parse!(ARGV)
11
+ end
12
+
13
+ libs = " -r irb/completion"
14
+ libs << %( -r "#{DAEMON_ROOT}/config/environment")
15
+ libs << " -r daemon_kit/console_daemon"
16
+
17
+ if options[:debugger]
18
+ begin
19
+ require 'ruby-debug'
20
+ libs << " -r ruby-debug"
21
+ puts "=> Debugger enabled"
22
+ rescue Exception
23
+ puts "You need to install ruby-debug to run the console in debugging mode. With gems, use 'gem install ruby-debug'"
24
+ exit
25
+ end
26
+ end
27
+
28
+ ENV['DAEMON_ENV'] = case ARGV.first
29
+ when "p"; "production"
30
+ when "d"; "development"
31
+ when "t"; "test"
32
+ else
33
+ ARGV.first || ENV['DAEMON_ENV'] || 'development'
34
+ end
35
+
36
+ puts "Loading #{ENV['DAEMON_ENV']} environment (daemon-kit #{DaemonKit::VERSION})"
37
+
38
+ exec "#{options[:irb]} #{libs} --simple-prompt"
@@ -0,0 +1,108 @@
1
+ module DaemonKit
2
+
3
+ # Simplify simple config file loading for daemons. Assumes the
4
+ # config files all live in DAEMON_ROOT/config and are YAML
5
+ # files. Loaded configs are accessed like a hash with string
6
+ # keys.
7
+ #
8
+ # Config files can either be keyed by environment (default behavior)
9
+ # or be a normal hash.
10
+ #
11
+ # Load a config by passing the filename (with or without the .yml
12
+ # extension) to #load.
13
+ #
14
+ # At this stage the configs are read-only.
15
+ #
16
+ # Any of the keys can be called as methods as well.
17
+ class Config
18
+
19
+ class << self
20
+
21
+ # Load the +config+.yml file from DAEMON_ROOT/config
22
+ def load( config )
23
+ config = config.to_s
24
+ config += '.yml' unless config =~ /\.yml$/
25
+
26
+ path = File.join( DAEMON_ROOT, 'config', config )
27
+
28
+ raise ArgumentError, "Can't find #{path}" unless File.exists?( path )
29
+
30
+ new( YAML.load_file( path ) )
31
+ end
32
+
33
+ # Return the +config+.yml file as a raw hash.
34
+ def hash( config, symbolize = false )
35
+ self.load( config ).to_h( symbolize )
36
+ end
37
+
38
+ end
39
+
40
+ # Expects a hash, looks for DAEMON_ENV key
41
+ def initialize( config_data ) #:nodoc:
42
+ if config_data.has_key?( DAEMON_ENV )
43
+ self.data = config_data[ DAEMON_ENV ]
44
+ else
45
+ self.data = config_data
46
+ end
47
+ end
48
+
49
+ # Pick out a config by name
50
+ def []( key )
51
+ @data[ key.to_s ]
52
+ end
53
+
54
+ # Return the internal hash structure used, optionally symbolizing
55
+ # the first level of keys in the hash
56
+ def to_h( symbolize = false )
57
+ symbolize ? @data.symbolize_keys : @data
58
+ end
59
+
60
+ def method_missing( method_name, *args ) #:nodoc:
61
+ unless method_name.to_s =~ /[\w_]+=$/
62
+ if @data.keys.include?( method_name.to_s )
63
+ return @data.send( method_name.to_s )
64
+ end
65
+ end
66
+
67
+ super
68
+ end
69
+
70
+ def data=( hash )
71
+ @data = hash
72
+ class << @data
73
+ def symbolize_keys( hash = self )
74
+ hash.inject({}) { |result, (key, value)|
75
+ new_key = case key
76
+ when String then key.to_sym
77
+ else key
78
+ end
79
+ new_value = case value
80
+ when Hash then symbolize_keys(value)
81
+ else value
82
+ end
83
+ result[new_key] = new_value
84
+ result
85
+ }
86
+ end
87
+ end
88
+
89
+ extend_hash( @data )
90
+ end
91
+
92
+ def extend_hash( hash )
93
+ hash.keys.each do |k|
94
+ hash.instance_eval <<-KEY
95
+ def #{k}
96
+ fetch("#{k}")
97
+ end
98
+ KEY
99
+ end
100
+
101
+ hash.each do |(key, value)|
102
+ case value
103
+ when Hash then extend_hash( value )
104
+ end
105
+ end
106
+ end
107
+ end
108
+ end
@@ -0,0 +1,2 @@
1
+ # Load and configure our daemon process, without daemonizing
2
+ DaemonKit::Application.running!
@@ -0,0 +1 @@
1
+ require File.dirname(__FILE__) + '/core_ext/string'
@@ -0,0 +1,96 @@
1
+ module DaemonKit
2
+
3
+ # Provide some advanced helpers for managing access to instance variables.
4
+ module Configurable
5
+
6
+ def self.included(base) #:nodoc:
7
+ base.class_eval <<-EOF
8
+ @configurables = {}
9
+ @configurable_defaults = {}
10
+
11
+ class << self
12
+ attr_reader :configurables, :configurable_defaults
13
+ end
14
+ EOF
15
+
16
+ base.extend( ClassMethods )
17
+ base.send( :include, InstanceMethods )
18
+ end
19
+
20
+ module ClassMethods
21
+
22
+ # Create a configurable value on any instance, which can contain
23
+ # a default value, and/or be locked.
24
+ #
25
+ # Create a standard getter/setter without a default value
26
+ #
27
+ # configurable :foo
28
+ #
29
+ # Create a getter/setter with a default value
30
+ #
31
+ # configurable :foo, true
32
+ #
33
+ # The final argument can be an options hash, which currently
34
+ # respects only one key: +locked+ (false by default). Locking a
35
+ # configurable means the value can only be set once by the
36
+ # setter method.
37
+ #
38
+ # configurable :foo, :locked => true
39
+ #
40
+ # As long as the getter method (+foo+) returns nil, the standard
41
+ # setter method will work. As soon as the getter returns a
42
+ # non-nil value the setter won't set a new value. To set a new
43
+ # value you'll have to explicitly use the #set instance method.
44
+ def configurable( name, *args )
45
+ opts = args.last.is_a?( Hash ) ? args.pop : {}
46
+ opts = { :locked => false }.merge( opts )
47
+
48
+ default = args.size <= 1 ? args.pop : args
49
+
50
+ name = name.to_sym
51
+
52
+ self.configurables[ name ] = opts
53
+ self.configurable_defaults[ name ] = default
54
+
55
+ class_eval( <<-EOF, __FILE__, __LINE__ )
56
+ def #{name} # def foo
57
+ if _configurables[:#{name}].nil? # if _configurables[:foo].nil?
58
+ self.class.configurable_defaults[:#{name}] # self.class.configurable_defaults[:foo]
59
+ else # else
60
+ _configurables[:#{name}] # _configurables[:foo]
61
+ end # end
62
+ end #
63
+
64
+ def #{name}=( value ) # def foo=( value )
65
+ if #{name}.nil? || # if foo.nil? ||
66
+ !self.class.configurables[:#{name}][:locked] # !self.class.configurables[:foo][:locked]
67
+ #
68
+ _configurables[:#{name}] = value # _configurables[:foo] = value
69
+ end # end
70
+ end # end
71
+ EOF
72
+ end
73
+
74
+ end
75
+
76
+ module InstanceMethods
77
+
78
+ # Force the value of a configurable to be set without any
79
+ # respect for it's locked status.
80
+ def set( name, value )
81
+ name = name.to_sym
82
+
83
+ if self.class.configurables.has_key?( name )
84
+ _configurables[ name ] = value
85
+ end
86
+ end
87
+
88
+ private
89
+
90
+ def _configurables
91
+ @_configurables ||= {}
92
+ end
93
+
94
+ end
95
+ end
96
+ end
@@ -0,0 +1,22 @@
1
+ require 'pathname'
2
+
3
+ class String
4
+
5
+ # Assuming the string is a file or path name, convert it into an
6
+ # absolute path.
7
+ def to_absolute_path
8
+ # Pathname is incompatible with Windows, but Windows doesn't have
9
+ # real symlinks so File.expand_path is safe.
10
+ if RUBY_PLATFORM =~ /(:?mswin|mingw)/
11
+ File.expand_path( self )
12
+
13
+ # Otherwise use Pathname#realpath which respects symlinks.
14
+ else
15
+ begin
16
+ File.expand_path( Pathname.new( self ).realpath.to_s )
17
+ rescue Errno::ENOENT
18
+ File.expand_path( Pathname.new( self ).cleanpath.to_s )
19
+ end
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,48 @@
1
+ module DaemonKit
2
+
3
+ # Thin wrapper around rufus-scheduler gem, specifically designed to ease
4
+ # configuration of a scheduler and provide some added simplicity.
5
+ #
6
+ # For more information on rufus-scheduler, please visit the RDoc's
7
+ # at http://rufus.rubyforge.org/rufus-scheduler/
8
+ #
9
+ # To use the evented scheduler, call #DaemonKit::EM.run prior to
10
+ # setting up your first schedule.
11
+ class Cron
12
+
13
+ @instance = nil
14
+
15
+ attr_reader :scheduler
16
+
17
+ class << self
18
+
19
+ # Access to the scheduler instance
20
+ def instance
21
+ @instance ||= new
22
+ end
23
+
24
+ def scheduler
25
+ instance.scheduler
26
+ end
27
+
28
+ private :new
29
+
30
+ # Once the scheduler has been configured, call #run to block the
31
+ # current thread and keep the process alive for the scheduled
32
+ # tasks to run
33
+ def run
34
+ DaemonKit.logger.info "Starting rufus-scheduler"
35
+
36
+ if instance.is_a?( Rufus::Scheduler::PlainScheduler )
37
+ instance.scheduler.join
38
+ else
39
+ Thread.stop
40
+ end
41
+ end
42
+ end
43
+
44
+ def initialize
45
+ @scheduler = Rufus::Scheduler.start_new
46
+ end
47
+ end
48
+ end