1
0
mirror of https://github.com/redelmann/scat synced 2025-01-09 22:24:19 +01:00

Using Scrypt instead of SHA-512.

This commit is contained in:
Romain Edelmann 2013-08-10 00:13:45 +02:00
parent b18c63c837
commit b44ea90397
2 changed files with 11 additions and 11 deletions

View File

@ -10,7 +10,7 @@ name: scat
-- PVP summary: +-+------- breaking API changes
-- | | +----- non-breaking API additions
-- | | | +--- code changes with no API change
version: 0.1.0.0
version: 0.2.0.0
-- A short (one-line) description of the package.
synopsis: Generates unique passwords for various websites from a single password.
@ -57,5 +57,5 @@ executable scat
other-modules: Scat.Builder, Scat.Schemas, Scat.Options, Scat.Utils.Permutation, Paths_scat
-- Other library packages from which modules are imported.
build-depends: base ==4.5.*, SHA ==1.6.*, bytestring ==0.9.*, optparse-applicative ==0.5.*, mtl ==2.1.*, vector ==0.10.*
build-depends: base ==4.5.*, scrypt ==0.3.*, bytestring ==0.9.*, optparse-applicative ==0.5.*, mtl ==2.1.*, vector ==0.10.*

View File

@ -3,16 +3,14 @@
-- | Password scatterer.
module Main (main) where
import Data.Monoid
import Data.Digest.Pure.SHA
import Data.ByteString.Lazy (ByteString)
import Data.ByteString (ByteString)
import Data.ByteString (unpack)
import qualified Data.ByteString.Char8 as C
import qualified Data.ByteString.Lazy.Char8 as LC
import qualified Data.ByteString.Lazy as BS
import System.IO
import System.Exit
import Control.Exception
import Control.Monad.Reader
import Crypto.Scrypt
import Scat.Schemas
import Scat.Builder
@ -20,7 +18,10 @@ import Scat.Options
-- | Generates the seed integer given a key and a password.
scatter :: ByteString -> ByteString -> Integer
scatter k pw = integerDigest $ sha512 (k <> pw)
scatter k pw = foldr (\ c s -> fromIntegral c + 256 * s) 0 $
unpack $ unHash $ scrypt params (Salt k) (Pass pw)
where
Just params = scryptParams 14 8 50
-- | Main type of the program.
type Scat a = ReaderT Options IO a
@ -55,7 +56,7 @@ printVerbose str = do
getPassword :: Scat ByteString
getPassword = do
mpw <- fmap password ask
pw <- case mpw of
case mpw of
-- Ask for the password on stdin.
Nothing -> do
c <- fmap confirm ask
@ -65,7 +66,6 @@ getPassword = do
-- Retrieve the password from the arguments.
Just st -> return $ C.pack st
return $ BS.fromChunks [pw]
where
getPass = askPassword "Password: "
@ -92,7 +92,7 @@ askPassword str = do
-- | Gets the key.
getKey :: Scat ByteString
getKey = fmap (LC.pack . key) ask
getKey = fmap (C.pack . key) ask
-- | Gets the schema to generate the new password.
getSchema :: Scat Schema