License | MIT |
---|---|
Maintainer | mmzk1526@outlook.com |
Portability | GHC |
Safe Haskell | Safe-Inferred |
Language | Haskell2010 |
Synopsis
- type TypeIDV5 = TypeID' 'V5
- getPrefix :: IDType a => a -> Text
- getUUID :: IDType a => a -> UUID
- genTypeID :: MonadIO m => Text -> UUID -> [Word8] -> m TypeIDV5
- decorateTypeID :: Text -> UUID -> Either TypeIDError TypeIDV5
- genID :: forall a m. (IDGen a, MonadIO m) => GenFunc (IDGenPrefix a) (IDGenReq a (m a))
- decorate :: forall a. IDGen a => GenFunc (IDGenPrefix a) (UUID -> ResWithErr (IDGenPrefix a) a)
- checkPrefix :: Text -> Maybe TypeIDError
- checkTypeID :: TypeIDV5 -> Maybe TypeIDError
- checkID :: forall a. IDGen a => a -> Maybe TypeIDError
- toString :: TypeIDV5 -> String
- toText :: TypeIDV5 -> Text
- toByteString :: TypeIDV5 -> ByteString
- parseString :: String -> Either TypeIDError TypeIDV5
- parseText :: Text -> Either TypeIDError TypeIDV5
- parseByteString :: ByteString -> Either TypeIDError TypeIDV5
- parseStringM :: MonadIO m => String -> m TypeIDV5
- parseTextM :: MonadIO m => Text -> m TypeIDV5
- parseByteStringM :: MonadIO m => ByteString -> m TypeIDV5
- id2String :: IDConv a => a -> String
- id2Text :: IDConv a => a -> Text
- id2ByteString :: IDConv a => a -> ByteString
- string2ID :: IDConv a => String -> Either TypeIDError a
- text2ID :: IDConv a => Text -> Either TypeIDError a
- byteString2ID :: IDConv a => ByteString -> Either TypeIDError a
- string2IDM :: (IDConv a, MonadIO m) => String -> m a
- text2IDM :: (IDConv a, MonadIO m) => Text -> m a
- byteString2IDM :: (IDConv a, MonadIO m) => ByteString -> m a
Data types
TypeIDV5
generation (TypeIDV5
-specific)
genTypeID :: MonadIO m => Text -> UUID -> [Word8] -> m TypeIDV5 Source #
Generate a new TypeIDV5
from a prefix.
It throws a TypeIDError
if the prefix does not match the specification,
namely if it's longer than 63 characters or if it contains characters other
than lowercase latin letters.
decorateTypeID :: Text -> UUID -> Either TypeIDError TypeIDV5 Source #
TypeIDV5
generation (class methods)
genID :: forall a m. (IDGen a, MonadIO m) => GenFunc (IDGenPrefix a) (IDGenReq a (m a)) Source #
Generate a new identifier with the given prefix.
decorate :: forall a. IDGen a => GenFunc (IDGenPrefix a) (UUID -> ResWithErr (IDGenPrefix a) a) Source #
Generate a new identifier with the given prefix and UUID
suffix.
Validation (TypeIDV5
-specific)
checkPrefix :: Text -> Maybe TypeIDError Source #
Check if the given prefix is a valid TypeIDV5
prefix.
checkTypeID :: TypeIDV5 -> Maybe TypeIDError Source #
Check if the prefix is valid and the suffix UUID
has the correct v5
version and variant.
Validation (class methods)
checkID :: forall a. IDGen a => a -> Maybe TypeIDError Source #
Check the validity of the identifier.
Encoding & decoding (TypeIDV5
-specific)
toByteString :: TypeIDV5 -> ByteString Source #
Pretty-print a TypeIDV5
to lazy ByteString
. It is id2ByteString
with concrete type.
parseByteString :: ByteString -> Either TypeIDError TypeIDV5 Source #
Parse a TypeIDV5
from its string representation as a lazy ByteString
.
It is byteString2ID
with concrete type.
parseStringM :: MonadIO m => String -> m TypeIDV5 Source #
Parse a TypeIDV5
from its String
representation, throwing an error when
the parsing fails. It is string2IDM
with concrete type.
parseByteStringM :: MonadIO m => ByteString -> m TypeIDV5 Source #
Parse a TypeIDV5
from its string representation as a lazy ByteString
,
throwing an error when the parsing fails. It is byteString2IDM
with
concrete type.
Encoding & decoding (class methods)
id2ByteString :: IDConv a => a -> ByteString Source #
Pretty-print the identifier to a lazy ByteString
.
string2ID :: IDConv a => String -> Either TypeIDError a Source #
Parse the identifier from its String
representation.
text2ID :: IDConv a => Text -> Either TypeIDError a Source #
Parse the identifier from its string representation as a strict Text
.
byteString2ID :: IDConv a => ByteString -> Either TypeIDError a Source #
Parse the identifier from its string representation as a lazy
ByteString
.
string2IDM :: (IDConv a, MonadIO m) => String -> m a Source #
Parse the identifier from its String
representation, throwing an error
when the parsing fails.
text2IDM :: (IDConv a, MonadIO m) => Text -> m a Source #
Parse the identifier from its string representation as a strict Text
,
throwing an error when the parsing fails.
byteString2IDM :: (IDConv a, MonadIO m) => ByteString -> m a Source #
Parse the identifier from its string representation as a lazy
ByteString
, throwing an error when the parsing fails.