blob: 3ed4a66a77bae2ac08ab2c09ac69641bcedc6725 (
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
 | module Storage.Key (
    KeyPair(..),
    storeKey, loadKey,
) where
import Data.ByteArray
import qualified Data.ByteString.Char8 as BC
import qualified Data.ByteString.Lazy as BL
import System.FilePath
import System.IO.Error
import Storage
import Storage.Internal
class Storable pub => KeyPair sec pub | sec -> pub, pub -> sec where
    generateKeys :: Storage -> IO (sec, Stored pub)
    keyGetPublic :: sec -> Stored pub
    keyGetData :: sec -> ScrubbedBytes
    keyFromData :: ScrubbedBytes -> Stored pub -> Maybe sec
keyStorage :: Storage -> FilePath
keyStorage (Storage base) = base </> "keys"
keyFilePath :: KeyPair sec pub => Stored pub -> FilePath
keyFilePath pkey = keyStorage (storedStorage pkey) </> (BC.unpack $ showRef $ storedRef pkey)
storeKey :: KeyPair sec pub => sec -> IO ()
storeKey key = writeFileOnce (keyFilePath $ keyGetPublic key) (BL.fromStrict $ convert $ keyGetData key)
loadKey :: KeyPair sec pub => Stored pub -> IO (Maybe sec)
loadKey spub = do
    tryIOError (BC.readFile (keyFilePath spub)) >>= \case
        Right kdata -> return $ keyFromData (convert kdata) spub
        Left _ -> return Nothing
 |