parent
d0afee5def
commit
3b752dc02e
@ -0,0 +1,112 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"github.com/go-yaml/yaml"
|
||||||
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
type SCORSHWorker_cfg struct {
|
||||||
|
Name string `yaml:"w_name"`
|
||||||
|
Repos []string `yaml:"w_repos"`
|
||||||
|
Folder string `yaml:"w_folder"`
|
||||||
|
Logfile string `yaml:"w_logfile"`
|
||||||
|
Tagfile string `yaml:"w_tagfile"`
|
||||||
|
Keyrings []string `yaml:"w_keyrings"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type SCORSHcfg struct {
|
||||||
|
Spooldir string `yaml:"s_spooldir"`
|
||||||
|
Logfile string `yaml:"s_logfile"`
|
||||||
|
LogPrefix string `yaml:"s_logprefix"`
|
||||||
|
Workers []SCORSHWorker_cfg `yaml:"s_workers"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read a configuration from fname or die
|
||||||
|
|
||||||
|
func ReadConfig(fname string) *SCORSHcfg {
|
||||||
|
|
||||||
|
data, err := ioutil.ReadFile(fname)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("Error while reading file: ", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
var cfg *SCORSHcfg
|
||||||
|
cfg = new(SCORSHcfg)
|
||||||
|
|
||||||
|
// Unmarshal the YAML configuration file into a SCORSHcfg structure
|
||||||
|
err = yaml.Unmarshal(data, cfg)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal("Error while reading configuration: ", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
fmt.Printf("%s", cfg)
|
||||||
|
|
||||||
|
// If the user has not set a spooldir, crash loudly
|
||||||
|
if cfg.Spooldir == "" {
|
||||||
|
log.Fatal("No spooldir defined in ", fname, ". Exiting\n")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if the user has set a custom logprefix
|
||||||
|
if cfg.LogPrefix != "" {
|
||||||
|
log.SetPrefix(cfg.LogPrefix)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if the user wants to redirect the logs to a file
|
||||||
|
if cfg.Logfile != "" {
|
||||||
|
f, err := os.Open(cfg.Logfile)
|
||||||
|
if err != nil {
|
||||||
|
log.SetOutput(io.Writer(f))
|
||||||
|
} else {
|
||||||
|
log.Printf("Error opening logfile: \n", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If we got so far, then there is some sort of config in cfg
|
||||||
|
log.Printf("Successfully read config from %s\n", fname)
|
||||||
|
|
||||||
|
return cfg
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cfg *SCORSHcfg) String() string {
|
||||||
|
|
||||||
|
var buff bytes.Buffer
|
||||||
|
|
||||||
|
buff.WriteString("spooldir: ")
|
||||||
|
buff.WriteString(cfg.Spooldir)
|
||||||
|
buff.WriteString("\nlogfile: ")
|
||||||
|
buff.WriteString(cfg.Logfile)
|
||||||
|
buff.WriteString("\nlogprefix: ")
|
||||||
|
buff.WriteString(cfg.LogPrefix)
|
||||||
|
buff.WriteString("\nWorkers: \n")
|
||||||
|
|
||||||
|
for _, w := range cfg.Workers {
|
||||||
|
buff.WriteString("---\n name: ")
|
||||||
|
buff.WriteString(w.Name)
|
||||||
|
buff.WriteString("\n repos: ")
|
||||||
|
for _, r := range w.Repos {
|
||||||
|
buff.WriteString("\n ")
|
||||||
|
buff.WriteString(r)
|
||||||
|
}
|
||||||
|
buff.WriteString("\n folder: ")
|
||||||
|
buff.WriteString(w.Folder)
|
||||||
|
buff.WriteString("\n logfile: ")
|
||||||
|
buff.WriteString(w.Logfile)
|
||||||
|
buff.WriteString("\n tagfile: ")
|
||||||
|
buff.WriteString(w.Tagfile)
|
||||||
|
buff.WriteString("\n keyrings: ")
|
||||||
|
for _, k := range w.Keyrings {
|
||||||
|
buff.WriteString("\n ")
|
||||||
|
buff.WriteString(k)
|
||||||
|
}
|
||||||
|
buff.WriteString("\n...\n")
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return buff.String()
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
#
|
||||||
|
# This is a typical scorsh configuration. We declare here the list of
|
||||||
|
# workers, with the corresponding repo/branches regular expressions
|
||||||
|
# and the associated folder
|
||||||
|
#
|
||||||
|
|
||||||
|
---
|
||||||
|
s_spooldir: "/var/spool/scorsh"
|
||||||
|
s_logfile: "/var/log/scorsh/scorsh.log"
|
||||||
|
s_logprefix: "[scorsh]"
|
||||||
|
|
||||||
|
s_workers:
|
||||||
|
[
|
||||||
|
{
|
||||||
|
w_name: catchall,
|
||||||
|
w_repos: ["*:*"], # All branches in all repos
|
||||||
|
w_folder: ./catchall,
|
||||||
|
w_logfile: ./catchall/catchall.log,
|
||||||
|
w_tagfile: "./catchall/tags.cfg",
|
||||||
|
w_keyrings: [
|
||||||
|
"./catchall/catchall_keyring.asc"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
w_name: ascii,
|
||||||
|
w_repos: ["*:suites/ascii", # branch "suites/ascii" in all the repos
|
||||||
|
"*:suites/ascii-updates",
|
||||||
|
"*:suites/ascii-security"
|
||||||
|
],
|
||||||
|
w_folder: ./ascii,
|
||||||
|
w_logfile: ./worker_ascii.log,
|
||||||
|
w_tagfile: "./ascii/tags.cfg",
|
||||||
|
w_keyrings: [
|
||||||
|
"./${w_folder}/ascii_keyring.asc"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
w_name: ascii-side-branches ,
|
||||||
|
w_repos: [
|
||||||
|
"*:suites/ascii-proposed",
|
||||||
|
"*:suites/ascii-proposed-updates"
|
||||||
|
],
|
||||||
|
w_folder: ./ascii-side-branches,
|
||||||
|
w_logfile: ./worker_ascii_side_branches.log,
|
||||||
|
w_tagfile: "./ascii-side-branches/tags.cfg",
|
||||||
|
w_keyrings: [
|
||||||
|
"./${w_folder}/ascii_keyring.asc",
|
||||||
|
"./${w_folder}/ascii_proposed_keyring.asc",
|
||||||
|
"./${w_folder}/ascii_proposed_updates_keyring.asc"
|
||||||
|
],
|
||||||
|
}
|
||||||
|
]
|
||||||
|
...
|
Loading…
Reference in new issue