summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorluke <luke@980ebf18-57e1-0310-9a29-db15c13687c0>2006-04-11 16:12:38 +0000
committerluke <luke@980ebf18-57e1-0310-9a29-db15c13687c0>2006-04-11 16:12:38 +0000
commitde0d1ddf13a8486ee6fe253e8c5a242aeca38c6a (patch)
tree966abd3ddee38fb78ffe3786c16b0f081e397afe /lib
parentbca4f5ea9df7c7374686fdee0ee672ed470ef91c (diff)
downloadpuppet-de0d1ddf13a8486ee6fe253e8c5a242aeca38c6a.tar.gz
puppet-de0d1ddf13a8486ee6fe253e8c5a242aeca38c6a.tar.xz
puppet-de0d1ddf13a8486ee6fe253e8c5a242aeca38c6a.zip
Adding a few informative facts on the server side: serverversion, servername, serverip. And only printing the parse time in the interpreter if it is not a local connection.
git-svn-id: https://reductivelabs.com/svn/puppet/trunk@1102 980ebf18-57e1-0310-9a29-db15c13687c0
Diffstat (limited to 'lib')
-rw-r--r--lib/puppet/parser/interpreter.rb8
-rw-r--r--lib/puppet/server/master.rb16
2 files changed, 21 insertions, 3 deletions
diff --git a/lib/puppet/parser/interpreter.rb b/lib/puppet/parser/interpreter.rb
index 5f5ecbe1f..f443ee3cd 100644
--- a/lib/puppet/parser/interpreter.rb
+++ b/lib/puppet/parser/interpreter.rb
@@ -77,6 +77,8 @@ module Puppet
# by the cfengine module.
@classes = hash[:Classes] || []
+ @local = hash[:Local] || false
+
# Create our parser object
parsefiles
end
@@ -292,8 +294,12 @@ module Puppet
@parser.file = @file
end
- @ast = benchmark(:info, "Parsed manifest") do
+ if @local
@parser.parse
+ else
+ @ast = benchmark(:info, "Parsed manifest") do
+ @parser.parse
+ end
end
# Mark when we parsed, so we can check freshness
diff --git a/lib/puppet/server/master.rb b/lib/puppet/server/master.rb
index bdae877a9..95d81cdf6 100644
--- a/lib/puppet/server/master.rb
+++ b/lib/puppet/server/master.rb
@@ -19,6 +19,16 @@ class Server
iface.add_method("int freshness()")
}
+ # FIXME At some point, this should be autodocumenting.
+ def addfacts(facts)
+ # Add our server version to the fact list
+ facts["serverversion"] = Puppet.version.to_s
+
+ # And then add the server name and IP
+ facts["servername"] = Facter["hostname"].value
+ facts["serverip"] = Facter["ipaddress"].value
+ end
+
def filetimeout
@interpreter.filetimeout
end
@@ -52,6 +62,8 @@ class Server
@local = false
end
+ args[:Local] = @local
+
if hash.include?(:CA) and hash[:CA]
@ca = Puppet::SSLCertificates::CA.new()
else
@@ -115,8 +127,8 @@ class Server
clientip = facts["ipaddress"]
end
- # Add our server version to the fact list
- facts["serverversion"] = Puppet.version.to_s
+ # Add any server-side facts to our server.
+ addfacts(facts)
retobjects = nil