Use a fully random async_id rather than a uuid
This commit is contained in:
parent
4a49c3940a
commit
b1f9139ca5
@ -39,7 +39,7 @@ func create_rc_CMD_NAME(args []string) (*utils.RemoteControlCmd, error) {
|
|||||||
NoResponse: NO_RESPONSE_BASE,
|
NoResponse: NO_RESPONSE_BASE,
|
||||||
}
|
}
|
||||||
if IS_ASYNC {
|
if IS_ASYNC {
|
||||||
async_id, err := utils.HumanUUID4()
|
async_id, err := utils.HumanRandomId(128)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|||||||
@ -3,6 +3,7 @@
|
|||||||
package utils
|
package utils
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/rand"
|
||||||
"math"
|
"math"
|
||||||
"math/big"
|
"math/big"
|
||||||
|
|
||||||
@ -70,6 +71,15 @@ func CreateShortUUID(alphabet string) *ShortUUID {
|
|||||||
return &ans
|
return &ans
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (self *ShortUUID) Random(num_bits int64) (string, error) {
|
||||||
|
max := big.NewInt(0).Exp(big.NewInt(2), big.NewInt(num_bits), nil)
|
||||||
|
bi, err := rand.Int(rand.Reader, max)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return num_to_string(bi, self.alphabet, &self.alphabet_len, self.pad_to_length), nil
|
||||||
|
}
|
||||||
|
|
||||||
func (self *ShortUUID) Uuid4() (string, error) {
|
func (self *ShortUUID) Uuid4() (string, error) {
|
||||||
b, err := uuid.NewRandom()
|
b, err := uuid.NewRandom()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -92,3 +102,10 @@ func HumanUUID4() (string, error) {
|
|||||||
}
|
}
|
||||||
return HumanUUID.Uuid4()
|
return HumanUUID.Uuid4()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func HumanRandomId(num_bits int64) (string, error) {
|
||||||
|
if HumanUUID == nil {
|
||||||
|
HumanUUID = CreateShortUUID(HUMAN_ALPHABET)
|
||||||
|
}
|
||||||
|
return HumanUUID.Random(num_bits)
|
||||||
|
}
|
||||||
|
|||||||
@ -8,11 +8,11 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func TestShortUUID(t *testing.T) {
|
func TestShortUUID(t *testing.T) {
|
||||||
a, err := HumanUUID4()
|
a, err := HumanRandomId(128)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
b, err := HumanUUID4()
|
b, err := HumanRandomId(128)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user