summaryrefslogtreecommitdiff
path: root/custom/notify-user.nix
blob: 17123e476bd9b9709d0a6554b99bd9a84f87f730 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
{ stdenv, writeTextFile
, ghcWithPackages
, user ? "gkleen"
# , libnotify
}:

stdenv.mkDerivation {
  name = ''notify-${user}'';
  src = writeTextFile { name = ''notify-${user}.hs''; text = ''
    {-# LANGUAGE ViewPatterns #-}
  
    import System.FilePath.Glob (glob)
    import System.Environment (setEnv, getArgs)
    import System.Process (spawnProcess, waitForProcess)
    import System.Exit (exitWith, ExitCode(..))

    import Data.List (isPrefixOf, dropWhile, dropWhileEnd, init)
    import Data.Char (isSpace)

    import Control.Monad (forM_, void)

    import qualified Libnotify as Notify
    import Data.Monoid

    main = do
      envFiles <- glob "/home/${user}/.dbus/session-bus/*"
      forM_ envFiles $ \envFile -> do
        sessionAddr <- unQuote . tail . snd . break (== '=') . head . filter ("DBUS_SESSION_BUS_ADDRESS=" `isPrefixOf`) . lines <$> readFile envFile
        setEnv "DBUS_SESSION_BUS_ADDRESS" sessionAddr
        lines <- lines <$> getContents
        case lines of
          ((trim -> app):(trim -> summary):(trim . unlines -> contents)) -> do
            Notify.display_ $ Notify.appName app <> Notify.summary summary <> Notify.body contents
          _ -> exitWith $ ExitFailure 2
      where
        trim = dropWhileEnd isSpace . dropWhile isSpace
        unQuote ('\''':xs) = init xs
        unQuote ('"':xs) = init xs
        unQuote xs = xs
  ''; };
  phases = [ "buildPhase" "installPhase" ];
  buildPhase = ''
    ${ghcWithPackages (p: with p; [ Glob process libnotify ])}/bin/ghc -odir . -hidir . $src -o notify-${user}
  '';
  installPhase = ''
    mkdir -p $out/bin
    cp notify-${user} $out/bin
    chmod +x $out/bin/notify-${user}
  '';
}