2024-04-24 10:49:47 +02:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"encoding/json"
|
|
|
|
"os"
|
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"forge.cadoles.com/arcad/arcast/pkg/server"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"gitlab.com/wpetit/goweb/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Config struct {
|
2024-04-24 17:32:01 +02:00
|
|
|
InstanceID string `json:"instanceId"`
|
|
|
|
HTTP HTTPConfig `json:"http"`
|
|
|
|
HTTPS HTTPSConfig `json:"https"`
|
|
|
|
Apps AppsConfig `json:"apps"`
|
|
|
|
AllowedOrigins []string `json:"allowedOrigins"`
|
2024-04-24 10:49:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type HTTPConfig struct {
|
2024-04-26 12:10:59 +02:00
|
|
|
Address string `json:"address"`
|
|
|
|
CustomDir string `json:"customDir"`
|
2024-04-24 10:49:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type HTTPSConfig struct {
|
|
|
|
Address string `json:"address"`
|
|
|
|
Cert []byte `json:"cert"`
|
|
|
|
Key []byte `json:"key"`
|
|
|
|
SelfSigned SelfSignedCertConfig `json:"selfSigned"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type SelfSignedCertConfig struct {
|
|
|
|
Enabled bool `json:"enabled"`
|
|
|
|
NetworkFingerprint string `json:"networkFingerprint"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type AppsConfig struct {
|
|
|
|
Enabled bool `json:"enabled"`
|
|
|
|
DefaultApp string `json:"defaultApp"`
|
|
|
|
}
|
|
|
|
|
2024-04-26 12:10:59 +02:00
|
|
|
type TransformFunc func(ctx context.Context, filename string, conf *Config) error
|
2024-04-24 10:49:47 +02:00
|
|
|
|
|
|
|
func DefaultConfigFile(ctx context.Context) string {
|
|
|
|
configDir, err := os.UserConfigDir()
|
|
|
|
if err != nil {
|
|
|
|
logger.Error(ctx, "could not get user config dir", logger.CapturedE(errors.WithStack(err)))
|
|
|
|
configDir = ""
|
|
|
|
}
|
|
|
|
|
|
|
|
if configDir != "" {
|
|
|
|
configDir = filepath.Join(configDir, "arcast-player")
|
|
|
|
}
|
|
|
|
|
|
|
|
return filepath.Join(configDir, "config.json")
|
|
|
|
}
|
|
|
|
|
|
|
|
func LoadOrCreate(ctx context.Context, filename string, conf *Config, funcs ...TransformFunc) error {
|
|
|
|
data, err := os.ReadFile(filename)
|
|
|
|
if err != nil && !os.IsNotExist(err) {
|
|
|
|
return errors.WithStack(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if data != nil {
|
|
|
|
if err := json.Unmarshal(data, conf); err != nil {
|
|
|
|
return errors.WithStack(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, fn := range funcs {
|
2024-04-26 12:10:59 +02:00
|
|
|
if err := fn(ctx, filename, conf); err != nil {
|
2024-04-24 10:49:47 +02:00
|
|
|
return errors.WithStack(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
data, err = json.MarshalIndent(conf, "", " ")
|
|
|
|
if err != nil {
|
|
|
|
return errors.WithStack(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
dirname := filepath.Dir(filename)
|
|
|
|
|
|
|
|
if _, err := os.Stat(dirname); os.IsNotExist(err) {
|
|
|
|
if err := os.MkdirAll(dirname, 0777); err != nil {
|
|
|
|
return errors.WithStack(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := os.WriteFile(filename, data, 0640); err != nil {
|
|
|
|
return errors.WithStack(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func DefaultConfig() *Config {
|
|
|
|
return &Config{
|
2024-04-24 17:32:01 +02:00
|
|
|
InstanceID: server.NewRandomInstanceID(),
|
|
|
|
AllowedOrigins: []string{},
|
2024-04-24 10:49:47 +02:00
|
|
|
HTTP: HTTPConfig{
|
2024-04-26 12:10:59 +02:00
|
|
|
Address: ":45555",
|
|
|
|
CustomDir: "",
|
2024-04-24 10:49:47 +02:00
|
|
|
},
|
|
|
|
HTTPS: HTTPSConfig{
|
|
|
|
Address: ":45556",
|
|
|
|
SelfSigned: SelfSignedCertConfig{
|
|
|
|
Enabled: true,
|
|
|
|
NetworkFingerprint: "",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Apps: AppsConfig{
|
|
|
|
Enabled: true,
|
2024-04-24 17:32:01 +02:00
|
|
|
DefaultApp: "main",
|
2024-04-24 10:49:47 +02:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|