| // Copyright (c) HashiCorp, Inc. |
| // SPDX-License-Identifier: MPL-2.0 |
| |
| package api |
| |
| import ( |
| "context" |
| "fmt" |
| "net/http" |
| ) |
| |
| func (c *Sys) MFAValidate(requestID string, payload map[string]interface{}) (*Secret, error) { |
| return c.MFAValidateWithContext(context.Background(), requestID, payload) |
| } |
| |
| func (c *Sys) MFAValidateWithContext(ctx context.Context, requestID string, payload map[string]interface{}) (*Secret, error) { |
| ctx, cancelFunc := c.c.withConfiguredTimeout(ctx) |
| defer cancelFunc() |
| |
| body := map[string]interface{}{ |
| "mfa_request_id": requestID, |
| "mfa_payload": payload, |
| } |
| |
| r := c.c.NewRequest(http.MethodPost, fmt.Sprintf("/v1/sys/mfa/validate")) |
| if err := r.SetJSONBody(body); err != nil { |
| return nil, fmt.Errorf("failed to set request body: %w", err) |
| } |
| |
| resp, err := c.c.rawRequestWithContext(ctx, r) |
| if resp != nil { |
| defer resp.Body.Close() |
| } |
| if err != nil { |
| return nil, err |
| } |
| |
| secret, err := ParseSecret(resp.Body) |
| if err != nil { |
| return nil, fmt.Errorf("failed to parse secret from response: %w", err) |
| } |
| |
| if secret == nil { |
| return nil, fmt.Errorf("data from server response is empty") |
| } |
| |
| return secret, nil |
| } |