mirror of
https://github.com/documize/community.git
synced 2025-07-19 05:09:42 +02:00
refactored salt code
This commit is contained in:
parent
6fd6bc6d26
commit
5acfae3d0d
2 changed files with 43 additions and 18 deletions
38
core/secrets/salt.go
Normal file
38
core/secrets/salt.go
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
|
||||||
|
//
|
||||||
|
// This software (Documize Community Edition) is licensed under
|
||||||
|
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
|
||||||
|
//
|
||||||
|
// You can operate outside the AGPL restrictions by purchasing
|
||||||
|
// Documize Enterprise Edition and obtaining a commercial license
|
||||||
|
// by contacting <sales@documize.com>.
|
||||||
|
//
|
||||||
|
// https://documize.com
|
||||||
|
|
||||||
|
package secrets
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/rand"
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
// RandSalt generates 16 character value for use in JWT token as salt.
|
||||||
|
func RandSalt() string {
|
||||||
|
b := make([]byte, 17)
|
||||||
|
|
||||||
|
_, err := rand.Read(b)
|
||||||
|
if err != nil {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
|
||||||
|
for k, v := range b {
|
||||||
|
if (v >= 'a' && v <= 'z') || (v >= 'A' && v <= 'Z') || (v >= '0' && v <= '0') {
|
||||||
|
b[k] = v
|
||||||
|
} else {
|
||||||
|
s := fmt.Sprintf("%x", v)
|
||||||
|
b[k] = s[0]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return string(b)
|
||||||
|
}
|
|
@ -13,43 +13,30 @@
|
||||||
package boot
|
package boot
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto/rand"
|
|
||||||
"fmt"
|
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/documize/community/core/database"
|
"github.com/documize/community/core/database"
|
||||||
"github.com/documize/community/core/env"
|
"github.com/documize/community/core/env"
|
||||||
|
"github.com/documize/community/core/secrets"
|
||||||
"github.com/documize/community/core/web"
|
"github.com/documize/community/core/web"
|
||||||
"github.com/jmoiron/sqlx"
|
"github.com/jmoiron/sqlx"
|
||||||
)
|
)
|
||||||
|
|
||||||
// InitRuntime prepares runtime using command line and environment variables.
|
// InitRuntime prepares runtime using command line and environment variables.
|
||||||
func InitRuntime(r *env.Runtime) bool {
|
func InitRuntime(r *env.Runtime) bool {
|
||||||
// Prepare SALT
|
// We need SALT to hash auth JWT tokens
|
||||||
if r.Flags.Salt == "" {
|
if r.Flags.Salt == "" {
|
||||||
b := make([]byte, 17)
|
r.Flags.Salt = secrets.RandSalt()
|
||||||
|
|
||||||
_, err := rand.Read(b)
|
if r.Flags.Salt == "" {
|
||||||
if err != nil {
|
|
||||||
r.Log.Error("problem using crypto/rand", err)
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
for k, v := range b {
|
|
||||||
if (v >= 'a' && v <= 'z') || (v >= 'A' && v <= 'Z') || (v >= '0' && v <= '0') {
|
|
||||||
b[k] = v
|
|
||||||
} else {
|
|
||||||
s := fmt.Sprintf("%x", v)
|
|
||||||
b[k] = s[0]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
r.Flags.Salt = string(b)
|
|
||||||
r.Log.Info("please set DOCUMIZESALT or use -salt with this value: " + r.Flags.Salt)
|
r.Log.Info("please set DOCUMIZESALT or use -salt with this value: " + r.Flags.Salt)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prepare HTTP ports
|
// We can use either or both HTTP and HTTPS ports
|
||||||
if r.Flags.SSLCertFile == "" && r.Flags.SSLKeyFile == "" {
|
if r.Flags.SSLCertFile == "" && r.Flags.SSLKeyFile == "" {
|
||||||
if r.Flags.HTTPPort == "" {
|
if r.Flags.HTTPPort == "" {
|
||||||
r.Flags.HTTPPort = "80"
|
r.Flags.HTTPPort = "80"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue