License | Apache 2.0 |
---|---|
Maintainer | smokejumperit@gmail.com |
Stability | experimental |
Safe Haskell | Safe-Inferred |
Language | Haskell2010 |
This generates unique (guaranteed) identifiers build from a timestamp, counter, and node id. Identifiers are convertible to values which are monotonically increasing with respect to time.
Synopsis
- newSnowcheckedGen :: MonadIO io => SnowcheckedConfig -> Word256 -> io SnowcheckedGen
- nextFlake :: MonadIO io => SnowcheckedGen -> io Flake
- data SnowcheckedConfig = SnowcheckedConfig {}
- data SnowcheckedGen
- data Flake
- snowcheckedConfigBitCount :: SnowcheckedConfig -> Word32
- uniqueFlakeCount :: SnowcheckedConfig -> Integer
Documentation
newSnowcheckedGen :: MonadIO io => SnowcheckedConfig -> Word256 -> io SnowcheckedGen Source #
Create a new generator. Takes a configuration and node id. The node id may be any
value that fits in a Word256
, but it will be truncated to the number of bits specified
in the provided configuration.
data SnowcheckedConfig Source #
Configuration that specifies how many bits are used for each part of the id. These values are not validated and may be any legal value for the type.
The default value provided by def
is 64 bits in total length, just like
the original Snowflake algorithm.
Note that specifying 0 check bits results in the normal Snowflake generation.
Setting confTimeBits
or confCountBits
near zero will significantly limit
the total number of UIDs that can be generated, as well as the throughput of
the UID generation.
SnowcheckedConfig | |
|
Instances
data SnowcheckedGen Source #
The state that needs to be communicated between flake generation calls. This should be treated as opaque by consumers of this library: messing about with its internals may cause your code to hang indefinitely.
The state of a given generated instance. Note that the actual value is calculated on demand.
Instances
Generic Flake Source # | |
Show Flake Source # | |
NFData Flake Source # | |
Defined in Data.Snowchecked.Types | |
Eq Flake Source # | |
Ord Flake Source # | |
type Rep Flake Source # | |
Defined in Data.Snowchecked.Types type Rep Flake = D1 ('MetaData "Flake" "Data.Snowchecked.Types" "snowchecked-0.0.2.0-JwkIfxT25kc6AQyhojYiCd" 'False) (C1 ('MetaCons "Flake" 'PrefixI 'True) ((S1 ('MetaSel ('Just "flakeTime") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 Word256) :*: S1 ('MetaSel ('Just "flakeCount") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 Word256)) :*: (S1 ('MetaSel ('Just "flakeNodeId") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 Word256) :*: S1 ('MetaSel ('Just "flakeConfig") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 SnowcheckedConfig)))) |
uniqueFlakeCount :: SnowcheckedConfig -> Integer Source #
Provides the count of total number of unique flakes possibly generated by a node using this configuration.