Puppet::Type.type(:service).provide :bsd, :parent => :init do
desc <<-EOT
Generic BSD form of `init`-style service management with `rc.d`.
Uses `rc.conf.d` for service enabling and disabling.
EOT
confine :operatingsystem => [:freebsd, :dragonfly]
def rcconf_dir
'/etc/rc.conf.d'
end
def self.defpath
superclass.defpath
end
# remove service file from rc.conf.d to disable it
def disable
rcfile = File.join(rcconf_dir, @resource[:name])
File.delete(rcfile) if Puppet::FileSystem.exist?(rcfile)
end
# if the service file exists in rc.conf.d then it's already enabled
def enabled?
rcfile = File.join(rcconf_dir, @resource[:name])
return :true if Puppet::FileSystem.exist?(rcfile)
:false
end
# enable service by creating a service file under rc.conf.d with the
# proper contents
def enable
Dir.mkdir(rcconf_dir) if not Puppet::FileSystem.exist?(rcconf_dir)
rcfile = File.join(rcconf_dir, @resource[:name])
File.open(rcfile, File::WRONLY | File::APPEND | File::CREAT, 0644) { |f|
f << "%s_enable=\"YES\"\n" % @resource[:name]
}
end
# Override stop/start commands to use one<cmd>'s and the avoid race condition
# where provider tries to stop/start the service before it is enabled
def startcmd
[self.initscript, :onestart]
end
def stopcmd
[self.initscript, :onestop]
end
end
Anons79 File Manager Version 1.0, Coded By Anons79
Email: [email protected]