59 lines
1.3 KiB
Go
59 lines
1.3 KiB
Go
package main
|
|
|
|
import (
|
|
"bytes"
|
|
"errors"
|
|
"fmt"
|
|
"io/ioutil"
|
|
|
|
"github.com/status-im/status-go/params"
|
|
)
|
|
|
|
// whisperConfig creates node configuration object from flags
|
|
func whisperConfig(nodeConfig *params.NodeConfig) (*params.NodeConfig, error) {
|
|
whisperConfig := nodeConfig.WhisperConfig
|
|
whisperConfig.Enabled = true
|
|
whisperConfig.EnableMailServer = *enableMailServer
|
|
whisperConfig.LightClient = *lightClient
|
|
whisperConfig.MinimumPoW = *minPow
|
|
whisperConfig.TTL = *ttl
|
|
|
|
if whisperConfig.EnableMailServer {
|
|
if *passwordFile == "" {
|
|
return nil, errors.New("passwordfile should be specified if MailServer is enabled")
|
|
}
|
|
|
|
password, err := readFile(*passwordFile)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("password file: %v", err)
|
|
}
|
|
|
|
whisperConfig.MailServerPassword = string(password)
|
|
}
|
|
|
|
// firebase configuration
|
|
firebaseConfig := whisperConfig.FirebaseConfig
|
|
firebaseConfig.AuthorizationKeyFile = *firebaseAuth
|
|
if firebaseConfig.AuthorizationKeyFile != "" {
|
|
if _, err := firebaseConfig.ReadAuthorizationKeyFile(); err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
|
|
return nodeConfig, nil
|
|
}
|
|
|
|
func readFile(path string) ([]byte, error) {
|
|
data, err := ioutil.ReadFile(path)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
data = bytes.TrimRight(data, "\n")
|
|
|
|
if len(data) == 0 {
|
|
return nil, errors.New("file is empty")
|
|
}
|
|
|
|
return data, nil
|
|
}
|