mirror of
https://github.com/0rangebananaspy/authelia.git
synced 2024-09-14 22:47:21 +07:00
8aade7f40e
* added regulation validator * made regulations find_time and ban_time values duration notation strings * added DefaultRegulationConfiguration for the validator * made session expiration and inactivity values duration notation strings * TOTP period does not need to be converted because adjustment should be discouraged * moved TOTP defaults to DefaultTOTPConfiguration and removed the consts * arranged the root config validator in configuration file order * adjusted tests for the changes * moved duration notation docs to root of configuration * added references to duration notation where applicable * project wide gofmt and goimports: * run gofmt * run goimports -local github.com/authelia/authelia -w on all files * Make jwt_secret error uniform and add tests * now at 100% coverage for internal/configuration/validator/configuration.go
33 lines
770 B
Go
33 lines
770 B
Go
package duo
|
|
|
|
import (
|
|
"net/url"
|
|
|
|
duoapi "github.com/duosecurity/duo_api_golang"
|
|
|
|
"github.com/authelia/authelia/internal/middlewares"
|
|
)
|
|
|
|
// API interface wrapping duo api library for testing purpose
|
|
type API interface {
|
|
Call(values url.Values, ctx *middlewares.AutheliaCtx) (*Response, error)
|
|
}
|
|
|
|
// APIImpl implementation of DuoAPI interface
|
|
type APIImpl struct {
|
|
*duoapi.DuoApi
|
|
}
|
|
|
|
// Response response coming from Duo API
|
|
type Response struct {
|
|
Response struct {
|
|
Result string `json:"result"`
|
|
Status string `json:"status"`
|
|
StatusMessage string `json:"status_msg"`
|
|
} `json:"response"`
|
|
Code int `json:"code"`
|
|
Message string `json:"message"`
|
|
MessageDetail string `json:"message_detail"`
|
|
Stat string `json:"stat"`
|
|
}
|