package main import ( "flag" "log" "dim13.org/acme" ) var confName = flag.String("conf", "acme.toml", "configuration file") func prepare(conf *Config) error { var err error for k, acc := range conf.Account { log.Println("LoadAccount", k) acc.Account, err = acme.LoadAccount(acc.Key) if err != nil { log.Println(err) log.Println("NewAccount", k) acc.Account, err = acme.NewAccount(acc.KeySize) if err != nil { return err } acc.Account.SaveKey(acc.Key) acc.pending = true } acc.Contacts.AddMail(acc.Mail) acc.Contacts.AddPhone(acc.Phone) conf.Account[k] = acc } for k, des := range conf.Desire { log.Println("NewDesire", k) des.Desire, err = acme.NewDesire(des.Altnames, des.Webroot, des.KeySize) if err != nil { return err } conf.Desire[k] = des } for k, pro := range conf.Provider { log.Println("NewProvider", k) pro.Provider, err = acme.NewProvider(pro.Directory) if err != nil { return err } conf.Provider[k] = pro } return nil } func execute(conf *Config) error { var err error for k, des := range conf.Desire { if des.account.pending { err = des.provider.Register(des.account, des.account.Contacts) if err != nil { return err } } hs := &httpChallenge{Webroot: des.Webroot} des.RegisterSolver(acme.ChallengeHTTP, hs) log.Println("process", k) err = des.provider.Authorize(des.account, des.Desire) if err != nil { return err } err = des.provider.Cert(des.account, des.Desire) if err != nil { return err } des.SaveKey(des.Key) des.SaveCert(des.Cert) } return nil } func main() { flag.Parse() conf, err := LoadConfig(*confName) if err != nil { log.Fatal(err) } if err := prepare(conf); err != nil { log.Fatal(err) } httpSolver(conf.Defaults.Listen) if err := execute(conf); err != nil { log.Fatal(err) } }