Add solvers to client

This commit is contained in:
xenolf 2015-06-11 01:11:14 +02:00
parent 0ca3e29eb4
commit 811c68692c

View file

@ -44,6 +44,7 @@ type challengeHandler interface {
type Client struct { type Client struct {
regURL string regURL string
user User user User
Solvers map[string]challengeHandler
} }
// NewClient creates a new client for the set user. // NewClient creates a new client for the set user.
@ -52,6 +53,11 @@ func NewClient(caURL string, usr User) *Client {
logger().Fatalf("Could not validate the private account key of %s -> %v", usr.GetEmail(), err) logger().Fatalf("Could not validate the private account key of %s -> %v", usr.GetEmail(), err)
} }
// REVIEW: best possibility?
solvers := make(map[string]challengeHandler)
solvers["simpleHttp"] = &simpleHTTPChallenge{}
solvers["dvsni"] = &dvsniChallenge{}
return &Client{regURL: caURL, user: usr} return &Client{regURL: caURL, user: usr}
} }
@ -152,15 +158,20 @@ func (c *Client) AgreeToTos() error {
func (c *Client) ObtainCertificates(domains []string) error { func (c *Client) ObtainCertificates(domains []string) error {
challenges := c.getChallenges(domains) challenges := c.getChallenges(domains)
c.doChallenges(challenges) c.solveChallenges(challenges)
return nil return nil
} }
func (c *Client) doChallenges(challenges []*authorizationResource) { // Looks through the challenge combinations to find a solvable match.
for _, auth := range challenges { // Then solves the challenges in series and returns.
func (c *Client) solveChallenges(challenges []*authorizationResource) {
// loop through the resources, basically through the domains.
for _, authz := challenges {
} }
} }
// Get the challenges needed to proof our identifier to the ACME server.
func (c *Client) getChallenges(domains []string) []*authorizationResource { func (c *Client) getChallenges(domains []string) []*authorizationResource {
resc, errc := make(chan *authorizationResource), make(chan error) resc, errc := make(chan *authorizationResource), make(chan error)