summaryrefslogtreecommitdiff
path: root/Assistant
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2012-10-18 00:29:27 -0400
committerGravatar Joey Hess <joey@kitenet.net>2012-10-20 16:21:39 -0400
commitff6df3c4eb4339ecf9905f7f7c97c5ab04f324bb (patch)
tree3f32a8ced10184bd53c2190e20c4041496300ed5 /Assistant
parentb95ae7e97b3acad9270698bc63d7c8d4c5248f2b (diff)
removed 3 partial !! and got a much nicer implementation
Yay, monadic Either!
Diffstat (limited to 'Assistant')
-rw-r--r--Assistant/Ssh.hs31
1 files changed, 21 insertions, 10 deletions
diff --git a/Assistant/Ssh.hs b/Assistant/Ssh.hs
index 59ed34497..1d1f99176 100644
--- a/Assistant/Ssh.hs
+++ b/Assistant/Ssh.hs
@@ -95,16 +95,27 @@ sshTranscript opts input = do
{- Ensure that the ssh public key doesn't include any ssh options, like
- command=foo, or other weirdness -}
validateSshPubKey :: SshPubKey -> IO ()
-validateSshPubKey pubkey = do
- let ws = words pubkey
- when (length ws > 3 || length ws < 2) $
- error $ "wrong number of words in ssh public key " ++ pubkey
- let (ssh, keytype) = separate (== '-') (ws !! 0)
- unless (ssh == "ssh" && all isAlphaNum keytype) $
- error $ "bad ssh public key prefix " ++ ws !! 0
- when (length ws == 3) $
- unless (all (\c -> isAlphaNum c || c == '@') (ws !! 2)) $
- error $ "bad comment in ssh public key " ++ pubkey
+validateSshPubKey pubkey = either error return $ check $ words pubkey
+ where
+ check [prefix, _key, comment] = do
+ checkprefix prefix
+ checkcomment comment
+ check [prefix, _key] =
+ checkprefix prefix
+ check _ = err "wrong number of words in ssh public key"
+
+ ok = Right ()
+ err msg = Left $ unwords [msg, pubkey]
+
+ checkprefix prefix
+ | ssh == "ssh" && all isAlphaNum keytype = ok
+ | otherwise = err "bad ssh public key prefix"
+ where
+ (ssh, keytype) = separate (== '-') prefix
+
+ checkcomment comment
+ | all (\c -> isAlphaNum c || c == '@') comment = ok
+ | otherwise = err "bad comment in ssh public key"
addAuthorizedKeys :: Bool -> SshPubKey -> IO Bool
addAuthorizedKeys rsynconly pubkey = boolSystem "sh"