2014-04-08 23:31:03 +00:00
|
|
|
module Propellor.Property.Service where
|
|
|
|
|
|
|
|
import Propellor
|
|
|
|
import Utility.SafeCommand
|
|
|
|
|
|
|
|
type ServiceName = String
|
|
|
|
|
|
|
|
-- | Ensures that a service is running. Does not ensure that
|
|
|
|
-- any package providing that service is installed. See
|
|
|
|
-- Apt.serviceInstalledRunning
|
|
|
|
--
|
|
|
|
-- Note that due to the general poor state of init scripts, the best
|
|
|
|
-- we can do is try to start the service, and if it fails, assume
|
|
|
|
-- this means it's already running.
|
|
|
|
running :: ServiceName -> Property
|
2014-12-08 05:22:29 +00:00
|
|
|
running = signaled "start" "running"
|
2014-04-08 23:31:03 +00:00
|
|
|
|
|
|
|
restarted :: ServiceName -> Property
|
2014-12-08 05:22:29 +00:00
|
|
|
restarted = signaled "restart" "restarted"
|
2014-04-10 05:46:33 +00:00
|
|
|
|
|
|
|
reloaded :: ServiceName -> Property
|
2014-12-08 05:22:29 +00:00
|
|
|
reloaded = signaled "reload" "reloaded"
|
|
|
|
|
|
|
|
signaled :: String -> Desc -> ServiceName -> Property
|
|
|
|
signaled cmd desc svc = property (desc ++ " " ++ svc) $ do
|
2014-04-10 05:46:33 +00:00
|
|
|
void $ ensureProperty $
|
2014-12-08 05:22:29 +00:00
|
|
|
scriptProperty ["service " ++ shellEscape svc ++ " " ++ cmd ++ " >/dev/null 2>&1 || true"]
|
2014-04-10 05:46:33 +00:00
|
|
|
return NoChange
|