Skip to content
Snippets Groups Projects
Select Git revision
  • c183df54f770c49c7f3f5c710b74c06a2c0c6b15
  • release default protected
  • 11-22-implement-kv-interface-defined-in-collectiveversionedkvgo
  • hotfix/TestHostPool_UpdateNdf_AddFilter
  • XX-4719/announcementChannels
  • xx-4717/logLevel
  • jonah/noob-channel
  • master protected
  • XX-4707/tagDiskJson
  • xx-4698/notification-retry
  • hotfix/notifylockup
  • syncNodes
  • hotfix/localCB
  • XX-4677/NewChanManagerMobile
  • XX-4689/DmSync
  • duplicatePrefix
  • XX-4601/HavenInvites
  • finalizedUICallbacks
  • XX-4673/AdminKeySync
  • debugNotifID
  • anne/test
  • v4.7.5
  • v4.7.4
  • v4.7.3
  • v4.7.2
  • v4.7.1
  • v4.6.3
  • v4.6.1
  • v4.5.0
  • v4.4.4
  • v4.3.11
  • v4.3.8
  • v4.3.7
  • v4.3.6
  • v4.3.5
  • v4.2.0
  • v4.3.0
  • v4.3.4
  • v4.3.3
  • v4.3.2
  • v4.3.1
41 results

secrets.go

  • secrets.go 1.17 KiB
    ///////////////////////////////////////////////////////////////////////////////
    // Copyright © 2020 xx network SEZC                                          //
    //                                                                           //
    // Use of this source code is governed by a license that can be found in the //
    // LICENSE file                                                              //
    ///////////////////////////////////////////////////////////////////////////////
    
    package bindings
    
    import (
    	jww "github.com/spf13/jwalterweatherman"
    	"gitlab.com/xx_network/crypto/csprng"
    )
    
    // GenerateSecret creates a secret password using a system-based
    // pseudorandom number generator. It takes 1 parameter, `numBytes`,
    // which should be set to 32, but can be set higher in certain cases.
    func GenerateSecret(numBytes int) []byte {
    	if numBytes < 32 {
    		jww.FATAL.Panicf("Secrets must have at least 32 bytes " +
    			"(256 bits) of entropy.")
    	}
    
    	out := make([]byte, numBytes)
    	rng := csprng.NewSystemRNG()
    	numRead, err := rng.Read(out)
    	if err != nil {
    		jww.FATAL.Panicf("%+v", err)
    	}
    	if numRead != numBytes {
    		jww.FATAL.Panicf("Unable to read %d bytes", numBytes)
    	}
    	return out
    }