{-# LANGUAGE OverloadedStrings #-}
module Data.MIME.Base64
(
contentTransferEncodeBase64
, contentTransferEncodingBase64
) where
import Control.Lens (prism')
import qualified Data.ByteString as B
import qualified Data.ByteString.Base64 as B64
import Data.Word (Word8)
import Data.MIME.Types (ContentTransferEncoding)
isBase64Char :: Word8 -> Bool
isBase64Char c =
(c >= 0x41 && c <= 0x5a)
|| (c >= 0x61 && c <= 0x7a)
|| (c >= 0x30 && c <= 0x39)
|| c == 43
|| c == 47
|| c == 61
contentTransferEncodeBase64 :: B.ByteString -> B.ByteString
contentTransferEncodeBase64 = B64.joinWith "\r\n" 76 . B64.encode
contentTransferDecodeBase64 :: B.ByteString -> Either String B.ByteString
contentTransferDecodeBase64 = B64.decode . B.filter isBase64Char
contentTransferEncodingBase64 :: ContentTransferEncoding
contentTransferEncodingBase64 = prism'
contentTransferEncodeBase64
(either (const Nothing) Just . contentTransferDecodeBase64)