|
1 | 1 | module Node.Crypto.Decipher |
2 | 2 | ( Decipher |
3 | | - , fromHex |
4 | | - , fromBase64 |
5 | | - , createDecipher |
| 3 | + , createDecipheriv |
6 | 4 | , update |
7 | 5 | , final |
8 | 6 | ) where |
9 | 7 |
|
10 | | -import Prelude |
| 8 | +import Data.Maybe (Maybe) |
| 9 | +import Data.Nullable (Nullable, toNullable) |
11 | 10 | import Effect (Effect) |
12 | | -import Node.Encoding (Encoding(UTF8, Hex, Base64)) |
13 | | -import Node.Buffer (Buffer, fromString, toString, concat) |
14 | | -import Node.Crypto.Cipher (Algorithm, Password) |
15 | | - |
| 11 | +import Effect.Uncurried (EffectFn1, EffectFn2, EffectFn3, runEffectFn1, runEffectFn2, runEffectFn3) |
| 12 | +import Node.Buffer (Buffer) |
| 13 | + |
| 14 | +-- | [https://nodejs.org/api/crypto.html#crypto_class_decipher](https://nodejs.org/api/crypto.html#crypto_class_decipher) |
| 15 | +-- | |
| 16 | +-- | Usage: |
| 17 | +-- | |
| 18 | +-- | ``` |
| 19 | +-- | buf <- Buffer.fromString "434cf3b56614fc8eb186ea866fbd33b4" Hex |
| 20 | +-- | pbuf <- Buffer.fromString "password" UTF8 |
| 21 | +-- | sbuf <- Buffer.fromString "salt" UTF8 |
| 22 | +-- | key <- Crypto.scryptSync pbuf sbuf 32 |
| 23 | +-- | iv <- Buffer.fromString "iviviviviviviviv" UTF8 |
| 24 | +-- | dec <- Decipher.createDecipheriv "aes256" key (Just iv) |
| 25 | +-- | rbuf1 <- Decipher.update buf dec |
| 26 | +-- | rbuf2 <- Decipher.final dec |
| 27 | +-- | Buffer.concat [ rbuf1, rbuf2 ] >>= Buffer.toString UTF8 |
| 28 | +-- | ``` |
16 | 29 | foreign import data Decipher :: Type |
17 | 30 |
|
18 | | -fromHex |
19 | | - :: Algorithm |
20 | | - -> Password |
21 | | - -> String |
22 | | - -> Effect String |
23 | | -fromHex alg password str = decipher alg password str Hex |
24 | | - |
25 | | -fromBase64 |
26 | | - :: Algorithm |
27 | | - -> Password |
28 | | - -> String |
29 | | - -> Effect String |
30 | | -fromBase64 alg password str = decipher alg password str Base64 |
31 | | - |
32 | | -decipher |
33 | | - :: Algorithm |
34 | | - -> Password |
35 | | - -> String |
36 | | - -> Encoding |
37 | | - -> Effect String |
38 | | -decipher alg password str enc = do |
39 | | - buf <- fromString str enc |
40 | | - dec <- createDecipher alg password |
41 | | - rbuf1 <- update dec buf |
42 | | - rbuf2 <- final dec |
43 | | - rbuf <- concat [ rbuf1, rbuf2 ] |
44 | | - toString UTF8 rbuf |
45 | | - |
46 | | -createDecipher :: Algorithm -> Password -> Effect Decipher |
47 | | -createDecipher alg password = _createDecipher (show alg) password |
| 31 | +createDecipheriv :: String -> Buffer -> Maybe Buffer -> Effect Decipher |
| 32 | +createDecipheriv alg key iv = |
| 33 | + runEffectFn3 createDecipherivImpl alg key (toNullable iv) |
48 | 34 |
|
49 | | -foreign import _createDecipher |
50 | | - :: String |
51 | | - -> String |
52 | | - -> Effect Decipher |
| 35 | +update :: Buffer -> Decipher -> Effect Buffer |
| 36 | +update buf decipher = runEffectFn2 updateImpl buf decipher |
53 | 37 |
|
54 | | -foreign import update :: Decipher -> Buffer -> Effect Buffer |
| 38 | +final :: Decipher -> Effect Buffer |
| 39 | +final decipher = runEffectFn1 finalImpl decipher |
55 | 40 |
|
56 | | -foreign import final :: Decipher -> Effect Buffer |
| 41 | +foreign import createDecipherivImpl :: EffectFn3 String Buffer (Nullable Buffer) Decipher |
| 42 | +foreign import updateImpl :: EffectFn2 Buffer Decipher Buffer |
| 43 | +foreign import finalImpl :: EffectFn1 Decipher Buffer |
0 commit comments