aboutsummaryrefslogtreecommitdiff
path: root/weed/sequence/snowflake_sequencer.go
blob: d6479fc68f572b555b2cbea00d9908ab3e4f35cb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
package sequence

import (
	"fmt"
	"hash/fnv"

	"github.com/bwmarrin/snowflake"
)

// a simple snowflake Sequencer
type SnowflakeSequencer struct {
	node *snowflake.Node
}

func NewSnowflakeSequencer(nodeid string) (*SnowflakeSequencer, error) {
	node, err := snowflake.NewNode(int64(hash(nodeid) & 0x3ff))
	if err != nil {
		fmt.Println(err)
		return nil, err
	}

	sequencer := &SnowflakeSequencer{node: node}
	return sequencer, nil
}

func hash(s string) uint32 {
	h := fnv.New32a()
	h.Write([]byte(s))
	return h.Sum32()
}

func (m *SnowflakeSequencer) NextFileId(count uint64) uint64 {
	return uint64(m.node.Generate().Int64())
}

// ignore setmax as we are snowflake
func (m *SnowflakeSequencer) SetMax(seenValue uint64) {
}

// return a new id as no Peek is stored
func (m *SnowflakeSequencer) Peek() uint64 {
	return uint64(m.node.Generate().Int64())
}