mmzk-typeid-0.6.0.0: A TypeID implementation for Haskell
LicenseMIT
Maintainermmzk1526@outlook.com
PortabilityGHC
Safe HaskellSafe-Inferred
LanguageHaskell2010

Data.TypeID.V1

Description

TypeID with UUIDv1.

Synopsis

Data types

type TypeIDV1 = TypeID' 'V1 Source #

Similar to TypeID, but uses UUIDv1.

getPrefix :: IDType a => a -> Text Source #

Get the prefix of the identifier.

getUUID :: IDType a => a -> UUID Source #

Get the UUID suffix of the identifier.

TypeIDV1 generation (TypeIDV1-specific)

genTypeID :: MonadIO m => Text -> m TypeIDV1 Source #

Generate a new TypeIDV1 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 TypeIDV1 Source #

Obtain a TypeIDV1 from a prefix and a UUID.

TypeIDV1 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 (TypeIDV1-specific)

checkPrefix :: Text -> Maybe TypeIDError Source #

Check if the given prefix is a valid TypeIDV1 prefix.

checkTypeID :: TypeIDV1 -> Maybe TypeIDError Source #

Check if the prefix is valid and the suffix UUID has the correct v1 version and variant.

Validation (class methods)

checkID :: forall a. IDGen a => a -> Maybe TypeIDError Source #

Check the validity of the identifier.

Encoding & decoding (TypeIDV1-specific)

toString :: TypeIDV1 -> String Source #

Pretty-print a TypeIDV1. It is id2String with concrete type.

toText :: TypeIDV1 -> Text Source #

Pretty-print a TypeIDV1 to strict Text. It is id2Text with concrete type.

toByteString :: TypeIDV1 -> ByteString Source #

Pretty-print a TypeIDV1 to lazy ByteString. It is id2ByteString with concrete type.

parseString :: String -> Either TypeIDError TypeIDV1 Source #

Parse a TypeIDV1 from its String representation. It is string2ID with concrete type.

parseText :: Text -> Either TypeIDError TypeIDV1 Source #

Parse a TypeIDV1 from its string representation as a strict Text. It is text2ID with concrete type.

parseByteString :: ByteString -> Either TypeIDError TypeIDV1 Source #

Parse a TypeIDV1 from its string representation as a lazy ByteString. It is byteString2ID with concrete type.

parseStringM :: MonadIO m => String -> m TypeIDV1 Source #

Parse a TypeIDV1 from its String representation, throwing an error when the parsing fails. It is string2IDM with concrete type.

parseTextM :: MonadIO m => Text -> m TypeIDV1 Source #

Parse a TypeIDV1 from its string representation as a strict Text, throwing an error when the parsing fails. It is text2IDM with concrete type.

parseByteStringM :: MonadIO m => ByteString -> m TypeIDV1 Source #

Parse a TypeIDV1 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)

id2String :: IDConv a => a -> String Source #

Pretty-print the identifier to a String.

id2Text :: IDConv a => a -> Text Source #

Pretty-print the identifier to a strict Text.

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.