WIP name dbus connections
This commit is contained in:
parent
58b68f298c
commit
78ba3173c3
|
@ -55,6 +55,12 @@ import qualified RIO.Text as T
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
-- Type-safe client
|
-- Type-safe client
|
||||||
|
|
||||||
|
-- data NamedConnection c = NamedConnection
|
||||||
|
-- { ncClient :: Client
|
||||||
|
-- , ncName :: Maybe BusName
|
||||||
|
-- , ncType :: c
|
||||||
|
-- }
|
||||||
|
|
||||||
class SafeClient c where
|
class SafeClient c where
|
||||||
toClient :: c -> Client
|
toClient :: c -> Client
|
||||||
|
|
||||||
|
|
|
@ -76,11 +76,11 @@ callGetBrightness
|
||||||
-> m (Maybe n)
|
-> m (Maybe n)
|
||||||
callGetBrightness BrightnessConfig {bcPath = p, bcInterface = i} =
|
callGetBrightness BrightnessConfig {bcPath = p, bcInterface = i} =
|
||||||
either (const Nothing) bodyGetBrightness
|
either (const Nothing) bodyGetBrightness
|
||||||
<$> callMethod xmonadBusName p i memGet
|
<$> callMethod xmonadSesBusName p i memGet
|
||||||
|
|
||||||
signalDep :: BrightnessConfig m a b -> DBusDependency_ SesClient
|
signalDep :: BrightnessConfig m a b -> DBusDependency_ SesClient
|
||||||
signalDep BrightnessConfig {bcPath = p, bcInterface = i} =
|
signalDep BrightnessConfig {bcPath = p, bcInterface = i} =
|
||||||
Endpoint [] xmonadBusName p i $ Signal_ memCur
|
Endpoint [] xmonadSesBusName p i $ Signal_ memCur
|
||||||
|
|
||||||
matchSignal
|
matchSignal
|
||||||
:: ( HasClient env
|
:: ( HasClient env
|
||||||
|
@ -118,7 +118,7 @@ brightnessExporter q ful deps bc@BrightnessConfig {bcName = n} cl =
|
||||||
Sometimes (T.append n " DBus Interface") q [Subfeature root "exporter"]
|
Sometimes (T.append n " DBus Interface") q [Subfeature root "exporter"]
|
||||||
where
|
where
|
||||||
root = DBusRoot_ (exportBrightnessControlsInner bc) tree cl
|
root = DBusRoot_ (exportBrightnessControlsInner bc) tree cl
|
||||||
tree = listToAnds (Bus ful xmonadBusName) $ fmap DBusIO deps
|
tree = listToAnds (Bus ful xmonadSesBusName) $ fmap DBusIO deps
|
||||||
|
|
||||||
exportBrightnessControlsInner
|
exportBrightnessControlsInner
|
||||||
:: (MonadReader env m, HasLogFunc env, MonadUnliftIO m, RealFrac b)
|
:: (MonadReader env m, HasLogFunc env, MonadUnliftIO m, RealFrac b)
|
||||||
|
@ -180,8 +180,8 @@ callBacklight
|
||||||
callBacklight q cl BrightnessConfig {bcPath = p, bcInterface = i, bcName = n} controlName m =
|
callBacklight q cl BrightnessConfig {bcPath = p, bcInterface = i, bcName = n} controlName m =
|
||||||
Sometimes (T.unwords [n, controlName]) q [Subfeature root "method call"]
|
Sometimes (T.unwords [n, controlName]) q [Subfeature root "method call"]
|
||||||
where
|
where
|
||||||
root = DBusRoot_ cmd (Only_ $ Endpoint [] xmonadBusName p i $ Method_ m) cl
|
root = DBusRoot_ cmd (Only_ $ Endpoint [] xmonadSesBusName p i $ Method_ m) cl
|
||||||
cmd c = void $ withDIO c $ callMethod xmonadBusName p i m
|
cmd c = void $ withDIO c $ callMethod xmonadSesBusName p i m
|
||||||
|
|
||||||
bodyGetBrightness :: Num a => [Variant] -> Maybe a
|
bodyGetBrightness :: Num a => [Variant] -> Maybe a
|
||||||
bodyGetBrightness [b] = fromIntegral <$> (fromVariant b :: Maybe Int32)
|
bodyGetBrightness [b] = fromIntegral <$> (fromVariant b :: Maybe Int32)
|
||||||
|
|
|
@ -2,7 +2,8 @@
|
||||||
-- High-level interface for managing XMonad's DBus
|
-- High-level interface for managing XMonad's DBus
|
||||||
|
|
||||||
module XMonad.Internal.DBus.Common
|
module XMonad.Internal.DBus.Common
|
||||||
( xmonadBusName
|
( xmonadSesBusName
|
||||||
|
, xmonadSysBusName
|
||||||
, btBus
|
, btBus
|
||||||
, notifyBus
|
, notifyBus
|
||||||
, notifyPath
|
, notifyPath
|
||||||
|
@ -12,8 +13,11 @@ where
|
||||||
|
|
||||||
import DBus
|
import DBus
|
||||||
|
|
||||||
xmonadBusName :: BusName
|
xmonadSesBusName :: BusName
|
||||||
xmonadBusName = busName_ "org.xmonad"
|
xmonadSesBusName = busName_ "org.xmonad.Session"
|
||||||
|
|
||||||
|
xmonadSysBusName :: BusName
|
||||||
|
xmonadSysBusName = busName_ "org.xmonad.System"
|
||||||
|
|
||||||
btBus :: BusName
|
btBus :: BusName
|
||||||
btBus = busName_ "org.bluez"
|
btBus = busName_ "org.bluez"
|
||||||
|
|
|
@ -10,7 +10,6 @@ module XMonad.Internal.DBus.Control
|
||||||
, withDBus
|
, withDBus
|
||||||
, withDBus_
|
, withDBus_
|
||||||
, connectDBus
|
, connectDBus
|
||||||
, connectDBusX
|
|
||||||
, disconnectDBus
|
, disconnectDBus
|
||||||
, disconnectDBusX
|
, disconnectDBusX
|
||||||
, getDBusClient
|
, getDBusClient
|
||||||
|
@ -23,10 +22,10 @@ where
|
||||||
|
|
||||||
import DBus
|
import DBus
|
||||||
import DBus.Client
|
import DBus.Client
|
||||||
|
import qualified Data.ByteString.Char8 as BC
|
||||||
import Data.Internal.DBus
|
import Data.Internal.DBus
|
||||||
import Data.Internal.XIO
|
import Data.Internal.XIO
|
||||||
import RIO
|
import RIO
|
||||||
import qualified RIO.Text as T
|
|
||||||
import XMonad.Internal.DBus.Brightness.ClevoKeyboard
|
import XMonad.Internal.DBus.Brightness.ClevoKeyboard
|
||||||
import XMonad.Internal.DBus.Brightness.IntelBacklight
|
import XMonad.Internal.DBus.Brightness.IntelBacklight
|
||||||
import XMonad.Internal.DBus.Common
|
import XMonad.Internal.DBus.Common
|
||||||
|
@ -49,8 +48,21 @@ withDBusX
|
||||||
=> (DBusState -> m a)
|
=> (DBusState -> m a)
|
||||||
-> m (Maybe a)
|
-> m (Maybe a)
|
||||||
withDBusX f = withDBus $ \db -> do
|
withDBusX f = withDBus $ \db -> do
|
||||||
forM (dbSesClient db) $ \ses -> do
|
case (dbSesClient db, dbSysClient db) of
|
||||||
bracket_ (requestXMonadName ses) (releaseXMonadName ses) $ f db
|
(Just ses, Just sys) -> do
|
||||||
|
res <-
|
||||||
|
bracket_
|
||||||
|
( do
|
||||||
|
requestBusName xmonadSesBusName ses
|
||||||
|
requestBusName xmonadSysBusName sys
|
||||||
|
)
|
||||||
|
( do
|
||||||
|
releaseBusName xmonadSesBusName ses
|
||||||
|
releaseBusName xmonadSysBusName sys
|
||||||
|
)
|
||||||
|
$ f db
|
||||||
|
return $ Just res
|
||||||
|
_ -> return Nothing
|
||||||
|
|
||||||
withDBus_
|
withDBus_
|
||||||
:: (MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
:: (MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
||||||
|
@ -80,14 +92,14 @@ disconnectDBus db = disc dbSesClient >> disc dbSysClient
|
||||||
disc :: (MonadUnliftIO m, SafeClient c) => (DBusState -> Maybe c) -> m ()
|
disc :: (MonadUnliftIO m, SafeClient c) => (DBusState -> Maybe c) -> m ()
|
||||||
disc f = maybe (return ()) disconnectDBusClient $ f db
|
disc f = maybe (return ()) disconnectDBusClient $ f db
|
||||||
|
|
||||||
-- | Connect to the DBus and request the XMonad name
|
-- -- | Connect to the DBus and request the XMonad name
|
||||||
connectDBusX
|
-- connectDBusX
|
||||||
:: (MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
-- :: (MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
||||||
=> m DBusState
|
-- => m DBusState
|
||||||
connectDBusX = do
|
-- connectDBusX = do
|
||||||
db <- connectDBus
|
-- db <- connectDBus
|
||||||
forM_ (dbSesClient db) requestXMonadName
|
-- requestXMonadName2 db
|
||||||
return db
|
-- return db
|
||||||
|
|
||||||
-- | Disconnect from DBus and release the XMonad name
|
-- | Disconnect from DBus and release the XMonad name
|
||||||
disconnectDBusX
|
disconnectDBusX
|
||||||
|
@ -95,9 +107,18 @@ disconnectDBusX
|
||||||
=> DBusState
|
=> DBusState
|
||||||
-> m ()
|
-> m ()
|
||||||
disconnectDBusX db = do
|
disconnectDBusX db = do
|
||||||
forM_ (dbSesClient db) releaseXMonadName
|
forM_ (dbSesClient db) $ releaseBusName xmonadSesBusName
|
||||||
|
forM_ (dbSysClient db) $ releaseBusName xmonadSysBusName
|
||||||
disconnectDBus db
|
disconnectDBus db
|
||||||
|
|
||||||
|
-- requestXMonadName2
|
||||||
|
-- :: (MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
||||||
|
-- => DBusState
|
||||||
|
-- -> m ()
|
||||||
|
-- requestXMonadName2 db = do
|
||||||
|
-- forM_ (dbSesClient db) requestXMonadName
|
||||||
|
-- forM_ (dbSysClient db) requestXMonadName
|
||||||
|
|
||||||
withDBusInterfaces
|
withDBusInterfaces
|
||||||
:: DBusState
|
:: DBusState
|
||||||
-> [Maybe SesClient -> Sometimes (XIO (), XIO ())]
|
-> [Maybe SesClient -> Sometimes (XIO (), XIO ())]
|
||||||
|
@ -116,32 +137,56 @@ dbusExporters
|
||||||
=> [Maybe SesClient -> Sometimes (m (), m ())]
|
=> [Maybe SesClient -> Sometimes (m (), m ())]
|
||||||
dbusExporters = [exportScreensaver, exportIntelBacklight, exportClevoKeyboard]
|
dbusExporters = [exportScreensaver, exportIntelBacklight, exportClevoKeyboard]
|
||||||
|
|
||||||
releaseXMonadName
|
-- releaseXMonadName
|
||||||
:: (MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
-- :: (SafeClient c, MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
||||||
=> SesClient
|
-- => c
|
||||||
-> m ()
|
-- -> m ()
|
||||||
releaseXMonadName ses = do
|
-- releaseXMonadName cl = do
|
||||||
-- TODO this might error?
|
-- -- TODO this might error?
|
||||||
liftIO $ void $ releaseName (toClient ses) xmonadBusName
|
-- liftIO $ void $ releaseName (toClient cl) xmonadBusName
|
||||||
logInfo "released xmonad name"
|
-- logInfo "released xmonad name"
|
||||||
|
|
||||||
requestXMonadName
|
releaseBusName
|
||||||
:: (MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
:: (SafeClient c, MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
||||||
=> SesClient
|
=> BusName
|
||||||
|
-> c
|
||||||
-> m ()
|
-> m ()
|
||||||
requestXMonadName ses = do
|
releaseBusName n cl = do
|
||||||
res <- liftIO $ requestName (toClient ses) xmonadBusName []
|
-- TODO this might error?
|
||||||
let msg
|
liftIO $ void $ releaseName (toClient cl) n
|
||||||
| res == NamePrimaryOwner = "registering name"
|
logInfo $ "released bus name: " <> displayBusName n
|
||||||
| res == NameAlreadyOwner = "this process already owns name"
|
|
||||||
| res == NameInQueue
|
requestBusName
|
||||||
|| res == NameExists =
|
:: (SafeClient c, MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
||||||
"another process owns name"
|
=> BusName
|
||||||
| otherwise = "unknown error when requesting name"
|
-> c
|
||||||
logInfo $ msg <> ": " <> xn
|
-> m ()
|
||||||
where
|
requestBusName n cl = do
|
||||||
xn =
|
res <- try $ liftIO $ requestName (toClient cl) n []
|
||||||
Utf8Builder $
|
case res of
|
||||||
encodeUtf8Builder $
|
Left e -> logError $ displayBytesUtf8 $ BC.pack $ clientErrorMessage e
|
||||||
T.pack $
|
Right r -> do
|
||||||
formatBusName xmonadBusName
|
let msg
|
||||||
|
| r == NamePrimaryOwner = "registering name"
|
||||||
|
| r == NameAlreadyOwner = "this process already owns name"
|
||||||
|
| r == NameInQueue
|
||||||
|
|| r == NameExists =
|
||||||
|
"another process owns name"
|
||||||
|
-- this should never happen
|
||||||
|
| otherwise = "unknown error when requesting name"
|
||||||
|
logInfo $ msg <> ": " <> displayBusName n
|
||||||
|
|
||||||
|
-- requestXMonadName
|
||||||
|
-- :: (SafeClient c, MonadReader env m, HasLogFunc env, MonadUnliftIO m)
|
||||||
|
-- => c
|
||||||
|
-- -> m ()
|
||||||
|
-- requestXMonadName cl = do
|
||||||
|
-- res <- liftIO $ requestName (toClient cl) xmonadBusName []
|
||||||
|
-- let msg
|
||||||
|
-- | res == NamePrimaryOwner = "registering name"
|
||||||
|
-- | res == NameAlreadyOwner = "this process already owns name"
|
||||||
|
-- | res == NameInQueue
|
||||||
|
-- || res == NameExists =
|
||||||
|
-- "another process owns name"
|
||||||
|
-- | otherwise = "unknown error when requesting name"
|
||||||
|
-- logInfo $ msg <> ": " <> displayBusName xmonadBusName
|
||||||
|
|
|
@ -119,7 +119,7 @@ exportScreensaver ses =
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
bus = Bus [] xmonadBusName
|
bus = Bus [] xmonadSesBusName
|
||||||
ssx = DBusIO $ sysExe [Package Official "xorg-xset"] ssExecutable
|
ssx = DBusIO $ sysExe [Package Official "xorg-xset"] ssExecutable
|
||||||
|
|
||||||
callToggle
|
callToggle
|
||||||
|
@ -131,7 +131,7 @@ callToggle =
|
||||||
"screensaver toggle"
|
"screensaver toggle"
|
||||||
"dbus switch"
|
"dbus switch"
|
||||||
[]
|
[]
|
||||||
xmonadBusName
|
xmonadSesBusName
|
||||||
ssPath
|
ssPath
|
||||||
interface
|
interface
|
||||||
memToggle
|
memToggle
|
||||||
|
@ -140,7 +140,7 @@ callQuery
|
||||||
:: (HasClient env, MonadReader (env SesClient) m, MonadUnliftIO m)
|
:: (HasClient env, MonadReader (env SesClient) m, MonadUnliftIO m)
|
||||||
=> m (Maybe SSState)
|
=> m (Maybe SSState)
|
||||||
callQuery = do
|
callQuery = do
|
||||||
reply <- callMethod xmonadBusName ssPath interface memQuery
|
reply <- callMethod xmonadSesBusName ssPath interface memQuery
|
||||||
return $ either (const Nothing) bodyGetCurrentState reply
|
return $ either (const Nothing) bodyGetCurrentState reply
|
||||||
|
|
||||||
matchSignal
|
matchSignal
|
||||||
|
@ -157,4 +157,4 @@ matchSignal cb =
|
||||||
(cb . bodyGetCurrentState)
|
(cb . bodyGetCurrentState)
|
||||||
|
|
||||||
ssSignalDep :: DBusDependency_ SesClient
|
ssSignalDep :: DBusDependency_ SesClient
|
||||||
ssSignalDep = Endpoint [] xmonadBusName ssPath interface $ Signal_ memState
|
ssSignalDep = Endpoint [] xmonadSesBusName ssPath interface $ Signal_ memState
|
||||||
|
|
Loading…
Reference in New Issue