2013-02-09 04:52:40 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2013-02-11 19:27:38 +00:00
|
|
|
"math/rand"
|
2013-02-09 04:52:40 +00:00
|
|
|
"crypto/md5"
|
|
|
|
"fmt"
|
|
|
|
"hash/adler32"
|
|
|
|
"io"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2013-02-11 19:27:38 +00:00
|
|
|
func Rand64() int64 {
|
|
|
|
return rand.Int63()
|
|
|
|
}
|
|
|
|
|
2013-02-09 04:52:40 +00:00
|
|
|
/* Convinience method for getting md5 sum of a string */
|
|
|
|
func GetMd5FromString(blob string) (sum []byte) {
|
|
|
|
h := md5.New()
|
|
|
|
defer h.Reset()
|
|
|
|
io.WriteString(h,blob)
|
|
|
|
return h.Sum(nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Convinience method for getting md5 sum of some bytes */
|
|
|
|
func GetMd5FromBytes(blob []byte) (sum []byte) {
|
|
|
|
h := md5.New()
|
|
|
|
defer h.Reset()
|
|
|
|
h.Write(blob)
|
|
|
|
return h.Sum(nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
/* get a small, decently unique hash */
|
|
|
|
func GetSmallHash() (small_hash string) {
|
|
|
|
h := adler32.New()
|
|
|
|
io.WriteString(h, fmt.Sprintf("%d", time.Now().Unix()))
|
|
|
|
return fmt.Sprintf("%X", h.Sum(nil))
|
|
|
|
}
|
|
|
|
|