web-facter 0.0.1 → 0.0.3
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile +1 -0
- data/Gemfile.lock +2 -0
- data/README +23 -1
- data/bin/web-facter +64 -1
- data/lib/web-facter/version.rb +1 -1
- metadata +6 -6
data/Gemfile
CHANGED
data/Gemfile.lock
CHANGED
data/README
CHANGED
@@ -2,4 +2,26 @@ A tiny ruby rack application which exposes the data from facter as JSON over HTT
|
|
2
2
|
|
3
3
|
gem install web-facter
|
4
4
|
|
5
|
-
|
5
|
+
Provides a simple command line tool which runs a built in web server. On accessing
|
6
|
+
the specified port you should get a JSON response containing the current facts.
|
7
|
+
|
8
|
+
web-facter --help
|
9
|
+
Usage: web-facter [options] ...
|
10
|
+
|
11
|
+
Configuration options:
|
12
|
+
--no-daemonize Don't daemonize the web server process
|
13
|
+
-p, --port PORT The port to run web-facter on
|
14
|
+
-c, --config FILE The file to load with configuration options
|
15
|
+
-h, --help Display this screenp
|
16
|
+
|
17
|
+
|
18
|
+
You can configure web-facter using a configuration file, using the following format, and
|
19
|
+
specifying the filename with the --config option above.
|
20
|
+
|
21
|
+
username=gilbert
|
22
|
+
password=george
|
23
|
+
port=3009
|
24
|
+
daemonize=true
|
25
|
+
|
26
|
+
Note that the port and daemonize options will override those on the command line.
|
27
|
+
The username and password options enable HTTP basic authentication using those details.
|
data/bin/web-facter
CHANGED
@@ -1,6 +1,69 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
2
|
|
3
3
|
require 'rack'
|
4
|
+
require 'optparse'
|
4
5
|
require 'web-facter'
|
6
|
+
require 'parseconfig'
|
5
7
|
|
6
|
-
|
8
|
+
options = {}
|
9
|
+
|
10
|
+
optparse = OptionParser.new do |opts|
|
11
|
+
opts.banner = 'Usage: web-facter [options] ...'
|
12
|
+
|
13
|
+
opts.separator ''
|
14
|
+
opts.separator 'Configuration options:'
|
15
|
+
|
16
|
+
options[:daemonize] = true
|
17
|
+
opts.on( '--no-daemonize', "Don't daemonize the web server process") do |_|
|
18
|
+
options[:daemonize] = false
|
19
|
+
end
|
20
|
+
|
21
|
+
options[:port] = 9294
|
22
|
+
opts.on( '-p', '--port PORT', 'The port to run web-facter on') do |port|
|
23
|
+
options[:port] = port
|
24
|
+
end
|
25
|
+
|
26
|
+
options[:config] = false
|
27
|
+
opts.on( '-c', '--config FILE', 'The file to load with configuration options') do |file|
|
28
|
+
options[:config] = file
|
29
|
+
end
|
30
|
+
|
31
|
+
opts.on_tail('-h', '--help', 'Display this screen') do
|
32
|
+
puts opts
|
33
|
+
exit
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
begin
|
38
|
+
optparse.parse!
|
39
|
+
|
40
|
+
application = WebFacter::App.new
|
41
|
+
|
42
|
+
daemonize = options[:daemonize]
|
43
|
+
port = options[:port]
|
44
|
+
|
45
|
+
if options[:config]
|
46
|
+
conf = ParseConfig.new(options[:config])
|
47
|
+
|
48
|
+
if conf.get_value('password')
|
49
|
+
application = Rack::Auth::Basic.new(application) do |username, password|
|
50
|
+
username_check = conf.get_value('username') ? conf.get_value('username') == username : true
|
51
|
+
password_check = conf.get_value('password') == password
|
52
|
+
username_check && password_check
|
53
|
+
end
|
54
|
+
application.realm = 'Web Facter'
|
55
|
+
end
|
56
|
+
|
57
|
+
port = conf.get_value('port') ? conf.get_value('port') : port
|
58
|
+
daemonize = conf.get_value('daemonize') ? conf.get_value('daemonize') == "true" : daemonize
|
59
|
+
end
|
60
|
+
|
61
|
+
Rack::Server.new(:app => application, :Port => port, :daemonize => daemonize).start
|
62
|
+
rescue OptionParser::InvalidArgument, OptionParser::InvalidOption, OptionParser::MissingArgument
|
63
|
+
puts $!.to_s
|
64
|
+
puts optparse
|
65
|
+
exit
|
66
|
+
rescue Errno::EACCES
|
67
|
+
puts $!.to_s
|
68
|
+
exit
|
69
|
+
end
|
data/lib/web-facter/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: web-facter
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.3
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,11 +9,11 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2011-10-
|
12
|
+
date: 2011-10-31 00:00:00.000000000Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rack
|
16
|
-
requirement: &
|
16
|
+
requirement: &70139598663080 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ! '>='
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: '0'
|
22
22
|
type: :runtime
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *70139598663080
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: facter
|
27
|
-
requirement: &
|
27
|
+
requirement: &70139598662660 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ! '>='
|
@@ -32,7 +32,7 @@ dependencies:
|
|
32
32
|
version: '0'
|
33
33
|
type: :runtime
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *70139598662660
|
36
36
|
description: Daemon which serves information from the facter gem as JSON over HTTP
|
37
37
|
email:
|
38
38
|
- gareth@morethanseven.net
|