2013-05-09 13:47:24 +00:00
|
|
|
package hash
|
2013-02-09 04:52:40 +00:00
|
|
|
|
|
|
|
import (
|
2013-03-27 20:30:24 +00:00
|
|
|
"crypto/md5"
|
2013-11-05 16:34:16 +00:00
|
|
|
"crypto/sha256"
|
2013-03-27 20:30:24 +00:00
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"math/rand"
|
2013-11-05 16:34:16 +00:00
|
|
|
"strings"
|
2013-03-27 20:30:24 +00:00
|
|
|
"time"
|
2013-02-09 04:52:40 +00:00
|
|
|
)
|
|
|
|
|
2013-11-05 16:34:16 +00:00
|
|
|
func init() {
|
|
|
|
rand.Seed(time.Now().UnixNano())
|
|
|
|
}
|
|
|
|
|
2013-02-14 03:30:04 +00:00
|
|
|
func Rand64() int64 {
|
2013-03-27 20:30:24 +00:00
|
|
|
return rand.Int63()
|
2013-02-14 03:30:04 +00:00
|
|
|
}
|
|
|
|
|
2013-02-09 04:52:40 +00:00
|
|
|
/* Convinience method for getting md5 sum of a string */
|
|
|
|
func GetMd5FromString(blob string) (sum []byte) {
|
2013-03-27 20:30:24 +00:00
|
|
|
h := md5.New()
|
|
|
|
defer h.Reset()
|
|
|
|
io.WriteString(h, blob)
|
|
|
|
return h.Sum(nil)
|
2013-02-09 04:52:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Convinience method for getting md5 sum of some bytes */
|
|
|
|
func GetMd5FromBytes(blob []byte) (sum []byte) {
|
2013-03-27 20:30:24 +00:00
|
|
|
h := md5.New()
|
|
|
|
defer h.Reset()
|
|
|
|
h.Write(blob)
|
|
|
|
return h.Sum(nil)
|
2013-02-09 04:52:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* get a small, decently unique hash */
|
|
|
|
func GetSmallHash() (small_hash string) {
|
2013-11-05 16:34:16 +00:00
|
|
|
h := sha256.New()
|
2013-11-07 15:01:36 +00:00
|
|
|
io.WriteString(h, fmt.Sprintf("%d%d", Rand64()))
|
|
|
|
return strings.ToLower(fmt.Sprintf("%X", h.Sum(nil)[0:4]))
|
2013-02-09 04:52:40 +00:00
|
|
|
}
|