package crypto
import (
"crypto/md5"
"crypto/rand"
"fmt"
"io"
"strings"
)
// GenerateMD5Hash : Generate a md5 hash from a string
func GenerateMD5Hash(str string) (string, error) {
str = strings.ToLower(strings.TrimSpace(str))
hash := md5.New()
_, err := hash.Write([]byte(str))
if err != nil {
return "", err
}
return fmt.Sprintf("%x", hash.Sum(nil)), nil
// GenerateRandomToken16 : Generates a random token 16bits long
func GenerateRandomToken16() (string, error) {
return GenerateRandomToken(16)
// GenerateRandomToken32 : Generates a random token 32bits long
func GenerateRandomToken32() (string, error) {
return GenerateRandomToken(32)
// GenerateRandomToken : Generates a random token int n long
func GenerateRandomToken(n int) (string, error) {
token := make([]byte, n)
_, err := io.ReadFull(rand.Reader, token)
// %x base 16, lower-case, two characters per byte
return fmt.Sprintf("%x", token), err