diff options
author | Joachim Breitner <mail@joachim-breitner.de> | 2015-02-18 10:18:16 +0100 |
---|---|---|
committer | Joachim Breitner <mail@joachim-breitner.de> | 2015-02-18 10:18:16 +0100 |
commit | c994eb6e375d47c6ad065ded4ec66936a3047043 (patch) | |
tree | c0137faa7dc090971fe8c24aa2b8a6352ae968e4 /XMonad/Prompt | |
parent | df6884bfa4b39f41dc2165bd380e32a18eaad34a (diff) | |
download | XMonadContrib-c994eb6e375d47c6ad065ded4ec66936a3047043.tar.gz XMonadContrib-c994eb6e375d47c6ad065ded4ec66936a3047043.tar.xz XMonadContrib-c994eb6e375d47c6ad065ded4ec66936a3047043.zip |
XMonad.Prompt.Pass: Handle hierachical password stores
Ignore-this: 2f0a02613780067d324b04a8cdb9c0ed
pass stores its passwords in directories, so the contents of the directory
store needs to be enumerated recursively. Alexander Sulfrian provided this
patch on the mailinglist, which I tested (it works) and cleaned up slightly.
darcs-hash:20150218091816-23c07-6951b0fd1dea96873ec7f7968e5775db8f4520be.gz
Diffstat (limited to 'XMonad/Prompt')
-rw-r--r-- | XMonad/Prompt/Pass.hs | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/XMonad/Prompt/Pass.hs b/XMonad/Prompt/Pass.hs index db4ce2d..099a1a6 100644 --- a/XMonad/Prompt/Pass.hs +++ b/XMonad/Prompt/Pass.hs @@ -50,8 +50,9 @@ import XMonad.Prompt ( XPrompt , mkXPrompt , mkComplFunFromList) import System.Directory (getDirectoryContents, getHomeDirectory) -import System.FilePath (takeBaseName, combine) +import System.FilePath (takeBaseName, takeExtension, dropExtension, combine) import System.Posix.Env (getEnv) +import XMonad.Util.Run (runProcessWithInput) -- $usages -- You can use this module with the following in your @~\/.xmonad\/xmonad.hs@: @@ -137,6 +138,14 @@ removePassword :: String -> X () removePassword passLabel = spawn $ "pass rm --force " ++ passLabel -- | Retrieve the list of passwords from the password storage 'passwordStoreDir --- -getPasswords :: String -> IO [String] -getPasswords passwordStoreDir = liftM (map takeBaseName) $ getDirectoryContents passwordStoreDir +getPasswords passwordStoreDir = do + files <- runProcessWithInput "find" [ + passwordStoreDir, + "-type", "f", + "-name", "*.gpg", + "-printf", "%P\n"] [] + return $ map removeGpgExtension $ lines files + +removeGpgExtension :: String -> String +removeGpgExtension file | takeExtension file == ".gpg" = dropExtension file + | otherwise = file |