mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-26 13:48:53 +08:00

* Use per-service URL in SDK Signed-off-by: Drasko DRASKOVIC <drasko.draskovic@gmail.com> * Fix CLI Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Fix CLI messaging Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Fix message tests Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Simplify Bootstrap Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Update API doc and responses Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * fix failing certs, bootstrap tests Signed-off-by: mteodor <mirko.teodorovic@gmail.com> * fix failing certs, bootstrap tests Signed-off-by: mteodor <mirko.teodorovic@gmail.com> * Fix tests and rename to auth service Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Clean the code Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Remove unnecessary Repository logs Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Always return error in case of repo failure Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Cleanup SDK and CLI Update tests, remove linter warnings, remove dead code. Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Clean the code Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Undo Bootstrap changes Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Fix tests Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> * Fix linter Signed-off-by: Drasko Draskovic <drasko.draskovic@gmail.com> Co-authored-by: mteodor <mirko.teodorovic@gmail.com> Co-authored-by: dusanb94 <dusan.borovcanin@mainflux.com>
98 lines
3.1 KiB
Go
98 lines
3.1 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package provision
|
|
|
|
import (
|
|
"fmt"
|
|
"io/ioutil"
|
|
|
|
"github.com/mainflux/mainflux/pkg/errors"
|
|
"github.com/pelletier/go-toml"
|
|
)
|
|
|
|
// Service represents service config.
|
|
type ServiceConf struct {
|
|
Port string `toml:"port"`
|
|
LogLevel string `toml:"log_level"`
|
|
TLS bool `toml:"tls"`
|
|
ServerCert string `toml:"server_cert"`
|
|
ServerKey string `toml:"server_key"`
|
|
ThingsURL string `toml:"things_url"`
|
|
UsersURL string `toml:"users_url"`
|
|
HTTPPort string `toml:"http_port"`
|
|
MfUser string `toml:"mf_user"`
|
|
MfPass string `toml:"mf_pass"`
|
|
MfAPIKey string `toml:"mf_api_key"`
|
|
MfBSURL string `toml:"mf_bs_url"`
|
|
MfWhiteListURL string `toml:"mf_white_list"`
|
|
MfCertsURL string `toml:"mf_certs_url"`
|
|
}
|
|
|
|
type Bootstrap struct {
|
|
X509Provision bool `toml:"x509_provision"`
|
|
Provision bool `toml:"provision"`
|
|
AutoWhiteList bool `toml:"autowhite_list"`
|
|
Content map[string]interface{} `toml:"content"`
|
|
}
|
|
type Channel struct {
|
|
Name string `toml:"name"`
|
|
Metadata map[string]interface{} `toml:"metadata" mapstructure:"metadata"`
|
|
}
|
|
type Thing struct {
|
|
Name string `toml:"name"`
|
|
Metadata map[string]interface{} `toml:"metadata" mapstructure:"metadata"`
|
|
}
|
|
|
|
type Gateway struct {
|
|
Type string `toml:"type" json:"type"`
|
|
ExternalID string `toml:"external_id" json:"external_id"`
|
|
ExternalKey string `toml:"external_key" json:"external_key"`
|
|
CtrlChannelID string `toml:"ctrl_channel_id" json:"ctrl_channel_id"`
|
|
DataChannelID string `toml:"data_channel_id" json:"data_channel_id"`
|
|
ExportChannelID string `toml:"export_channel_id" json:"export_channel_id"`
|
|
CfgID string `toml:"cfg_id" json:"cfg_id"`
|
|
}
|
|
|
|
type Certs struct {
|
|
HoursValid string `json:"days_valid" toml:"days_valid"`
|
|
KeyBits int `json:"key_bits" toml:"key_bits"`
|
|
KeyType string `json:"key_type"`
|
|
}
|
|
|
|
// Config struct of Provision
|
|
type Config struct {
|
|
File string `toml:"file"`
|
|
Server ServiceConf `toml:"server" mapstructure:"server"`
|
|
Bootstrap Bootstrap `toml:"bootstrap" mapstructure:"bootstrap"`
|
|
Things []Thing `toml:"things" mapstructure:"things"`
|
|
Channels []Channel `toml:"channels" mapstructure:"channels"`
|
|
Certs Certs `toml:"certs" mapstructure:"certs"`
|
|
}
|
|
|
|
// Save - store config in a file
|
|
func Save(c Config, file string) error {
|
|
b, err := toml.Marshal(c)
|
|
if err != nil {
|
|
return errors.New(fmt.Sprintf("Error reading config file: %s", err))
|
|
}
|
|
if err := ioutil.WriteFile(file, b, 0644); err != nil {
|
|
return errors.New(fmt.Sprintf("Error writing toml: %s", err))
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Read - retrieve config from a file
|
|
func Read(file string) (Config, error) {
|
|
data, err := ioutil.ReadFile(file)
|
|
c := Config{}
|
|
if err != nil {
|
|
return c, errors.New(fmt.Sprintf("Error reading config file: %s", err))
|
|
}
|
|
|
|
if err := toml.Unmarshal(data, &c); err != nil {
|
|
return Config{}, errors.New(fmt.Sprintf("Error unmarshaling toml: %s", err))
|
|
}
|
|
return c, nil
|
|
}
|