statping/utils/encryption.go

51 lines
1.5 KiB
Go
Raw Normal View History

2018-12-04 05:57:11 +00:00
// Statping
2018-08-16 06:22:20 +00:00
// Copyright (C) 2018. Hunter Long and the project contributors
// Written by Hunter Long <info@socialeck.com> and the project contributors
//
2020-03-09 18:17:55 +00:00
// https://github.com/statping/statping
2018-08-16 06:22:20 +00:00
//
// The licenses for most software and other practical works are designed
// to take away your freedom to share and change the works. By contrast,
// the GNU General Public License is intended to guarantee your freedom to
// share and change all versions of a program--to make sure it remains free
// software for all its users.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
2018-06-30 00:57:05 +00:00
package utils
import (
2020-03-16 06:51:15 +00:00
"crypto/sha256"
2018-06-30 00:57:05 +00:00
"fmt"
"golang.org/x/crypto/bcrypt"
"math/rand"
2018-10-07 22:38:56 +00:00
"time"
2018-06-30 00:57:05 +00:00
)
// HashPassword returns the bcrypt hash of a password string
2018-06-30 00:57:05 +00:00
func HashPassword(password string) string {
bytes, _ := bcrypt.GenerateFromPassword([]byte(password), 14)
return string(bytes)
}
// NewSHA1Hash returns a random SHA1 hash based on a specific length
2020-03-16 06:51:15 +00:00
func NewSHA256Hash() string {
d := make([]byte, 10)
rand.Seed(Now().UnixNano())
2020-03-19 01:50:53 +00:00
rand.Read(d)
return fmt.Sprintf("%x", sha256.Sum256(d))
2018-06-30 00:57:05 +00:00
}
var characterRunes = []rune("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789")
// RandomString generates a random string of n length
func RandomString(n int) string {
b := make([]rune, n)
2018-10-07 22:38:56 +00:00
rand.Seed(time.Now().UnixNano())
2018-06-30 00:57:05 +00:00
for i := range b {
b[i] = characterRunes[rand.Intn(len(characterRunes))]
}
return string(b)
}