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