Compare commits

...

2 Commits

Author SHA1 Message Date
cf26a112f2 Merge remote-tracking branch 'origin/main' 2023-03-27 01:41:06 +03:00
16583fc689 add uuid validation 2023-03-27 00:17:39 +03:00

69
osutils/data.go Normal file
View File

@ -0,0 +1,69 @@
package osutils
import (
"github.com/pkg/errors"
"unicode"
)
func UuidValidate(uuid string) error {
if len(uuid) != 36 {
return errors.New("uuid length not valid")
}
// validate first 8 octets
for i := 0; i < 8; i++ {
if !(unicode.IsLetter(rune(uuid[i])) || unicode.IsDigit(rune(uuid[i]))) && uuid[i] == '-' {
return errors.New("uuid first 8 octets not valid")
}
}
// validate separator
if uuid[8] != '-' {
return errors.New("uuid separator not valid")
}
// validate second 4 octets
for i := 9; i < 13; i++ {
if !(unicode.IsLetter(rune(uuid[i])) || unicode.IsDigit(rune(uuid[i]))) && uuid[i] == '-' {
return errors.New("uuid second 4 octets not valid")
}
}
// validate separator
if uuid[13] != '-' {
return errors.New("uuid separator not valid")
}
// validate third 4 octets
for i := 14; i < 18; i++ {
if !(unicode.IsLetter(rune(uuid[i])) || unicode.IsDigit(rune(uuid[i]))) && uuid[i] == '-' {
return errors.New("uuid third 4 octets not valid")
}
}
// validate separator
if uuid[18] != '-' {
return errors.New("uuid separator not valid")
}
// validate fourth 4 octets
for i := 19; i < 23; i++ {
if !(unicode.IsLetter(rune(uuid[i])) || unicode.IsDigit(rune(uuid[i]))) && uuid[i] == '-' {
return errors.New("uuid fourth 4 octets not valid")
}
}
// validate separator
if uuid[23] != '-' {
return errors.New("uuid separator not valid")
}
// validate fourth 4 octets
for i := 24; i < 36; i++ {
if !(unicode.IsLetter(rune(uuid[i])) || unicode.IsDigit(rune(uuid[i]))) && uuid[i] == '-' {
return errors.New("uuid fifth 12 octets not valid")
}
}
return nil
}